Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Schema 4.5 - Initial release #1042

Merged
merged 47 commits into from
Dec 4, 2023
Merged
Show file tree
Hide file tree
Changes from 36 commits
Commits
Show all changes
47 commits
Select commit Hold shift + click to select a range
800a6e5
Temporarily - pull the schema-4.5 bolognese branch - for development.
svogt0511 Oct 4, 2023
9e21f05
Merge remote-tracking branch 'origin/master' into schema-4.5-r2
svogt0511 Oct 4, 2023
71251f7
Appease rubocop.
svogt0511 Oct 4, 2023
cbf19ae
Elastic search and misc
svogt0511 Oct 6, 2023
a4dc6b7
Fix syntax errors.
svogt0511 Oct 6, 2023
02823f2
Preliminary support for receiving and storing publisher hash values
codycooperross Oct 6, 2023
3ab5c6c
Use updated bolognese from schema-4.5-r2 branch - ref works better th…
svogt0511 Oct 8, 2023
67e5ff4
Added accessor for publisher in doi model, serializer, and ?publisher…
svogt0511 Oct 13, 2023
b54dbbf
Fix to serializer for null publisher.
svogt0511 Oct 13, 2023
80b6d5b
More fixes.
svogt0511 Oct 15, 2023
d3dff8c
Fixes to serializer for publisher param when data is from ES; refinem…
codycooperross Oct 16, 2023
b907405
Normalization for publisher-as-hash in GraphQL WorkType
codycooperross Oct 16, 2023
b5e47c8
Support for publisher hash in WorkSerializer; test corrections for bo…
codycooperross Oct 19, 2023
85326ed
Merge remote-tracking branch 'origin/master' into schema-4.5-r2
svogt0511 Oct 23, 2023
4ba23fa
Update bolognese gem (from bolognese schema-4.5 branch)
svogt0511 Oct 23, 2023
203483e
Update schema -4.5-r2 branch from master
svogt0511 Oct 24, 2023
c462c44
Make publisher_obj private.
svogt0511 Oct 24, 2023
28b07dd
Allow publisher=true to available options for validate (and affiliati…
svogt0511 Oct 25, 2023
eb0e99a
First installment of migration script (publisher => publisher_obj). …
svogt0511 Oct 25, 2023
856e495
Change private to protected on publisher_obj accessors.
svogt0511 Oct 26, 2023
a069e3d
Mods for activities endpoint.
svogt0511 Oct 28, 2023
ddfd286
Mods for activities endpoint. Made publisher_obj accessors public to…
svogt0511 Oct 28, 2023
703bb65
Tests for activities endpoint - publishers flag.
svogt0511 Oct 29, 2023
dc9c611
Validation for publisher_obj (activerecord_json_validator).
svogt0511 Nov 1, 2023
14cb361
Mods to publisher/publisher_obj. (activerecord_json_validator).
svogt0511 Nov 3, 2023
61bd4ad
Merge remote-tracking branch 'origin/master' into schema-4.5-r2
svogt0511 Nov 3, 2023
a1cc1a9
Clean blank and null properties from publisher parameters in datacite…
svogt0511 Nov 3, 2023
a1974b1
Merge remote-tracking branch 'origin/master' into schema-4.5-r2
svogt0511 Nov 4, 2023
c104c9d
Revert back original to publisher_obj validation.
svogt0511 Nov 4, 2023
be0bbd3
Allow blank/null publisher_obj properties.
svogt0511 Nov 7, 2023
e685e04
Validation.
svogt0511 Nov 7, 2023
676ded1
Move processing of null parameters over to update_publisher.
svogt0511 Nov 9, 2023
c0a98ca
Appease rubocop.
svogt0511 Nov 13, 2023
b6756d5
Cleanup
codycooperross Nov 14, 2023
dde6e51
Publisher param test corrections
codycooperross Nov 16, 2023
11cd92c
Merge remote-tracking branch 'origin/master' into schema-4.5-r2
svogt0511 Nov 27, 2023
8fa20c1
Mods from suggestions in PR.
svogt0511 Nov 27, 2023
3926084
Appease rubocop.
svogt0511 Nov 27, 2023
8e8bb94
Use updated bolognese branch.
svogt0511 Nov 27, 2023
9916391
Cleanup syntax error.
svogt0511 Nov 27, 2023
1782bb3
Appease rubocop.
svogt0511 Nov 27, 2023
b7db165
Revert some changes.
svogt0511 Nov 28, 2023
06c5e31
DOI serializer.
svogt0511 Nov 28, 2023
7954d19
Cleanup.
svogt0511 Nov 28, 2023
668c643
Update bolognese branch.
svogt0511 Dec 1, 2023
cbce6af
Update bolognese to use v2.0.0
svogt0511 Dec 4, 2023
580e305
Implementing review comment.
svogt0511 Dec 4, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion Gemfile
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,8 @@ gem "aws-sdk-sqs", "~> 1.3"
gem "base32-url", "~> 0.3"
gem "batch-loader", "~> 1.4", ">= 1.4.1"
gem "bcrypt", "~> 3.1.7"
gem "bolognese", "~> 1.11.5"
# gem "bolognese", "~> 1.11.5"
gem "bolognese", git: "https://github.com/datacite/bolognese", branch: "schema-4.5"
ashwinisukale marked this conversation as resolved.
Show resolved Hide resolved
gem "bootsnap", "~> 1.4", ">= 1.4.4", require: false
gem "cancancan", "~> 3.0"
gem "commonmarker", "~> 0.23.4"
Expand Down
58 changes: 32 additions & 26 deletions Gemfile.lock
Original file line number Diff line number Diff line change
@@ -1,3 +1,33 @@
GIT
remote: https://github.com/datacite/bolognese
revision: 714d71a4a2169d1880ccb296df3ca1331e0e1a83
branch: schema-4.5
specs:
bolognese (1.11.5)
activesupport (>= 4.2.5)
benchmark_methods (~> 0.7)
bibtex-ruby (>= 5.1.0)
builder (~> 3.2, >= 3.2.2)
citeproc-ruby (~> 1.1, >= 1.1.12)
colorize (~> 0.8.1)
concurrent-ruby (~> 1.1, >= 1.1.5)
csl-styles (~> 1.0, >= 1.0.1.10)
edtf (~> 3.0, >= 3.0.4)
gender_detector (~> 0.1.2)
iso8601 (~> 0.9.1)
json-ld-preloaded (~> 3.1, >= 3.1.3)
jsonlint (~> 0.3.0)
loofah (~> 2.0, >= 2.0.3)
maremma (>= 4.9.4, < 5)
namae (~> 1.0)
nokogiri (>= 1.13.2, < 1.14)
oj (~> 3.10)
oj_mimic_json (~> 1.0, >= 1.0.1)
postrank-uri (~> 1.0, >= 1.0.18)
rdf-rdfxml (~> 3.1)
rdf-turtle (~> 3.1)
thor (>= 0.19)

GEM
remote: https://rubygems.org/
specs:
Expand Down Expand Up @@ -113,30 +143,6 @@ GEM
latex-decode (~> 0.0)
binding_of_caller (1.0.0)
debug_inspector (>= 0.0.1)
bolognese (1.11.5)
activesupport (>= 4.2.5)
benchmark_methods (~> 0.7)
bibtex-ruby (>= 5.1.0)
builder (~> 3.2, >= 3.2.2)
citeproc-ruby (~> 1.1, >= 1.1.12)
colorize (~> 0.8.1)
concurrent-ruby (~> 1.1, >= 1.1.5)
csl-styles (~> 1.0, >= 1.0.1.10)
edtf (~> 3.0, >= 3.0.4)
gender_detector (~> 0.1.2)
iso8601 (~> 0.9.1)
json-ld-preloaded (~> 3.1, >= 3.1.3)
jsonlint (~> 0.3.0)
loofah (~> 2.0, >= 2.0.3)
maremma (>= 4.9.4, < 5)
namae (~> 1.0)
nokogiri (>= 1.13.2, < 1.14)
oj (~> 3.10)
oj_mimic_json (~> 1.0, >= 1.0.1)
postrank-uri (~> 1.0, >= 1.0.18)
rdf-rdfxml (~> 3.1)
rdf-turtle (~> 3.1)
thor (>= 0.19)
bootsnap (1.15.0)
msgpack (~> 1.2)
builder (3.2.4)
Expand Down Expand Up @@ -656,7 +662,7 @@ DEPENDENCIES
bcrypt (~> 3.1.7)
better_errors
binding_of_caller
bolognese (~> 1.11.5)
bolognese!
bootsnap (~> 1.4, >= 1.4.4)
bullet (~> 6.1)
byebug
Expand Down Expand Up @@ -749,4 +755,4 @@ DEPENDENCIES
webmock (~> 3.1)

BUNDLED WITH
2.4.10
2.4.20
9 changes: 9 additions & 0 deletions app/controllers/activities_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,9 @@ def index
end,
}.compact
options[:is_collection] = true
options[:params] = {
publisher: params[:publisher],
}

