daengine 0.1.8 → 0.1.9
Sign up to get free protection for your applications and to get access to all the features.
- data/README.md +28 -0
- data/bin/process_assets +1 -3
- data/lib/daengine/teamsite_metadata_parser.rb +28 -28
- data/lib/daengine/version.rb +1 -1
- metadata +1 -1
data/README.md
CHANGED
@@ -62,3 +62,31 @@ Query via the REST API...
|
|
62
62
|
get 'http://localhost:3000/digital_assets/search?sami=FOOBAR.001'
|
63
63
|
get 'http://localhost:3000/digital_assets/search?funds=12345'
|
64
64
|
|
65
|
+
|
66
|
+
To test the app locally as a project from irb console
|
67
|
+
------------------------------------------------------
|
68
|
+
Update your #{RAILS_ROOT}/client/config.yml
|
69
|
+
|
70
|
+
1. Ensure mongo is running locally
|
71
|
+
2. Provide a database name. Asset metadata records will be stored in edist database in mongo.
|
72
|
+
3. Ensure mongo port is correct in config.yml
|
73
|
+
4. Ensure assets_path info is correct. [Sample deploy files provided under #{RAILS_ROOT}/client/digital-assets/*.xml]
|
74
|
+
5. Set paths for daengine.yml, daengine.log in config.yml
|
75
|
+
|
76
|
+
%%% Sample config.yml %%%
|
77
|
+
host: localhost
|
78
|
+
database: edist
|
79
|
+
port: 27017
|
80
|
+
assets_path: c:/tmp/daengine/digital_assets
|
81
|
+
daengine_yml_file: c:/tmp/daengine/daengine.yml
|
82
|
+
logfile_location: c:/tmp/daengine.log
|
83
|
+
|
84
|
+
Start the irb using the command from your project root directory:
|
85
|
+
C:\dev\daengine> irb -Ilib -rdaengine
|
86
|
+
irb(main): config = YAML.load_file('#{RAILS_ROOT}\client\config.yml')
|
87
|
+
irb(main): Daengine.execute(config)
|
88
|
+
|
89
|
+
At the end of this, "digital_assets" collection will be created with all asset metadata records in "edist" database.
|
90
|
+
|
91
|
+
|
92
|
+
|
data/bin/process_assets
CHANGED
@@ -22,7 +22,7 @@ module Daengine::TeamsiteMetadataParser
|
|
22
22
|
"TeamSite/Metadata/enterprise_content_type_id" => 'content_type'
|
23
23
|
}
|
24
24
|
@@validations = {
|
25
|
-
"TeamSite/Metadata/display_on_website" => lambda { |val| /Y|1/ =~ val },
|
25
|
+
"TeamSite/Metadata/display_on_website" => lambda { |val| /Y|1|true/ =~ val },
|
26
26
|
"TeamSite/Metadata/enterprise_expiration_date" => lambda {|val| !val.blank? },
|
27
27
|
# "TeamSite/Metadata/enterprise_unpublish_date" => lambda {|val| val.blank? },
|
28
28
|
"path" => lambda {|val| !(/\/manifest\// =~ val) }
|
@@ -40,43 +40,43 @@ module Daengine::TeamsiteMetadataParser
|
|
40
40
|
end
|
41
41
|
|
42
42
|
def self.parse_tuple_file(file)
|
43
|
-
|
43
|
+
time do
|
44
44
|
asset = nil
|
45
45
|
assets = {}
|
46
46
|
docpath = {}
|
47
47
|
valid = true
|
48
48
|
while (line = file.gets)
|
49
49
|
case line
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
end
|
62
|
-
when /<tuple-field name="([^"]+)">([^<]+)<\/tuple-field>/
|
63
|
-
if (valid)
|
64
|
-
if @@validations[$1]
|
65
|
-
valid = @@validations[$1].call($2)
|
50
|
+
when /<\/?data-tuple>/
|
51
|
+
if (asset.blank?)
|
52
|
+
asset = DigitalAsset.new
|
53
|
+
elsif (valid)
|
54
|
+
assets[asset.guid] ||= asset.attributes # first tuple metadata wins
|
55
|
+
assets[asset.guid]['documents_attributes'] ||= []
|
56
|
+
assets[asset.guid]['documents_attributes'] << docpath
|
57
|
+
# assets[asset.guid]['_id'] = asset.guid
|
58
|
+
asset = nil; docpath = {}; valid = true;
|
59
|
+
else
|
60
|
+
asset = nil; docpath = {}; valid = true;
|
66
61
|
end
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
62
|
+
when /<tuple-field name="([^"]+)">([^<]+)<\/tuple-field>/
|
63
|
+
if (valid)
|
64
|
+
if @@validations[$1]
|
65
|
+
valid = @@validations[$1].call($2)
|
66
|
+
end
|
67
|
+
if @@path_tuples[$1]
|
68
|
+
docpath[@@path_tuples[$1]] = $2 # if this is one of our keys, 'send' to the method
|
69
|
+
elsif (@@translation[$1])
|
70
|
+
val = asset.send("#{@@translation[$1]}").respond_to?(:[]) ? $2.split(',') : $2
|
71
|
+
asset.send("#{@@translation[$1]}=", val)
|
72
|
+
end
|
72
73
|
end
|
73
|
-
end
|
74
74
|
end
|
75
75
|
end
|
76
76
|
# loop thru each doc in the collection, either replace or delete it
|
77
77
|
error_files = []
|
78
78
|
update_count = 0; delete_count = 0; added_count = 0;
|
79
|
-
|
79
|
+
assets.keys.each do |key|
|
80
80
|
da = nil
|
81
81
|
begin
|
82
82
|
if (!assets[key]['unpublished_at'].nil?)
|
@@ -90,7 +90,7 @@ module Daengine::TeamsiteMetadataParser
|
|
90
90
|
creating = da.new?
|
91
91
|
da.documents = []
|
92
92
|
da.update_attributes!(assets[key])
|
93
|
-
if(creating)
|
93
|
+
if (creating)
|
94
94
|
added_count += 1
|
95
95
|
else
|
96
96
|
update_count += 1
|
@@ -99,14 +99,14 @@ module Daengine::TeamsiteMetadataParser
|
|
99
99
|
rescue Exception => e
|
100
100
|
#puts "--**Exception**--- #{e}"
|
101
101
|
error_files << "#{da.try(:guid)}, #{da.try(:errors).try(:full_messages)}"
|
102
|
-
end
|
102
|
+
end
|
103
103
|
end
|
104
104
|
log_txt = "TeamsiteMetadataParser: Failed to save/update following DigitalAssets in database:\n"
|
105
105
|
error_files.each do |asset_file|
|
106
106
|
log_txt = log_txt + "> #{asset_file}\n"
|
107
107
|
end
|
108
108
|
Daengine.log(log_txt, "warn") if !error_files.empty?
|
109
|
-
DigitalAsset.purge!
|
109
|
+
DigitalAsset.purge! # if the purge criteria is met, purge anything not updated
|
110
110
|
Daengine.log("TeamsiteMetadataParser: #{added_count} records added, #{update_count} updated, #{delete_count} removed", "info")
|
111
111
|
end
|
112
112
|
end
|
data/lib/daengine/version.rb
CHANGED