workflow-archiver 2.0.1 → 2.0.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/VERSION +1 -1
- data/lib/dor/workflow_archiver.rb +13 -5
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: bfb0bdfe2166b60e965269c08e3e3974acc57fcc
|
4
|
+
data.tar.gz: 48643eb6e09e11edc36562a76a7a58dbd3058db0
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 56a8bcad387c55e927386038257654188640136e0093081a1d697401641a8a3dede603c8af0f53ce9d0d97afc7a5198d0bbf362d4c580adef02bd2cdddd21989
|
7
|
+
data.tar.gz: f12a9553415f97617aa6d7c2e5a0ae5994a55c7483c5dbcb8a77ee3c3ff6bfd40b141948ffd8509d7390a031fdeeabc0fb6cb424ccc1ffb18352d26e68625682
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
2.0.
|
1
|
+
2.0.2
|
@@ -7,11 +7,11 @@ module Dor
|
|
7
7
|
# Holds the paramaters about the workflow rows that need to be deleted
|
8
8
|
ArchiveCriteria = Struct.new(:repository, :druid, :datastream, :version) do
|
9
9
|
# @param [Array<Hash>] List of objects returned from {WorkflowArchiver#find_completed_objects}. It expects the following keys in the hash
|
10
|
-
def setup_from_query(row_hash)
|
10
|
+
def setup_from_query(row_hash, dor_conn)
|
11
11
|
self.repository = row_hash[:repository]
|
12
12
|
self.druid = row_hash[:druid]
|
13
13
|
self.datastream = row_hash[:datastream]
|
14
|
-
set_current_version
|
14
|
+
set_current_version(dor_conn)
|
15
15
|
self
|
16
16
|
end
|
17
17
|
|
@@ -25,8 +25,9 @@ module Dor
|
|
25
25
|
h
|
26
26
|
end
|
27
27
|
|
28
|
-
def set_current_version
|
29
|
-
|
28
|
+
def set_current_version(dor_conn)
|
29
|
+
response = dor_conn.get "/dor/v1/objects/#{druid}/versions/current"
|
30
|
+
self.version = response.body
|
30
31
|
rescue Faraday::Error::ClientError => ise
|
31
32
|
raise unless ise.inspect =~ /Unable to find.*in fedora/
|
32
33
|
LyberCore::Log.warn ise.inspect.to_s
|
@@ -67,6 +68,10 @@ module Dor
|
|
67
68
|
@conn ||= Sequel.connect(@db_uri)
|
68
69
|
end
|
69
70
|
|
71
|
+
def dor_conn
|
72
|
+
@dor_conn ||= Faraday.new(:url => WorkflowArchiver.config.dor_service_uri)
|
73
|
+
end
|
74
|
+
|
70
75
|
# @return [String] The columns appended with comma and newline
|
71
76
|
def wf_column_string
|
72
77
|
WF_COLUMNS.join(",\n")
|
@@ -135,6 +140,9 @@ module Dor
|
|
135
140
|
|
136
141
|
delete_sql = "delete from #{@workflow_table} where druid = :druid and datastream = :datastream "
|
137
142
|
|
143
|
+
LyberCore::Log.debug "copy_sql is #{copy_sql}"
|
144
|
+
LyberCore::Log.debug "delete_sql is #{delete_sql}"
|
145
|
+
|
138
146
|
if(workflow_info.repository)
|
139
147
|
copy_sql += "and #{@workflow_table}.repository = :repository"
|
140
148
|
delete_sql += 'and repository = :repository'
|
@@ -183,7 +191,7 @@ module Dor
|
|
183
191
|
def map_result_to_criteria(rows)
|
184
192
|
rows.lazy.map do |r|
|
185
193
|
begin
|
186
|
-
ArchiveCriteria.new.setup_from_query(r)
|
194
|
+
ArchiveCriteria.new.setup_from_query(r, dor_conn)
|
187
195
|
rescue => e
|
188
196
|
LyberCore::Log.error("Skipping archiving of #{r['DRUID']}")
|
189
197
|
LyberCore::Log.error("#{e.inspect}\n" + e.backtrace.join("\n"))
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: workflow-archiver
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.0.
|
4
|
+
version: 2.0.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Willy Mene
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2017-11-29 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: lyber-core
|
@@ -138,7 +138,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
138
138
|
version: 1.3.6
|
139
139
|
requirements: []
|
140
140
|
rubyforge_project:
|
141
|
-
rubygems_version: 2.
|
141
|
+
rubygems_version: 2.6.13
|
142
142
|
signing_key:
|
143
143
|
specification_version: 4
|
144
144
|
summary: Enables archiving of DOR workflows
|