bolognese 0.9.71 → 0.9.72

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 27fa08f0cba20d70f70c8709c515c73429e654e312e4ce423b14b0945f99e752
4
- data.tar.gz: 2612b3851f969a1c9601ed0829c9d15ca323936ce1893165428166373f34c9e5
3
+ metadata.gz: 10b7b19b50f11d59d731d5ce52c7ab445ec2a5b3090f3c33bbdc7221438dfcf2
4
+ data.tar.gz: e7470fb34f1f232bd6f6e7f16a7cccfd0081d9d0f289c1f381accc0adcc509ac
5
5
  SHA512:
6
- metadata.gz: 19d1353aa529869aebeb96243334ce073a9a81895aed9a14b5293b12f48f30a5583a9624f9f450c6e59a521430e0ca6e60413f43567a36d2d46f1614395532f3
7
- data.tar.gz: 9388a935ad023229179832f289c2067e975af6b8d653ec5b45c1a5e400c5a11adbae01484bc4d109fc40830542ece84c22268db869f1da24386262f10b2ef590
6
+ metadata.gz: f688d4378c6f8a73c12de3b022bdfd2dbb3cd4ceb13d8d7de6e37c47414235184cceee8b776d106a68a2185bcc7e3fc57853448893f8143d64ce1602035802f0
7
+ data.tar.gz: be780ab41ab782b9bf199c4ca82a626eb5f18659d43cab0a6df6b8ab8cde34e2992679b1499fef797e813863c4e2efc788250699795d91f5c7f5b85b04704ec6
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- bolognese (0.9.71)
4
+ bolognese (0.9.72)
5
5
  activesupport (>= 4.2.5, < 6)
6
6
  benchmark_methods (~> 0.7)
7
7
  bibtex-ruby (~> 4.1)
@@ -61,14 +61,14 @@ module Bolognese
61
61
  include Bolognese::Writers::SchemaOrgWriter
62
62
  include Bolognese::Writers::TurtleWriter
63
63
 
64
- attr_accessor :doi, :author, :title, :publisher, :contributor, :license,
64
+ attr_accessor :id, :doi, :author, :title, :publisher, :contributor, :license,
65
65
  :date_accepted, :date_available, :date_copyrighted, :date_collected,
66
66
  :date_submitted, :date_valid, :date_created, :date_modified,
67
67
  :date_registered, :date_updated, :provider_id, :client_id, :journal,
68
68
  :volume, :issue, :first_page, :last_page, :url, :version, :keywords, :editor,
69
69
  :description, :alternate_name, :language, :content_size, :spatial_coverage,
70
70
  :schema_version, :additional_type, :has_part, :same_as,
71
- :is_previous_version_of, :is_new_version_of, :is_cited_by, :cites,
71
+ :is_previous_version_of, :is_new_version_of, :is_cited_by, :cites,
72
72
  :is_supplement_to, :is_supplemented_by, :is_continued_by, :continues,
73
73
  :has_metadata, :is_metadata_for, :is_referenced_by, :references,
74
74
  :is_documented_by, :documents, :is_compiled_by, :compiles,
@@ -87,8 +87,8 @@ module Bolognese
87
87
  @from = from || find_from_format(id: id)
88
88
 
89
89
  # generate name for method to call dynamically
90
- hsh = @from.present? ? send("get_" + @from, id: id, sandbox: options[:sandbox]) : nil
91
- string = hsh.to_h.fetch("string", nil)
90
+ hsh = @from.present? ? send("get_" + @from, id: id, sandbox: options[:sandbox]) : {}
91
+ string = hsh.fetch("string", nil)
92
92
  elsif File.exist?(input)
93
93
  ext = File.extname(input)
94
94
  if %w(.bib .ris .xml .json).include?(ext)
@@ -110,11 +110,11 @@ module Bolognese
110
110
  end
111
111
 
112
112
  # generate name for method to call dynamically
113
- @metadata = @from.present? ? send("read_" + @from, string: string, sandbox: options[:sandbox], doi: options[:doi], url: options[:url]) : {}
113
+ @metadata = @from.present? ? send("read_" + @from, string: string, id: id, sandbox: options[:sandbox], doi: options[:doi], url: options[:url]) : {}
114
114
  @raw = string.present? ? string.strip : nil
115
115
 
116
116
  # replace DOI in XML if provided in options
117
- if @from == "datacite" && options[:doi].present?
117
+ if @from == "datacite" && options[:doi].present? && string.present?
118
118
  doc = Nokogiri::XML(string, nil, 'UTF-8', &:noblanks)
119
119
  node = doc.at_css("identifier")
120
120
  node.content = options[:doi].upcase
@@ -135,7 +135,7 @@ module Bolognese
135
135
  end
136
136
 
137
137
  def exists?
138
- metadata.fetch("id", nil).present?
138
+ metadata.fetch("state", "not_found") != "not_found"
139
139
  end
140
140
 
141
141
  def valid?
@@ -150,7 +150,7 @@ module Bolognese
150
150
  end
151
151
 
152
152
  def id
153
- @doi.present? ? doi_as_url(@doi) : metadata.fetch("id", nil)
153
+ @id ||= metadata.fetch("id", nil)
154
154
  end
155
155
 
156
156
  def type
@@ -178,7 +178,7 @@ module Bolognese
178
178
  end
179
179
 
180
180
  def doi
181
- @doi ||= metadata.fetch("doi", nil)
181
+ @doi ||= @id.present? ? doi_from_url(@id) : metadata.fetch("doi", nil)
182
182
  end
183
183
 
184
184
  def url
@@ -44,6 +44,7 @@ module Bolognese
44
44
  end
45
45
 
46
46
  page_first, page_last = meta.pages.to_s.split("-")
47
+ state = doi.present? ? "findable" : "not_found"
47
48
 
