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 +4 -4
- data/CHANGELOG.md +14 -0
- data/lib/theoj/git.rb +1 -1
- data/lib/theoj/github.rb +1 -1
- data/lib/theoj/paper.rb +8 -6
- data/lib/theoj/submission.rb +12 -5
- data/lib/theoj/version.rb +1 -1
- metadata +19 -19
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e547b163db1515379b7d14d756ce1a33c87ac3edc664ec1b88d9398886e82ca9
|
4
|
+
data.tar.gz: 98454621720c0c22f4d7a37134b344b55a9e0c29168b62ced477ae2eba4ad226
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
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}
|
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.
|
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(
|
136
|
-
|
137
|
+
def parse_affiliations(affiliations_yaml)
|
138
|
+
affiliations_metadata = {}
|
137
139
|
|
138
|
-
|
139
|
-
|
140
|
+
affiliations_yaml.each do |affiliation|
|
141
|
+
affiliations_metadata[affiliation['index']] = affiliation['name']
|
140
142
|
end
|
141
143
|
|
142
|
-
|
144
|
+
affiliations_metadata
|
143
145
|
end
|
144
146
|
|
145
147
|
def detect_languages
|
data/lib/theoj/submission.rb
CHANGED
@@ -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(
|
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
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.
|
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:
|
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: '
|
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: '
|
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: '
|
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: '
|
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:
|
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:
|
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:
|
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:
|
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.
|
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
|