render json: ActivitySerializer.new(results, options).serialized_json,
status: :ok
Expand Down Expand Up @@ -105,6 +108,9 @@ def index
}.compact
options[:include] = @include
options[:is_collection] = true
options[:params] = {
publisher: params[:publisher],
}

render json: ActivitySerializer.new(results, options).serialized_json,
status: :ok
Expand All @@ -129,6 +135,9 @@ def show
options = {}
options[:include] = @include
options[:is_collection] = false
options[:params] = {
publisher: params[:publisher],
}

render json: ActivitySerializer.new(@activity, options).serialized_json,
status: :ok
Expand Down
12 changes: 11 additions & 1 deletion app/controllers/datacite_dois_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -196,6 +196,7 @@ def index
current_ability: current_ability,
detail: params[:detail],
affiliation: params[:affiliation],
publisher: params[:publisher],
is_collection: options[:is_collection],
}

Expand Down Expand Up @@ -339,6 +340,7 @@ def index
detail: params[:detail],
composite: params[:composite],
affiliation: params[:affiliation],
publisher: params[:publisher],
# The cursor link should be an array of values, but we want to encode it into a single string for the URL
"page[cursor]" =>
page[:cursor] ? make_cursor(results) : nil,
Expand All @@ -359,6 +361,7 @@ def index
detail: params[:detail],
composite: params[:composite],
affiliation: params[:affiliation],
publisher: params[:publisher],
is_collection: options[:is_collection],
}