48
49
  { "id" => normalize_doi(doi),
49
50
  "type" => type,
@@ -61,7 +62,8 @@ module Bolognese
61
62
  "page_first" => page_first,
62
63
  "page_last" => page_last,
63
64
  "description" => { "text" => meta.field?(:abstract) && sanitize(meta.abstract.to_s).presence },
64
- "license" => { "id" => meta.field?(:copyright) && meta.copyright.to_s.presence }
65
+ "license" => { "id" => meta.field?(:copyright) && meta.copyright.to_s.presence },
66
+ "state" => state
65
67
  }
66
68
  end
67
69
  end
@@ -24,8 +24,10 @@ module Bolognese
24
24
  }
25
25
 
26
26
  def read_citeproc(string: nil, **options)
27
- errors = jsonlint(string)
28
- return { "errors" => errors } if errors.present?
27
+ if string.present?
28
+ errors = jsonlint(string)
29
+ return { "errors" => errors } if errors.present?
30
+ end
29
31
 
30
32
  meta = string.present? ? Maremma.from_json(string) : {}
31
33
 
@@ -43,8 +45,10 @@ module Bolognese
43
45
  else
44
46
  nil
45
47
  end
48
+ id = normalize_id(meta.fetch("id", nil))
49
+ state = id.present? ? "findable" : "not_found"
46
50
 
