daengine 0.1.7 → 0.1.8

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.
@@ -68,7 +68,7 @@ module Daengine
68
68
  open_file = File.open(file, 'rb')
69
69
  Daengine::TeamsiteMetadataParser.parse_tuple_file(open_file)
70
70
  Daengine.log("DigitalAssetProcessor: Finished processing #{filename}", "info")
71
- @@last_read_time = File.mtime(file)
71
+ @@last_read_time = File.mtime(file) + 1.second
72
72
  self.save_last_read_time
73
73
  Daengine.log("DigitalAssetProcessor: Last process time set to #{@@last_read_time}", "info")
74
74
  end
@@ -23,7 +23,7 @@ module Daengine::TeamsiteMetadataParser
23
23
  }
24
24
  @@validations = {
25
25
  "TeamSite/Metadata/display_on_website" => lambda { |val| /Y|1/ =~ val },
26
- "TeamSite/Metadata/enterprise_expiration_date" => lambda { |val| Time.parse(val) > 1.minute.from_now },
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) }
29
29
  }
@@ -79,9 +79,12 @@ module Daengine::TeamsiteMetadataParser
79
79
  assets.keys.each do |key|
80
80
  da = nil
81
81
  begin
82
- if(!assets[key]['unpublished_at'].blank?)
83
- DigitalAsset.where(guid: key).delete_all
84
- delete_count += 1
82
+ if (!assets[key]['unpublished_at'].nil?)
83
+ DigitalAsset.where(guid: key).try :delete_all
84
+ delete_count += 1
85
+ elsif (assets[key]['expires_at'].nil? || (assets[key]['expires_at'] < 1.minute.from_now))
86
+ DigitalAsset.where(guid: key).try :delete_all
87
+ delete_count += 1
85
88
  else
86
89
  da = DigitalAsset.find_or_initialize_by(guid: key)
87
90
  creating = da.new?
@@ -89,12 +92,12 @@ module Daengine::TeamsiteMetadataParser
89
92
  da.update_attributes!(assets[key])
90
93
  if(creating)
91
94
  added_count += 1
92
- else
95
+ else
93
96
  update_count += 1
94
97
  end
95
98
  end
96
99
  rescue Exception => e
97
- error_files << e.to_s
100
+ #puts "--**Exception**--- #{e}"
98
101
  error_files << "#{da.try(:guid)}, #{da.try(:errors).try(:full_messages)}"
99
102
  end
100
103
  end
@@ -102,7 +105,7 @@ module Daengine::TeamsiteMetadataParser
102
105
  error_files.each do |asset_file|
103
106
  log_txt = log_txt + "> #{asset_file}\n"
104
107
  end
105
- Daengine.log(log_txt, "warn") if error_files
108
+ Daengine.log(log_txt, "warn") if !error_files.empty?
106
109
  DigitalAsset.purge! # if the purge criteria is met, purge anything not updated
107
110
  Daengine.log("TeamsiteMetadataParser: #{added_count} records added, #{update_count} updated, #{delete_count} removed", "info")
108
111
  end
@@ -1,3 +1,3 @@
1
1
  module Daengine
2
- VERSION = "0.1.7"
2
+ VERSION = "0.1.8"
3
3
  end
metadata CHANGED
@@ -2,7 +2,7 @@
2
2
  name: daengine
3
3
  version: !ruby/object:Gem::Version
4
4
  prerelease:
5
- version: 0.1.7
5
+ version: 0.1.8
6
6
  platform: ruby
7
7
  authors:
8
8
  - sbhatia