Class: DigitalAssetsController

Inherits:
ApplicationController
  • Object
show all
Includes:
DigitalAssetsHelper
Defined in:
app/controllers/digital_assets_controller.rb

Constant Summary collapse

CACHE_LAST_PARSE_TIME =
'last_parse_time'

Instance Method Summary collapse

Methods included from DigitalAssetsHelper

#search_da

Instance Method Details

#indexObject

GET /digital_assets GET /digital_assets.json



8
9
10
11
# File 'app/controllers/digital_assets_controller.rb', line 8

def index
  @digital_assets = DigitalAsset.all
  respond_with(@digital_assets)
end

#searchObject

/digital_assets/search/sami_code=92023 /digital_assets/search/sami_code=NE00192&title=Fund%20Prospectus&fund_code=20293



22
23
24
25
# File 'app/controllers/digital_assets_controller.rb', line 22

def search
  @digital_assets = search_da(params)
  respond_with(@digital_assets)
end

#showObject

GET /digital_assets/1 GET /digital_assets/1.json



15
16
17
18
# File 'app/controllers/digital_assets_controller.rb', line 15

def show
  @digital_asset = /\w{4,8}\.\d{0,3}/ =~ params[:id] ? DigitalAsset.sami_is(params[:id]).desc(:changed_at).first : DigitalAsset.find(params[:id])
  respond_with(@digital_asset)
end

#sync_assetsObject



27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# File 'app/controllers/digital_assets_controller.rb', line 27

def sync_assets
  time0 = Rails.cache.read(CACHE_LAST_PARSE_TIME)
  if time0.nil?
    time0 = 2.days.ago
  end
  logger.info "Last time when ssc deploy files were read: #{time0.inspect}"
  time1 = Time.new
  logger.info "Current time: #{time1.inspect}"

  Rails.cache.write(CACHE_LAST_PARSE_TIME, time1)
  deploy_files= []

  start_directory = EDIST['digital_assets_directory']
  logger.info "Reading digital asset deployment files from #{start_directory}"
  if (File::directory?(start_directory))
    Dir.foreach(start_directory) do |entry|
      if (!File::directory?(entry))
        filename = start_directory + entry
        difference0 = File.mtime(filename)- time0 #To-Do - We should be looking at created time - ctime
        difference1 = File.mtime(filename) - time1
        if ((difference0 >= 0) & (difference1 < 0))
          if(/bulk-ssc_|selective-ssc_/ =~ filename)
            deploy_files << filename
          end
        end
      end
    end
  end

  deploy_files.each do |filename|
    #parse the file and add content to database.
    logger.info "Processing file #{filename} found."
    file = File.expand_path(filename, __FILE__)
    open_file = open(file, 'rb')
    Etl::TeamsiteMetadataParser.parse_tuple_file(open_file)
    logger.info "Finished parsing #{filename}."
  end

  head :accepted
end