47
- { "id" => normalize_id(meta.fetch("id", nil)),
51
+ { "id" => id,
48
52
  "type" => type,
49
53
  "additional_type" => meta.fetch("additionalType", nil),
50
54
  "citeproc_type" => citeproc_type,
@@ -64,7 +68,8 @@ module Bolognese
64
68
  "description" => meta.fetch("abstract", nil).present? ? { "text" => sanitize(meta.fetch("abstract")) } : nil,
65
69
  #{ }"license" => { "id" => meta.field?(:copyright) && meta.copyright.to_s.presence },
66
70
  "version" => meta.fetch("version", nil),
67
- "keywords" => meta.fetch("categories", nil)
71
+ "keywords" => meta.fetch("categories", nil),
72
+ "state" => state
68
73
  }
69
74
  end
70
75
  end
@@ -2,7 +2,7 @@ module Bolognese
2
2
  module Readers
3
3
  module CodemetaReader
4
4
  def get_codemeta(id: nil, **options)
5
- return nil unless id.present?
5
+ return { "string" => nil, "state" => "not_found" } unless id.present?
6
6
  id = normalize_id(id)
7
7
  response = Maremma.get(github_as_codemeta_url(id), accept: "json", raw: true)
8
8
  string = response.body.fetch("data", nil)
@@ -11,17 +11,20 @@ module Bolognese
11
11
  end
12
12
 
13
13
  def read_codemeta(string: nil, **options)
14
- errors = jsonlint(string)
15
- return { "errors" => errors } if errors.present?
14
+ if string.present?
15
+ errors = jsonlint(string)
16
+ return { "errors" => errors } if errors.present?
17
+ end
16
18
 
17
19
  meta = string.present? ? Maremma.from_json(string) : {}
18
- identifier = meta.fetch("identifier", nil)
20
+ identifier = meta.fetch("identifier", nil) || options[:id]
19
21
  id = normalize_id(meta.fetch("@id", nil) || identifier)
20
22
  type = meta.fetch("@type", nil)
21
23
  author = get_authors(from_schema_org(Array.wrap(meta.fetch("agents", nil))))
22
24
  editor = get_authors(from_schema_org(Array.wrap(meta.fetch("editor", nil))))
23
25
  date_published = meta.fetch("datePublished", nil)
24
26
  publisher = meta.fetch("publisher", nil)
27
+ state = meta.present? ? "findable" : "not_found"
25
28
 
26
29
  { "id" => id,
27
30
  "type" => type,
@@ -45,7 +48,8 @@ module Bolognese
45
48
  "description" => meta.fetch("description", nil).present? ? { "text" => sanitize(meta.fetch("description")) } : nil,
46
49
  "license" => { "id" => meta.fetch("license", nil) },
47
50
  "version" => meta.fetch("version", nil),
48
- "keywords" => meta.fetch("tags", nil)
51
+ "keywords" => meta.fetch("tags", nil),
52
+ "state" => state
49
53
  }
50
54
  end
51
55
 
@@ -63,7 +63,7 @@ module Bolognese
63
63
  CONTACT_EMAIL = "tech@datacite.org"
64
64
 
65
65
  def get_crossref(id: nil, **options)
66
- return nil unless id.present?
66
+ return { "string" => nil, "state" => "not_found" } unless id.present?
67
67
 
68
68
  doi = doi_from_url(id)
69
69
  url = "http://www.crossref.org/openurl/?id=doi:#{doi}&noredirect=true&pid=#{CONTACT_EMAIL}&format=unixref"
@@ -82,13 +82,12 @@ module Bolognese
82
82
  meta = {}
83
83
  end
84
84
 
85
- return meta unless meta["crossref"].present?
86
-
87
85
  # model should be one of book, conference, database, dissertation, journal, peer_review, posted_content,
88
86
  # report-paper, sa_component, standard
89
- model = meta.dig("crossref").keys.first
87
+ model = meta.dig("crossref").to_h.keys.first
90
88
 
91
89
  additional_type = nil
90
+ bibliographic_metadata = {}
92
91
  program_metadata = {}
93
92
  journal_metadata = nil
94
93
  journal_issue = {}
@@ -99,15 +98,15 @@ module Bolognese
99
98
  book_metadata = meta.dig("crossref", "book", "book_metadata")
100
99
  book_series_metadata = meta.dig("crossref", "book", "book_series_metadata")
101
100
  book_set_metadata = meta.dig("crossref", "book", "book_set_metadata")
102
- bibliographic_metadata = meta.dig("crossref", "book", "content_item") || {}
101
+ bibliographic_metadata = meta.dig("crossref", "book", "content_item").to_h
103
102
  additional_type = bibliographic_metadata.fetch("component_type", nil) ? "book-" + bibliographic_metadata.fetch("component_type") : "book"
104
103
  publisher = book_metadata.dig("publisher", "publisher_name")
105
104
  when "conference"
106
105
  event_metadata = meta.dig("crossref", "conference", "event_metadata") || {}
107
- bibliographic_metadata = meta.dig("crossref", "conference", "conference_paper") || {}
106
+ bibliographic_metadata = meta.dig("crossref", "conference", "conference_paper").to_h
108
107
  when "journal"
109
108
  journal_metadata = meta.dig("crossref", "journal", "journal_metadata") || {}
110
- bibliographic_metadata = meta.dig("crossref", "journal", "journal_article") || {}
109
+ bibliographic_metadata = meta.dig("crossref", "journal", "journal_article").to_h
111
110
  program_metadata = bibliographic_metadata.dig("crossmark", "custom_metadata", "program") || bibliographic_metadata.dig("program")
112
111
  journal_issue = meta.dig("crossref", "journal", "journal_issue") || {}
113
112
  journal_article = meta.dig("crossref", "journal", "journal_article") || {}
@@ -120,18 +119,20 @@ module Bolognese
120
119
  "journal"
121
120
  end
122
121
  when "posted_content"
123
- bibliographic_metadata = meta.dig("crossref", "posted_content") || {}
122
+ bibliographic_metadata = meta.dig("crossref", "posted_content").to_h
124
123
  when "sa_component"
125
- bibliographic_metadata = meta.dig("crossref", "sa_component", "component_list", "component") || {}
124
+ bibliographic_metadata = meta.dig("crossref", "sa_component", "component_list", "component").to_h
126
125
  end
127
126
 
128
- additional_type = (additional_type || model).underscore.camelize
127
+ additional_type = (additional_type || model).to_s.underscore.camelize.presence
129
128
  type = CR_TO_SO_TRANSLATIONS[additional_type] || "ScholarlyArticle"
130
- doi = bibliographic_metadata.dig("doi_data", "doi").to_s.downcase
129
+
130
+ doi = bibliographic_metadata.dig("doi_data", "doi").to_s.downcase.presence || doi_from_url(options[:id])
131
131
 
132
132
  # Crossref servers run on Eastern Time
133
133
  Time.zone = 'Eastern Time (US & Canada)'
134
- date_modified = Time.zone.parse(meta.fetch("timestamp", "")).utc.iso8601
134
+ date_modified = Time.zone.parse(meta.fetch("timestamp", "2018-01-01")).utc.iso8601
135
+ state = meta.present? ? "findable" : "not_found"
135
136
 
136
137
  { "id" => normalize_doi(doi),
137
138
  "type" => type,
@@ -163,7 +164,8 @@ module Bolognese
163
164
  "keywords" => nil,
164
165
  "language" => nil,
165
166
  "content_size" => nil,
166
- "schema_version" => nil
167
+ "schema_version" => nil,
168
+ "state" => state
167
169
  }
168
170
  end
169
171
 
@@ -9,6 +9,7 @@ module Bolognese
9
9
 
10
10
  resource_type_general = meta.fetch("resource-type-general", nil)
11
11
  type = Bolognese::Utils::DC_TO_SO_TRANSLATIONS[resource_type_general.to_s.dasherize] || "CreativeWork"
12
+ state = meta.fetch("doi", nil).present? ? "findable" : "not_found"
12
13
 
13
14
  { "id" => meta.fetch("id", nil),
14
15
  "type" => type,
@@ -44,7 +45,8 @@ module Bolognese
44
45
  "keywords" => meta.fetch("subject", nil),
45
46
  "language" => meta.fetch("language", nil),
46
47
  "content_size" => meta.fetch("size", nil),
47
- "schema_version" => meta.fetch("schema-version", nil)
48
+ "schema_version" => meta.fetch("schema-version", nil),
49
+ "state" => state
48
50
  }
49
51
  end
50
52
 
@@ -2,7 +2,7 @@ module Bolognese
2
2
  module Readers
3
3
  module DataciteReader
4
4
  def get_datacite(id: nil, **options)
5
- return nil unless id.present?
5
+ return { "string" => nil, "state" => "not_found" } unless id.present?
6
6
 
7
7
  doi = doi_from_url(id)
8
8
  search_url = doi_search(id, options)
@@ -10,7 +10,7 @@ module Bolognese
10
10
 
11
11
  response = Maremma.get search_url
12
12
  attributes = response.body.dig("data", "attributes")
13
- return nil unless attributes.present?
13
+ return { "string" => nil, "state" => "not_found" } unless attributes.present?
14
14
 
15
15
  client_id = response.body.dig("data", "relationships", "client", "data", "id").upcase
16
16
  provider_id = response.body.dig("data", "relationships", "provider", "data", "id").upcase
@@ -42,9 +42,7 @@ module Bolognese
42
42
  end
43
43
 
44
44
  def read_datacite(string: nil, **options)
45
- return { "errors" => "no content" } unless string.present?
46
-
47
- meta = Maremma.from_xml(string).fetch("resource", {})
45
+ meta = Maremma.from_xml(string).to_h.fetch("resource", {})
48
46
  schema_version = meta.fetch("xmlns", nil)
49
47
 
50
48
  # validate only when option is set, as this step is expensive and
@@ -57,7 +55,7 @@ module Bolognese
57
55
  if options[:doi]
58
56
  id = normalize_doi(options[:doi], sandbox: options[:sandbox])
59
57
  else
60
- id = normalize_doi(meta.dig("identifier", "__content__"), sandbox: options[:sandbox])
58
+ id = normalize_doi(meta.dig("identifier", "__content__") || options[:id], sandbox: options[:sandbox])
61
59
  end
62
60
 
63
61
  doi = doi_from_url(id)
@@ -93,6 +91,7 @@ module Bolognese
93
91
  f = datacite_funder_contributor(meta) + datacite_funding_reference(meta)
94
92
  f.length > 1 ? f : f.first
95
93
  end
94
+ state = doi.present? ? "findable" : "not_found"
96
95
 
97
96
  { "id" => id,
98
97
  "type" => type,
@@ -133,7 +132,8 @@ module Bolognese
133
132
  "keywords" => keywords,
134
133
  "language" => meta.fetch("language", nil),
135
134
  "content_size" => meta.fetch("size", nil),
136
- "schema_version" => schema_version
135
+ "schema_version" => schema_version,
136
+ "state" => state
137
137
  }
138
138
  end
139
139
 
@@ -46,6 +46,7 @@ module Bolognese
46
46
  else
47
47
  nil
48
48
  end
49
+ state = doi.present? ? "findable" : "not_found"
49
50
 
50
51
  { "id" => normalize_doi(doi),
51
52
  "type" => type,
@@ -68,7 +69,8 @@ module Bolognese
68
69
  "first_page" => meta.fetch("SP", nil),
69
70
  "last_page" => meta.fetch("EP", nil),
70
71
  "keywords" => meta.fetch("KW", nil),
71
- "language" => meta.fetch("LA", nil)
72
+ "language" => meta.fetch("LA", nil),
73
+ "state" => state
72
74
  }
73
75
  end
74
76
 
@@ -10,13 +10,27 @@ module Bolognese
10
10
  "isSuccessor" => "IsNewVersionOf"
11
11
  }
