theoj 1.2.0 → 1.3.1

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: e9c9c517ea91deba2fcbca39a4098266b8b2adcf749de0c1803c0c36905d54d9
4
- data.tar.gz: 1a4877b0a9e1bb9d58ceebf7a5bbca8cdaefcc2f35a7cbe2696570c828e6d96c
3
+ metadata.gz: e547b163db1515379b7d14d756ce1a33c87ac3edc664ec1b88d9398886e82ca9
4
+ data.tar.gz: 98454621720c0c22f4d7a37134b344b55a9e0c29168b62ced477ae2eba4ad226
5
5
  SHA512:
6
- metadata.gz: 4f6661c7163fedb8ba1248b2e1861c6a9f2c842ccfa2a4824fa42cd660ce7660c13b7097728c4078881748d3d69898a78f594717dffcfce08e6cb957e2c7a382
7
- data.tar.gz: 2c812174f9bfd07155ada8ee909dca12a10398f05c042092d014b3401efecba59f9d9c3a2213fdd626a40b06d84156eadbe675e9877ce5950ec3c991b902d159
6
+ metadata.gz: 593a9a2099f19f529e3b96693d757dd3c97c61e74cb2a549a90734fd3e02b0f0dd4e24e3df175a9f91fc2ea54503098f08ff708defadd4c8ebd0351387a60cca
7
+ data.tar.gz: 89889649760946e68a6feafa397cead283c29242708c55a91cf07e33f7251e40935abe12125d6a6f8a1e354be4c63265136d41817123059dc5d376d280d709d3
data/CHANGELOG.md CHANGED
@@ -1,5 +1,19 @@
1
1
  # Changelog
2
2
 
3
+ ## 1.3.1 (2022-03-09)
4
+
5
+ - Fix error when loading metadata for papers with wrong path
6
+
7
+ ## 1.3.0 (2022-03-02)
8
+
9
+ - Change branches using git-switch instead of git-checkout to remove ambiguaties. Requires Git >= 2.23
10
+
11
+ ## 1.2.1 (2021-11-30)
12
+
13
+ - Changed metadata dates format to ISO
14
+ - Changed editor and reviewers metadata values to github login
15
+ - Removed languages from article metadata
16
+
3
17
  ## 1.2.0 (2021-11-23)
4
18
 
5
19
  - Added reviews_repository_url to Journal
data/lib/theoj/git.rb CHANGED
@@ -14,7 +14,7 @@ module Theoj
14
14
 
15
15
  def change_branch(branch, local_path)
16
16
  return true if (branch.nil? || branch.strip.empty?)
17
- stdout, stderr, status = Open3.capture3 "git -C #{local_path} checkout #{branch}"
17
+ stdout, stderr, status = Open3.capture3 "git -C #{local_path} switch #{branch}"
18
18
  status.success?
19
19
  end
20
20
  end
data/lib/theoj/github.rb CHANGED
@@ -52,7 +52,7 @@ module Theoj
52
52
 
53
53
  # Returns the user login (removes the @ from the username)
54
54
  def user_login(username)
55
- username.strip.sub(/^@/, "").downcase
55
+ username.to_s.strip.sub(/^@/, "").downcase
56
56
  end
57
57
 
58
58
  # Returns true if the string is a valid GitHub isername (starts with @)
data/lib/theoj/paper.rb CHANGED
@@ -105,7 +105,9 @@ module Theoj
105
105
  end
106
106
 
107
107
  def load_metadata
108
- @paper_metadata ||= if paper_path.include?('.tex')
108
+ @paper_metadata ||= if paper_path.nil?
109
+ {}
110
+ elsif paper_path.include?('.tex')
109
111
  YAML.load_file(paper_path.gsub('.tex', '.yml'))
110
112
  else
111
113
  YAML.load_file(paper_path)
@@ -132,14 +134,14 @@ module Theoj
132
134
  parsed_authors
133
135
  end
134
136
 
135
- def parse_affiliations(affliations_yaml)
136
- affliations_metadata = {}
137
+ def parse_affiliations(affiliations_yaml)
138
+ affiliations_metadata = {}
137
139
 
138
- affliations_yaml.each do |affiliation|
139
- affliations_metadata[affiliation['index']] = affiliation['name']
140
+ affiliations_yaml.each do |affiliation|
141
+ affiliations_metadata[affiliation['index']] = affiliation['name']
140
142
  end
141
143
 
142
- affliations_metadata
144
+ affiliations_metadata
143
145
  end
144
146
 
145
147
  def detect_languages
@@ -1,4 +1,5 @@
1
1
  require "json"
2
+ require "date"
2
3
  require "base64"
3
4
  require "faraday"
4
5
 