Expand Down Expand Up @@ -459,6 +462,7 @@ def show
detail: true,
composite: nil,
affiliation: params[:affiliation],
publisher: params[:publisher],
}

render json: DataciteDoiSerializer.new(doi, options).serialized_json,
Expand Down Expand Up @@ -511,7 +515,11 @@ def validate
options = {}
options[:include] = @include
options[:is_collection] = false
options[:params] = { current_ability: current_ability }
options[:params] = {
current_ability: current_ability,
affiliation: params[:affiliation],
publisher: params[:publisher]
}

render json: DataciteDoiSerializer.new(@doi, options).serialized_json,
status: :ok
Expand Down Expand Up @@ -539,6 +547,7 @@ def create
current_ability: current_ability,
detail: true,
affiliation: params[:affiliation],
publisher: params[:publisher],
}

render json: DataciteDoiSerializer.new(@doi, options).serialized_json,
Expand Down Expand Up @@ -597,6 +606,7 @@ def update
current_ability: current_ability,
detail: true,
affiliation: params[:affiliation],
publisher: params[:publisher],
}

render json: DataciteDoiSerializer.new(@doi, options).serialized_json,
Expand Down
10 changes: 9 additions & 1 deletion app/graphql/types/doi_item.rb
Original file line number Diff line number Diff line change
Expand Up @@ -579,6 +579,14 @@ def identifiers
end
end

def publisher
if object.publisher.respond_to?(:to_hash)
object.publisher["name"]
elsif object.publisher.respond_to?(:to_str)
object.publisher
end
end

svogt0511 marked this conversation as resolved.
Show resolved Hide resolved
def bibtex
pages =
if object.container.to_h["firstPage"].present?
Expand Down Expand Up @@ -909,7 +917,7 @@ def citeproc_hsh
"volume" => object.container.to_h["volume"],
"issue" => object.container.to_h["issue"],
"page" => page,
"publisher" => object.publisher,
"publisher" => object.publisher["name"] || object.publisher,
ashwinisukale marked this conversation as resolved.
Show resolved Hide resolved
"title" => parse_attributes(object.titles, content: "title", first: true),
"URL" => object.url,
"version" => object.version_info,
Expand Down
14 changes: 14 additions & 0 deletions app/jobs/doi_convert_publisher_by_id_job.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
# frozen_string_literal: true

class DoiConvertPublisherByIdJob < ApplicationJob
queue_as :lupo_background

rescue_from ActiveJob::DeserializationError,
Elasticsearch::Transport::Transport::Errors::BadRequest do |error|
Rails.logger.error error.message
end

def perform(options = {})
Doi.convert_publisher_by_id(options)
end
end
9 changes: 9 additions & 0 deletions app/lib/params_sanitizer.rb
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,15 @@ class ParamsSanitizer
:titles,
{ titles: %i[title titleType lang] },
:publisher,
{
publisher: %i[
name
publisherIdentifier
publisherIdentifierScheme
schemeUri
lang
],
},
:publicationYear,
:created,
:prefix,
Expand Down
Loading