12
12
 
13
+ def get_schema_org(id: nil, **options)
14
+ return { "string" => nil, "state" => "not_found" } unless id.present?
15
+
16
+ id = normalize_id(id)
17
+ response = Maremma.get(id)
18
+ doc = Nokogiri::XML(response.body.fetch("data", nil), nil, 'UTF-8')
19
+ string = doc.at_xpath('//script[@type="application/ld+json"]')
20
+ string = string.text if string.present?
21
+
22
+ { "string" => string }
23
+ end
24
+
13
25
  def read_schema_org(string: nil, **options)
14
- errors = jsonlint(string)
15
- return { "errors" => errors } if errors.present?
26
+ if string.present?
27
+ errors = jsonlint(string)
28
+ return { "errors" => errors } if errors.present?
29
+ end
16
30
 
17
31
  meta = string.present? ? Maremma.from_json(string) : {}
18
32
 
19
- id = normalize_id(meta.fetch("@id", nil))
33
+ id = normalize_id(meta.fetch("@id", nil) || options[:id])
20
34
  type = meta.fetch("@type", nil)
21
35
  resource_type_general = Bolognese::Utils::SO_TO_DC_TRANSLATIONS[type]
22
36
  author = get_authors(from_schema_org(Array.wrap(meta.fetch("author", nil))))
@@ -27,6 +41,7 @@ module Bolognese
27
41
  meta.dig("publisher")
28
42
  end
29
43
  date_published = meta.fetch("datePublished", nil)
44
+ state = meta.present? ? "findable" : "not_found"
30
45
 
31
46
  { "id" => id,
32
47
  "type" => type,
@@ -55,22 +70,11 @@ module Bolognese
55
70
  "description" => meta.fetch("description", nil).present? ? { "text" => sanitize(meta.fetch("description")) } : nil,
56
71
  "license" => { "id" => meta.fetch("license", nil) },
57
72
  "version" => meta.fetch("version", nil),
58
- "keywords" => meta.fetch("keywords", nil).to_s.split(", ")
73
+ "keywords" => meta.fetch("keywords", nil).to_s.split(", "),
74
+ "state" => state
59
75
  }
60
76
  end
61
77
 
62
- def get_schema_org(id: nil, **options)
63
- return nil unless id.present?
64
-
65
- id = normalize_id(id)
66
- response = Maremma.get(id)
67
- doc = Nokogiri::XML(response.body.fetch("data", nil), nil, 'UTF-8')
68
- string = doc.at_xpath('//script[@type="application/ld+json"]')
69
- string = string.text if string.present?
70
-
71
- { "string" => string }
72
- end
73
-
74
78
  def schema_org_related_identifier(meta, relation_type: nil)
75
79
  normalize_ids(ids: meta.fetch(relation_type, nil))
76
80
  end
@@ -1,3 +1,3 @@
1
1
  module Bolognese
2
- VERSION = "0.9.71"
2
+ VERSION = "0.9.72"
3
3
  end
@@ -35,5 +35,6 @@
35
35
  "text": "This tools are used to analyse the data produced by the Crosssover Experiment I designed to test Choice Architecture techniques as UI interventions in a SEEk4Science data catalogue. It contains:\n\n- Data structures for the experimental data.<br>\n- Visualisation functions<br>\n- Analysis functions\n\n## Installation\n\n- R<br>\n- python<br>\n- ipython 4\n\nClone and use.\n\n## Usage\n\n<br>\n```python<br>\nsource('parallel_plot.r')<br>\nwith(z, parallelset(trt,response, freq=count, alpha=0.2))<br>\n```\n\n<br>\n## Contributing\n\n1. Fork it!<br>\n2. Create your feature branch: `git checkout -b my-new-feature`<br>\n3. Commit your changes: `git commit -am 'Add some feature'`<br>\n4. Push to the branch: `git push origin my-new-feature`<br>\n5. Submit a pull request :D\n\n<br>\n## License\n\nThis work supports my PhD Thesis at University of Manchester."
36
36
  },
37
37
  "schema_version": "http://datacite.org/schema/kernel-4",
