From dd21fa319540cc0d08d85dd01144b093d7e2e97c Mon Sep 17 00:00:00 2001 From: Kristian Garza Date: Mon, 17 Sep 2018 09:16:48 +0200 Subject: [PATCH 1/6] Enable doi transfers We could separate this into another module. Maybe later --- lib/cirneco/api.rb | 9 +++++++++ lib/cirneco/doi.rb | 26 ++++++++++++++++++++++++++ lib/cirneco/utils.rb | 20 ++++++++++++++++++++ 3 files changed, 55 insertions(+) diff --git a/lib/cirneco/api.rb b/lib/cirneco/api.rb index e07fa55..a9a32b5 100644 --- a/lib/cirneco/api.rb +++ b/lib/cirneco/api.rb @@ -21,6 +21,15 @@ def put_metadata(doi, options={}) Maremma.put(url, content_type: 'application/xml;charset=UTF-8', data: options[:data], username: options[:username], password: options[:password]) end + def transfer_doi(doi, options={}) + return OpenStruct.new(body: { "errors" => [{ "title" => "JWT missing" }] }) unless options[:jwt].present? + + api_url = options[:sandbox] ? 'https://api.test.datacite.org' : 'https://api.datacite.org' + + url = URI.encode("#{api_url}/dois/#{doi}") + Maremma.patch(url, content_type: 'application/vnd.api+json;charset=UTF-8', data: options[:data], bearer: options[:jwt]) + end + def get_metadata(doi, options={}) return OpenStruct.new(body: { "errors" => [{ "title" => "Username or password missing" }] }) unless options[:username].present? && options[:password].present? diff --git a/lib/cirneco/doi.rb b/lib/cirneco/doi.rb index 2de0a53..50e6a7e 100644 --- a/lib/cirneco/doi.rb +++ b/lib/cirneco/doi.rb @@ -1,5 +1,6 @@ require 'thor' require 'bolognese' +require 'csv' require_relative 'api' require_relative 'utils' @@ -9,6 +10,7 @@ module Cirneco class Doi < Thor include Cirneco::Base include Cirneco::Api + include Cirneco::Lupo include Cirneco::Utils include Bolognese::Utils include Bolognese::DoiUtils @@ -112,5 +114,29 @@ def check(doi) puts "Checksum for #{doi} is not valid" end end + + desc "transfer DOIs", "transfer list of DOIs" + method_option :jwt, :default => ENV['JWT'] + method_option :target, :type => :string + method_option :sandbox, :type => :boolean, :force => false + def transfer(file) + count = 0 + File.foreach(file) do |line| + doi = line.rstrip + next unless doi.present? + meta = generate_transfer_template(options) + + response = transfer_doi(doi, options.merge(data: meta.to_json)) + + if [200, 201].include?(response.status) + puts "#{doi} Transfered to #{options[:target]}." + count += 1 + else + puts "Error: " + response.body["errors"].first.fetch("title", "An error occured") + end + end + + puts "#{count} DOIs transfered." + end end end diff --git a/lib/cirneco/utils.rb b/lib/cirneco/utils.rb index 9c4f8b8..fb5cce1 100644 --- a/lib/cirneco/utils.rb +++ b/lib/cirneco/utils.rb @@ -18,6 +18,26 @@ def get_dois_by_prefix(prefix, options={}) response end + def generate_transfer_template(options={}) + response = { + "data" => { + "type" => "dois", + "attributes" => { + "mode" => "transfer" + }, + "relationships"=> { + "client"=> { + "data"=> { + "type"=> "clients", + "id"=> options[:target].downcase + } + } + } + } + } + response + end + def decode_doi(doi) prefix, string = doi.split('/', 2) Base32::URL.decode(string, checksum: true).to_i From 23e1ab560ee152ac5865dc2e62c0e396ae1c78a7 Mon Sep 17 00:00:00 2001 From: Kristian Garza Date: Mon, 17 Sep 2018 09:16:59 +0200 Subject: [PATCH 2/6] version and libraries --- Gemfile.lock | 16 ++++++++-------- lib/cirneco/version.rb | 2 +- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/Gemfile.lock b/Gemfile.lock index f16f58c..db247ff 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -1,7 +1,7 @@ PATH remote: . specs: - cirneco (0.9.25) + cirneco (0.9.28) activesupport (>= 4.2.5, < 6) base32-url (~> 0.5) bergamasco (~> 0.3) @@ -36,7 +36,7 @@ GEM safe_yaml (~> 1.0, >= 1.0.4) bibtex-ruby (4.4.7) latex-decode (~> 0.0) - bolognese (0.13.4) + bolognese (0.14.1) activesupport (>= 4.2.5, < 6) benchmark_methods (~> 0.7) bibtex-ruby (~> 4.1) @@ -66,13 +66,13 @@ GEM diff-lcs (1.3) docile (1.1.5) dotenv (2.5.0) - ebnf (1.1.2) - rdf (>= 2.2, < 4.0) + ebnf (1.1.3) + rdf (~> 3.0) sxp (~> 1.0) excon (0.62.0) faraday (0.15.2) multipart-post (>= 1.2, < 3) - faraday-encoding (0.0.4) + faraday-encoding (0.0.5) faraday faraday_middleware (0.12.2) faraday (>= 0.7.4, < 1.0) @@ -129,7 +129,7 @@ GEM rack-test (0.8.3) rack (>= 1.0, < 3) rake (12.3.1) - rdf (3.0.2) + rdf (3.0.3) hamster (~> 3.0) link_header (~> 0.0, >= 0.0.8) rdf-aggregate-repo (2.2.1) @@ -148,7 +148,7 @@ GEM rdf-turtle (2.2.2) ebnf (~> 1.1) rdf (>= 2.2, < 4.0) - rdf-xsd (3.0.0) + rdf-xsd (3.0.1) rdf (~> 3.0) rspec (3.8.0) rspec-core (~> 3.8.0) @@ -204,4 +204,4 @@ DEPENDENCIES webmock (~> 3.0, >= 3.0.1) BUNDLED WITH - 1.16.1 + 1.16.4 diff --git a/lib/cirneco/version.rb b/lib/cirneco/version.rb index 27fc8c8..8d58682 100644 --- a/lib/cirneco/version.rb +++ b/lib/cirneco/version.rb @@ -1,3 +1,3 @@ module Cirneco - VERSION = "0.9.25" + VERSION = "0.9.26" end From fee3f7241bd45d8118f1f51691feda1e0c55c50d Mon Sep 17 00:00:00 2001 From: Kristian Garza Date: Mon, 17 Sep 2018 09:17:08 +0200 Subject: [PATCH 3/6] documentation --- README.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/README.md b/README.md index b2509f0..dec349a 100644 --- a/README.md +++ b/README.md @@ -127,6 +127,19 @@ Hide DOIs with metadata for all markdown files in a folder cirneco doi hide /source/posts ``` +## Bulk Operations + +Transfer a list of DOIs. A list of DOIs must be provided in a file + +``` +10.5438/5aep-2n86 +10.5438/cd2b-xj80 +``` + +```shell +cirneco doi transfer --target DATACITE.DATACITE --jwt {YOUR-JSON-WEB-TOKEN} ./doi_transfer.txt +``` + ## Development We use rspec for unit testing: From 60af553e8725b0203da1e24fe2354b7a7b5da9b6 Mon Sep 17 00:00:00 2001 From: Kristian Garza Date: Mon, 17 Sep 2018 09:25:44 +0200 Subject: [PATCH 4/6] remove variable --- lib/cirneco/doi.rb | 1 - 1 file changed, 1 deletion(-) diff --git a/lib/cirneco/doi.rb b/lib/cirneco/doi.rb index 50e6a7e..209d548 100644 --- a/lib/cirneco/doi.rb +++ b/lib/cirneco/doi.rb @@ -10,7 +10,6 @@ module Cirneco class Doi < Thor include Cirneco::Base include Cirneco::Api - include Cirneco::Lupo include Cirneco::Utils include Bolognese::Utils include Bolognese::DoiUtils From 8986883a9d06e1f58f46fb05dbb977d7bce1cc5c Mon Sep 17 00:00:00 2001 From: Kristian Garza Date: Tue, 18 Sep 2018 12:15:33 +0200 Subject: [PATCH 5/6] remove wrong library --- Gemfile.lock | 2 +- lib/cirneco/doi.rb | 1 - 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/Gemfile.lock b/Gemfile.lock index db247ff..67e0d15 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -1,7 +1,7 @@ PATH remote: . specs: - cirneco (0.9.28) + cirneco (0.9.26) activesupport (>= 4.2.5, < 6) base32-url (~> 0.5) bergamasco (~> 0.3) diff --git a/lib/cirneco/doi.rb b/lib/cirneco/doi.rb index 209d548..d665b28 100644 --- a/lib/cirneco/doi.rb +++ b/lib/cirneco/doi.rb @@ -1,6 +1,5 @@ require 'thor' require 'bolognese' -require 'csv' require_relative 'api' require_relative 'utils' From ba5ff0eef2a180e9a23702b07d374a8f79c7b1ed Mon Sep 17 00:00:00 2001 From: Kristian Garza Date: Wed, 19 Sep 2018 23:00:46 +0200 Subject: [PATCH 6/6] added compatibility for usernam password --- lib/cirneco/api.rb | 8 ++++++-- lib/cirneco/doi.rb | 4 +++- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/lib/cirneco/api.rb b/lib/cirneco/api.rb index a9a32b5..6a387d0 100644 --- a/lib/cirneco/api.rb +++ b/lib/cirneco/api.rb @@ -22,12 +22,16 @@ def put_metadata(doi, options={}) end def transfer_doi(doi, options={}) - return OpenStruct.new(body: { "errors" => [{ "title" => "JWT missing" }] }) unless options[:jwt].present? + return OpenStruct.new(body: { "errors" => [{ "title" => "JWT or Username or password missing" }] }) unless options[:jwt].present? || (options[:username].present? && options[:password].present?) api_url = options[:sandbox] ? 'https://api.test.datacite.org' : 'https://api.datacite.org' url = URI.encode("#{api_url}/dois/#{doi}") - Maremma.patch(url, content_type: 'application/vnd.api+json;charset=UTF-8', data: options[:data], bearer: options[:jwt]) + if options[:jwt].present? + Maremma.patch(url, content_type: 'application/vnd.api+json;charset=UTF-8', data: options[:data], bearer: options[:jwt]) + else + Maremma.patch(url, content_type: 'application/vnd.api+json;charset=UTF-8', data: options[:data], username: options[:username], password: options[:password]) + end end def get_metadata(doi, options={}) diff --git a/lib/cirneco/doi.rb b/lib/cirneco/doi.rb index d665b28..6a3e4ab 100644 --- a/lib/cirneco/doi.rb +++ b/lib/cirneco/doi.rb @@ -114,9 +114,11 @@ def check(doi) end desc "transfer DOIs", "transfer list of DOIs" - method_option :jwt, :default => ENV['JWT'] method_option :target, :type => :string + method_option :username, :default => ENV['MDS_USERNAME'] + method_option :password, :default => ENV['MDS_PASSWORD'] method_option :sandbox, :type => :boolean, :force => false + method_option :jwt, :default => ENV['JWT'] def transfer(file) count = 0 File.foreach(file) do |line|