@@ -56,11 +57,10 @@ module Theoj
56
57
  metadata = {
57
58
  title: paper.title,
58
59
  tags: paper.tags,
59
- languages: paper.languages,
60
60
  authors: paper.authors.collect { |a| a.to_h },
61
61
  doi: paper_doi,
62
62
  software_repository_url: review_issue.target_repository,
63
- reviewers: review_issue.reviewers.collect(&:strip),
63
+ reviewers: review_issue.reviewers.collect{|r| user_login(r)},
64
64
  volume: journal.current_volume,
65
65
  issue: journal.current_issue,
66
66
  year: journal.current_year,
@@ -76,7 +76,7 @@ module Theoj
76
76
 
77
77
  def editor_info
78
78
  editor_info = { editor: {
79
- github_user: review_issue.editor,
79
+ github_user: user_login(review_issue.editor),
80
80
  name: nil,
81
81
  url: nil,
82
82
  orcid: nil
@@ -103,8 +103,8 @@ module Theoj
103
103
  paper_lookup = Faraday.get(journal.url + "/papers/lookup/" + review_issue.issue_id.to_s)
104
104
  if paper_lookup.status == 200
105
105
  info = JSON.parse(paper_lookup.body, symbolize_names: true)
106
- dates_info[:submitted_at] = info[:submitted]
107
- dates_info[:published_at] = info[:accepted]
106
+ dates_info[:submitted_at] = format_date(info[:submitted]) if info[:submitted]
107
+ dates_info[:published_at] = format_date(info[:accepted]) if info[:accepted]
108
108
  end
109
109
  end
110
110
 
@@ -128,5 +128,12 @@ module Theoj
128
128
  def paper_doi
129
129
  journal.paper_doi_for_id(paper_id)
130
130
  end
131
+
132
+ private
133
+ def format_date(date_string)
134
+ Date.parse(date_string.to_s).strftime("%Y-%m-%d")
135
+ rescue Date::Error
136
+ nil
137
+ end
131
138
  end
132
139
  end
data/lib/theoj/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module Theoj
2
- VERSION = "1.2.0"
2
+ VERSION = "1.3.1"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: theoj
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.2.0
4
+ version: 1.3.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Juanjo Bazán
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-11-23 00:00:00.000000000 Z
11
+ date: 2022-03-09 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: octokit
@@ -28,58 +28,58 @@ dependencies:
28
28
  name: faraday
29
29
  requirement: !ruby/object:Gem::Requirement
30
30
  requirements:
31
- - - ">="
31
+ - - "~>"
32
32
  - !ruby/object:Gem::Version
33
- version: '0'
33
+ version: '1.10'
34
34
  type: :runtime
35
35
  prerelease: false
36
36
  version_requirements: !ruby/object:Gem::Requirement
37
37
  requirements:
38
- - - ">="
38
+ - - "~>"
39
39
  - !ruby/object:Gem::Version
40
- version: '0'
40
+ version: '1.10'
41
41
  - !ruby/object:Gem::Dependency
42
42
  name: openjournals-nameable
43
43
  requirement: !ruby/object:Gem::Requirement
44
44
  requirements:
45
- - - ">="
45
+ - - "~>"
46
46
  - !ruby/object:Gem::Version
47
- version: '0'
47
+ version: '1.1'
48
48
  type: :runtime
49
49
  prerelease: false
50
50
  version_requirements: !ruby/object:Gem::Requirement
51
51
  requirements:
52
- - - ">="
52
+ - - "~>"
53
53
  - !ruby/object:Gem::Version
54
- version: '0'
54
+ version: '1.1'
55
55
  - !ruby/object:Gem::Dependency
56
56
  name: github-linguist
57
57
  requirement: !ruby/object:Gem::Requirement
58
58
  requirements:
59
- - - ">="
59
+ - - "~>"
60
60
  - !ruby/object:Gem::Version
61
- version: '0'
61
+ version: 7.19.0
62
62
  type: :runtime
63
63
  prerelease: false
64
64
  version_requirements: !ruby/object:Gem::Requirement
65
65
  requirements:
66
- - - ">="
66
+ - - "~>"
67
67
  - !ruby/object:Gem::Version
68
- version: '0'
68
+ version: 7.19.0
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: rugged
71
71
  requirement: !ruby/object:Gem::Requirement
72
72
  requirements:
73
- - - ">="
73
+ - - "~>"
74
74
  - !ruby/object:Gem::Version
75
- version: '0'
75
+ version: 1.4.2
76
76
  type: :runtime
77
77
  prerelease: false
78
78
  version_requirements: !ruby/object:Gem::Requirement
79
79
  requirements:
80
- - - ">="
80
+ - - "~>"
81
81
  - !ruby/object:Gem::Version
82
- version: '0'
82
+ version: 1.4.2
83
83
  - !ruby/object:Gem::Dependency
84
84
  name: rake
85
85
  requirement: !ruby/object:Gem::Requirement
@@ -157,7 +157,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
157
157
  - !ruby/object:Gem::Version
158
158
  version: '0'
159
159
  requirements: []
160
- rubygems_version: 3.2.22
160
+ rubygems_version: 3.3.3
161
161
  signing_key:
162
162
  specification_version: 4
163
163
  summary: Editorial objects used by the Open Journals