38
- "provider": "DataCite"
38
+ "provider": "DataCite",
39
+ "state": "findable"
39
40
  }
@@ -0,0 +1,112 @@
1
+ ---
2
+ http_interactions:
3
+ - request:
4
+ method: get
5
+ uri: https://api.datacite.org/prefixes/10.5061
6
+ body:
7
+ encoding: US-ASCII
8
+ string: ''
9
+ headers:
10
+ User-Agent:
11
+ - Maremma - https://github.com/datacite/maremma
12
+ Accept:
13
+ - text/html,application/json,application/xml;q=0.9, text/plain;q=0.8,image/png,*/*;q=0.5
14
+ response:
15
+ status:
16
+ code: 200
17
+ message: OK
18
+ headers:
19
+ Date:
20
+ - Sun, 14 Jan 2018 11:23:03 GMT
21
+ Content-Type:
22
+ - application/vnd.api+json; charset=utf-8
23
+ Connection:
24
+ - keep-alive
25
+ Status:
26
+ - 200 OK
27
+ X-Anonymous-Consumer:
28
+ - 'true'
29
+ Cache-Control:
30
+ - max-age=0, private, must-revalidate
31
+ Vary:
32
+ - Accept-Encoding
33
+ Etag:
34
+ - W/"675f0459ac44bbdfed07edbab66f777b"
35
+ X-Runtime:
36
+ - '0.019398'
37
+ X-Request-Id:
38
+ - 872af865-7150-4f9e-b467-7c44762acadf
39
+ X-Powered-By:
40
+ - Phusion Passenger 5.1.12
41
+ Server:
42
+ - nginx/1.12.2 + Phusion Passenger 5.1.12
43
+ Access-Control-Allow-Origin:
44
+ - "*"
45
+ Access-Control-Allow-Methods:
46
+ - GET, POST, PATCH, PUT, DELETE, OPTIONS
47
+ Access-Control-Allow-Headers:
48
+ - DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Content-Range,Range,Authorization
49
+ Access-Control-Expose-Headers:
50
+ - DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Content-Range,Range,Authorization
51
+ body:
52
+ encoding: UTF-8
53
+ string: '{"data":{"id":"10.5061","type":"prefixes","attributes":{"registration-agency":"DataCite","created":"2010-01-01T00:00:00.000Z","updated":null},"relationships":{"clients":{"data":[{"id":"cdl.dryad","type":"clients"}]},"providers":{"data":[{"id":"cdl","type":"providers"}]}}},"included":[{"id":"cdl.dryad","type":"clients","attributes":{"name":"Dryad","symbol":"CDL.DRYAD","year":2013,"contact-name":"Greg
54
+ Janee","contact-email":"gjanee@ucop.edu","domains":"*","is-active":true,"password":null,"created":"2013-02-19T17:42:03Z","updated":"2017-11-09T00:11:37Z"},"relationships":{"prefixes":{"meta":{}},"provider":{"meta":{}},"repository":{"meta":{}}}},{"id":"cdl","type":"providers","attributes":{"name":"California
55
+ Digital Library","symbol":"CDL","year":2010,"contact-name":"Greg Janee","contact-email":"gjanee@ucop.edu","logo-url":"https://assets.datacite.org/images/members/cdl.png","is-active":true,"password":"yes","created":"2010-01-01T00:00:00.000Z","updated":"2017-11-09T00:06:44.000Z"},"relationships":{"clients":{"meta":{}},"prefixes":{"meta":{}}}}]}'
56
+ http_version:
57
+ recorded_at: Sun, 14 Jan 2018 11:23:03 GMT
58
+ - request:
59
+ method: get
60
+ uri: https://api.datacite.org/dois/10.5061/dryad.8515?include=client,provider
61
+ body:
62
+ encoding: US-ASCII
63
+ string: ''
64
+ headers:
65
+ User-Agent:
66
+ - Maremma - https://github.com/datacite/maremma
67
+ Accept:
68
+ - text/html,application/json,application/xml;q=0.9, text/plain;q=0.8,image/png,*/*;q=0.5
69
+ response:
70
+ status:
71
+ code: 200
72
+ message: OK
73
+ headers:
74
+ Date:
75
+ - Sun, 14 Jan 2018 11:23:03 GMT
76
+ Content-Type:
77
+ - application/vnd.api+json; charset=utf-8
78
+ Connection:
79
+ - keep-alive
80
+ Status:
81
+ - 200 OK
82
+ X-Anonymous-Consumer:
83
+ - 'true'
84
+ Cache-Control:
85
+ - max-age=0, private, must-revalidate
86
+ Vary:
87
+ - Accept-Encoding
88
+ Etag:
89
+ - W/"94247e0a1f8d60cd1f284a23b3041e51"
90
+ X-Runtime:
91
+ - '0.143771'
92
+ X-Request-Id:
93
+ - ea9d617f-832e-4750-9101-41eed0b38227
94
+ X-Powered-By:
95
+ - Phusion Passenger 5.1.12
96
+ Server:
97
+ - nginx/1.12.2 + Phusion Passenger 5.1.12
98
+ Access-Control-Allow-Origin:
99
+ - "*"
100
+ Access-Control-Allow-Methods:
101
+ - GET, POST, PATCH, PUT, DELETE, OPTIONS
102
+ Access-Control-Allow-Headers:
103
+ - DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Content-Range,Range,Authorization
104
+ Access-Control-Expose-Headers:
105
+ - DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Content-Range,Range,Authorization
106
+ body:
107
+ encoding: ASCII-8BIT
108
+ string: !binary |-
109
+ {"data":{"id":"10.5061/dryad.8515","type":"dois","attributes":{"doi":"10.5061/dryad.8515","identifier":"https://doi.org/10.5061/dryad.8515","url":"http://datadryad.org/resource/doi:10.5061/dryad.8515","author":[{"type":"Person","name":"Benjamin Ollomo","given-name":"Benjamin","family-name":"Ollomo"},{"type":"Person","name":"Patrick Durand","given-name":"Patrick","family-name":"Durand"},{"type":"Person","name":"Franck Prugnolle","given-name":"Franck","family-name":"Prugnolle"},{"type":"Person","name":"Emmanuel J. P. Douzery","given-name":"Emmanuel J. P.","family-name":"Douzery"},{"type":"Person","name":"Céline Arnathau","given-name":"Céline","family-name":"Arnathau"},{"type":"Person","name":"Dieudonné Nkoghe","given-name":"Dieudonné","family-name":"Nkoghe"},{"type":"Person","name":"Eric Leroy","given-name":"Eric","family-name":"Leroy"},{"type":"Person","name":"François Renaud","given-name":"François","family-name":"Renaud"}],"title":"Data from: A new malaria agent in African hominids.","container-title":"Dryad Digital Repository","description":null,"resource-type-subtype":"DataPackage","license":"http://creativecommons.org/publicdomain/zero/1.0","version":20,"related-identifier":[{"type":"CreativeWork","id":"https://doi.org/10.5061/dryad.8515/1","relation-type":"HasPart"},{"type":"CreativeWork","id":"https://doi.org/10.5061/dryad.8515/2","relation-type":"HasPart"},{"type":"CreativeWork","id":"https://doi.org/10.1371/journal.ppat.1000446","relation-type":"IsReferencedBy"},{"type":"CreativeWork","id":"https://doi.org/10.1371/journal.ppat.1000446","relation-type":"IsSupplementTo"}],"schema-version":"http://datacite.org/schema/kernel-4","state":"findable","xml":"PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHJlc291\ncmNlIHhtbG5zPSJodHRwOi8vZGF0YWNpdGUub3JnL3NjaGVtYS9rZXJuZWwt\nNCIgeG1sbnM6eHNpPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxL1hNTFNjaGVt\nYS1pbnN0YW5jZSIgeG1sbnM6bWV0cz0iaHR0cDovL3d3dy5sb2MuZ292L01F\nVFMvIiB4bWxuczpkc3BhY2U9Imh0dHA6Ly93d3cuZHNwYWNlLm9yZy94bWxu\ncy9kc3BhY2UvZGltIiB4bWxuczpkaW09Imh0dHA6Ly93d3cuZHNwYWNlLm9y\nZy94bWxucy9kc3BhY2UvZGltIiB4bWxuczpkcnlhZD0iaHR0cDovL3B1cmwu\nb3JnL2RyeWFkL3Rlcm1zLyIgeHNpOnNjaGVtYUxvY2F0aW9uPSJodHRwOi8v\nZGF0YWNpdGUub3JnL3NjaGVtYS9rZXJuZWwtNCBodHRwOi8vc2NoZW1hLmRh\ndGFjaXRlLm9yZy9tZXRhL2tlcm5lbC00L21ldGFkYXRhLnhzZCI+CiAgPGlk\nZW50aWZpZXIgaWRlbnRpZmllclR5cGU9IkRPSSI+MTAuNTA2MS9EUllBRC44\nNTE1PC9pZGVudGlmaWVyPgogIDx2ZXJzaW9uPjE8L3ZlcnNpb24+CiAgPGNy\nZWF0b3JzPgogICAgPGNyZWF0b3I+CiAgICAgIDxjcmVhdG9yTmFtZT5PbGxv\nbW8sIEJlbmphbWluPC9jcmVhdG9yTmFtZT4KICAgIDwvY3JlYXRvcj4KICAg\nIDxjcmVhdG9yPgogICAgICA8Y3JlYXRvck5hbWU+RHVyYW5kLCBQYXRyaWNr\nPC9jcmVhdG9yTmFtZT4KICAgIDwvY3JlYXRvcj4KICAgIDxjcmVhdG9yPgog\nICAgICA8Y3JlYXRvck5hbWU+UHJ1Z25vbGxlLCBGcmFuY2s8L2NyZWF0b3JO\nYW1lPgogICAgPC9jcmVhdG9yPgogICAgPGNyZWF0b3I+CiAgICAgIDxjcmVh\ndG9yTmFtZT5Eb3V6ZXJ5LCBFbW1hbnVlbCBKLiBQLjwvY3JlYXRvck5hbWU+\nCiAgICA8L2NyZWF0b3I+CiAgICA8Y3JlYXRvcj4KICAgICAgPGNyZWF0b3JO\nYW1lPkFybmF0aGF1LCBDw6lsaW5lPC9jcmVhdG9yTmFtZT4KICAgIDwvY3Jl\nYXRvcj4KICAgIDxjcmVhdG9yPgogICAgICA8Y3JlYXRvck5hbWU+TmtvZ2hl\nLCBEaWV1ZG9ubsOpPC9jcmVhdG9yTmFtZT4KICAgIDwvY3JlYXRvcj4KICAg\nIDxjcmVhdG9yPgogICAgICA8Y3JlYXRvck5hbWU+TGVyb3ksIEVyaWM8L2Ny\nZWF0b3JOYW1lPgogICAgPC9jcmVhdG9yPgogICAgPGNyZWF0b3I+CiAgICAg\nIDxjcmVhdG9yTmFtZT5SZW5hdWQsIEZyYW7Dp29pczwvY3JlYXRvck5hbWU+\nCiAgICA8L2NyZWF0b3I+CiAgPC9jcmVhdG9ycz4KICA8dGl0bGVzPgogICAg\nPHRpdGxlPkRhdGEgZnJvbTogQSBuZXcgbWFsYXJpYSBhZ2VudCBpbiBBZnJp\nY2FuIGhvbWluaWRzLjwvdGl0bGU+CiAgPC90aXRsZXM+CiAgPHB1Ymxpc2hl\ncj5EcnlhZCBEaWdpdGFsIFJlcG9zaXRvcnk8L3B1Ymxpc2hlcj4KICA8cHVi\nbGljYXRpb25ZZWFyPjIwMTE8L3B1YmxpY2F0aW9uWWVhcj4KICA8c3ViamVj\ndHM+CiAgICA8c3ViamVjdD5QaHlsb2dlbnk8L3N1YmplY3Q+CiAgICA8c3Vi\namVjdD5NYWxhcmlhPC9zdWJqZWN0PgogICAgPHN1YmplY3Q+UGFyYXNpdGVz\nPC9zdWJqZWN0PgogICAgPHN1YmplY3Q+VGF4b25vbXk8L3N1YmplY3Q+CiAg\nICA8c3ViamVjdD5NaXRvY2hvbmRyaWFsIGdlbm9tZTwvc3ViamVjdD4KICAg\nIDxzdWJqZWN0PkFmcmljYTwvc3ViamVjdD4KICAgIDxzdWJqZWN0PlBsYXNt\nb2RpdW08L3N1YmplY3Q+CiAgPC9zdWJqZWN0cz4KICA8cmVzb3VyY2VUeXBl\nIHJlc291cmNlVHlwZUdlbmVyYWw9IkRhdGFzZXQiPkRhdGFQYWNrYWdlPC9y\nZXNvdXJjZVR5cGU+CiAgPGFsdGVybmF0ZUlkZW50aWZpZXJzPgogICAgPGFs\ndGVybmF0ZUlkZW50aWZpZXIgYWx0ZXJuYXRlSWRlbnRpZmllclR5cGU9ImNp\ndGF0aW9uIj5PbGxvbW8gQiwgRHVyYW5kIFAsIFBydWdub2xsZSBGLCBEb3V6\nZXJ5IEVKUCwgQXJuYXRoYXUgQywgTmtvZ2hlIEQsIExlcm95IEUsIFJlbmF1\nZCBGICgyMDA5KSBBIG5ldyBtYWxhcmlhIGFnZW50IGluIEFmcmljYW4gaG9t\naW5pZHMuIFBMb1MgUGF0aG9nZW5zIDUoNSk6IGUxMDAwNDQ2LjwvYWx0ZXJu\nYXRlSWRlbnRpZmllcj4KICA8L2FsdGVybmF0ZUlkZW50aWZpZXJzPgogIDxy\nZWxhdGVkSWRlbnRpZmllcnM+CiAgICA8cmVsYXRlZElkZW50aWZpZXIgcmVs\nYXRlZElkZW50aWZpZXJUeXBlPSJET0kiIHJlbGF0aW9uVHlwZT0iSGFzUGFy\ndCI+MTAuNTA2MS9EUllBRC44NTE1LzE8L3JlbGF0ZWRJZGVudGlmaWVyPgog\nICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0i\nRE9JIiByZWxhdGlvblR5cGU9Ikhhc1BhcnQiPjEwLjUwNjEvRFJZQUQuODUx\nNS8yPC9yZWxhdGVkSWRlbnRpZmllcj4KICAgIDxyZWxhdGVkSWRlbnRpZmll\nciByZWxhdGVkSWRlbnRpZmllclR5cGU9IkRPSSIgcmVsYXRpb25UeXBlPSJJ\nc1JlZmVyZW5jZWRCeSI+MTAuMTM3MS9KT1VSTkFMLlBQQVQuMTAwMDQ0Njwv\ncmVsYXRlZElkZW50aWZpZXI+CiAgICA8cmVsYXRlZElkZW50aWZpZXIgcmVs\nYXRlZElkZW50aWZpZXJUeXBlPSJET0kiIHJlbGF0aW9uVHlwZT0iSXNTdXBw\nbGVtZW50VG8iPjEwLjEzNzEvSk9VUk5BTC5QUEFULjEwMDA0NDY8L3JlbGF0\nZWRJZGVudGlmaWVyPgogICAgPHJlbGF0ZWRJZGVudGlmaWVyIHJlbGF0ZWRJ\nZGVudGlmaWVyVHlwZT0iUE1JRCIgcmVsYXRpb25UeXBlPSJJc1JlZmVyZW5j\nZWRCeSI+MTk0Nzg4Nzc8L3JlbGF0ZWRJZGVudGlmaWVyPgogICAgPHJlbGF0\nZWRJZGVudGlmaWVyIHJlbGF0ZWRJZGVudGlmaWVyVHlwZT0iUE1JRCIgcmVs\nYXRpb25UeXBlPSJJc1N1cHBsZW1lbnRUbyI+MTk0Nzg4Nzc8L3JlbGF0ZWRJ\nZGVudGlmaWVyPgogIDwvcmVsYXRlZElkZW50aWZpZXJzPgogIDxyaWdodHNM\naXN0PgogICAgPHJpZ2h0cyByaWdodHNVUkk9Imh0dHA6Ly9jcmVhdGl2ZWNv\nbW1vbnMub3JnL3B1YmxpY2RvbWFpbi96ZXJvLzEuMC8iLz4KICA8L3JpZ2h0\nc0xpc3Q+CjwvcmVzb3VyY2U+\n","published":"2011","registered":"2011-02-01T17:32:02.000Z","updated":"2017-09-02T07:32:23.000Z"},"relationships":{"client":{"data":{"id":"cdl.dryad","type":"clients"}},"provider":{"data":{"id":"cdl","type":"providers"}},"resource-type":{"meta":{}},"media":{"meta":{}}}},"included":[{"id":"cdl.dryad","type":"clients","attributes":{"name":"Dryad","symbol":"CDL.DRYAD","year":2013,"contact-name":"Greg Janee","contact-email":"gjanee@ucop.edu","domains":"*","is-active":true,"password":null,"created":"2013-02-19T17:42:03Z","updated":"2017-11-09T00:11:37Z"},"relationships":{"prefixes":{"meta":{}},"provider":{"meta":{}},"repository":{"meta":{}}}},{"id":"cdl","type":"providers","attributes":{"name":"California Digital Library","symbol":"CDL","year":2010,"contact-name":"Greg Janee","contact-email":"gjanee@ucop.edu","logo-url":"https://assets.datacite.org/images/members/cdl.png","is-active":true,"password":"yes","created":"2010-01-01T00:00:00.000Z","updated":"2017-11-09T00:06:44.000Z"},"relationships":{"clients":{"meta":{}},"prefixes":{"meta":{}}}}]}
110
+ http_version:
111
+ recorded_at: Sun, 14 Jan 2018 11:23:03 GMT
112
+ recorded_with: VCR 3.0.3
@@ -32,15 +32,17 @@ describe Bolognese::Metadata, vcr: true do
32
32
  it "no codemeta.json" do
