38 lines
1.6 KiB
Ruby
38 lines
1.6 KiB
Ruby
# Datasets CSV example:
|
|
# carto-do-public-data.open_data.geography_usa_state_2015,bq;spanner,999,2020-09-27T08:00:00
|
|
# carto-do-public-data.open_data.demographics_acs_usa_cbsaclipped_2015_yearly_2015,bq,2000,2020-09-27T08:00:00
|
|
namespace :cartodb do
|
|
namespace :data_observatory do
|
|
desc "Enables access to DO datasets for a user and saves the metadata in Central and Redis"
|
|
task :purchase_datasets, [:username, :datasets_csv] => [:environment] do |_, args|
|
|
username = args[:username]
|
|
datasets_csv = args[:datasets_csv]
|
|
usage = 'USAGE: data_observatory:purchase_datasets["username","path/datasets.csv"]'
|
|
raise usage unless username.present? && datasets_csv.present?
|
|
|
|
datasets = []
|
|
CSV.foreach(args[:datasets_csv]) do |row|
|
|
available_in = row[1].split(';')
|
|
dataset = { dataset_id: row[0], available_in: available_in, price: row[2].to_f, expires_at: Time.parse(row[3]) }
|
|
datasets << dataset
|
|
end
|
|
|
|
Carto::DoLicensingService.new(username).subscribe(datasets)
|
|
|
|
puts 'Task finished succesfully!'
|
|
end
|
|
|
|
desc "Removes access to a DO dataset for a user and updates the metadata in Central and Redis"
|
|
task :remove_purchase, [:username, :dataset_id] => [:environment] do |_, args|
|
|
username = args[:username]
|
|
dataset_id = args[:dataset_id]
|
|
usage = 'USAGE: data_observatory:remove_purchase["username","project.schema.table"]'
|
|
raise usage unless username.present? && dataset_id.present?
|
|
|
|
Carto::DoLicensingService.new(username).unsubscribe(dataset_id)
|
|
|
|
puts 'Task finished succesfully!'
|
|
end
|
|
end
|
|
end
|