33
33
  input = "https://github.com/datacite/homepage"
34
34
  subject = Bolognese::Metadata.new(input: input)
35
- expect(subject.id).to be_nil
35
+ expect(subject.id).to eq("https://github.com/datacite/homepage")
36
36
  expect(subject.exists?).to be false
37
+ expect(subject.state).to eq("not_found")
37
38
  end
38
39
 
39
40
  it "not found error" do
40
41
  input = "https://github.com/datacite/x"
41
42
  subject = Bolognese::Metadata.new(input: input)
42
- expect(subject.id).to be_nil
43
+ expect(subject.id).to eq("https://github.com/datacite/x")
43
44
  expect(subject.exists?).to be false
45
+ expect(subject.state).to eq("not_found")
44
46
  end
45
47
 
46
48
  it "rdataone" do
@@ -193,6 +193,10 @@ describe Bolognese::Metadata, vcr: true do
193
193
  input = "https://doi.org/10.7554/elife.01567x"
194
194
  subject = Bolognese::Metadata.new(input: input)
195
195
  expect(subject.valid?).to be false
196
+ expect(subject.id).to eq("https://doi.org/10.7554/elife.01567x")
197
+ expect(subject.doi).to eq("10.7554/elife.01567x")
198
+ expect(subject.provider).to eq("Crossref")
199
+ expect(subject.state).to eq("not_found")
196
200
  end
197
201
  end
198
202
  end
@@ -323,6 +323,10 @@ describe Bolognese::Metadata, vcr: true do
323
323
  input = "https://doi.org/10.4124/05F6C379-DD68-4CDB-880D-33D3E9576D52/1"
324
324
  subject = Bolognese::Metadata.new(input: input)
325
325
  expect(subject.valid?).to be false
326
+ expect(subject.id).to eq("https://doi.org/10.4124/05f6c379-dd68-4cdb-880d-33d3e9576d52/1")
327
+ expect(subject.doi).to eq("10.4124/05f6c379-dd68-4cdb-880d-33d3e9576d52/1")
328
+ expect(subject.provider).to eq("DataCite")
329
+ expect(subject.state).to eq("not_found")
326
330
  end
327
331
 
328
332
  it "DOI in test system" do
@@ -368,8 +372,8 @@ describe Bolognese::Metadata, vcr: true do
368
372
  end
369
373
 
370
374
  context "change datacite metadata" do
371
- it "change doi" do
372
- subject.doi = "10.5061/8515"
375
+ it "change id" do
376
+ subject.id = "https://doi.org/10.5061/8515"
373
377
  expect(subject.valid?).to be true
374
378
  expect(subject.id).to eq("https://doi.org/10.5061/8515")
375
379
  expect(subject.doi).to eq("10.5061/8515")
@@ -34,7 +34,7 @@ describe Bolognese::Metadata, vcr: true do
34
34
 
35
35
  it "BlogPosting with new DOI" do
36
36
  subject = Bolognese::Metadata.new(input: input)
37
- subject.doi = "10.5438/0000-00ss"
37
+ subject.id = "https://doi.org/10.5438/0000-00ss"
38
38
  expect(subject.valid?).to be true
39
39
  expect(subject.id).to eq("https://doi.org/10.5438/0000-00ss")
40
40
  expect(subject.doi).to eq("10.5438/0000-00ss")
@@ -45,8 +45,9 @@ describe Bolognese::Metadata, vcr: true do
45
45
  it "not found error" do
46
46
  input = "https://doi.org/10.5438/4K3M-NYVGx"
47
47
  subject = Bolognese::Metadata.new(input: input, from: "schema_org")
48
- expect(subject.id).to be_nil
48
+ expect(subject.id).to eq("https://doi.org/10.5438/4k3m-nyvgx")
49
49
  expect(subject.exists?).to be false
50
+ expect(subject.state).to eq("not_found")
50
51
  end
51
52
  end
52
53
 
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: bolognese
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.9.71
4
+ version: 0.9.72
5
5
  platform: ruby
6
6
  authors:
7
7
  - Martin Fenner
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2018-01-13 00:00:00.000000000 Z
11
+ date: 2018-01-14 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: maremma
@@ -584,6 +584,7 @@ files:
584
584
  - spec/fixtures/vcr_cassettes/Bolognese_Metadata/authors_as_string/single_author.yml
585
585
  - spec/fixtures/vcr_cassettes/Bolognese_Metadata/authors_as_string/with_organization.yml
586
586
  - spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_datacite_metadata/change_doi.yml
587
+ - spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_datacite_metadata/change_id.yml
587
588
  - spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_datacite_metadata/change_title.yml
588
589
  - spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_metadata_as_datacite_xml/validates_against_schema.yml
589
590
  - spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_metadata_as_datacite_xml/with_data_citation.yml