aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorXinhui2016-08-10 10:43:13 +0200
committerXinhui2016-08-10 10:43:13 +0200
commit53526748c12eb790647b656254b009a08278b70f (patch)
treedae69edd198142e25f9334391cd3d9568ed96987 /lib
parent0857749941849c71a6d24f2a38891d3c19964126 (diff)
downloadchouette-core-53526748c12eb790647b656254b009a08278b70f.tar.bz2
Refactoring move portail sync code into models
Diffstat (limited to 'lib')
-rw-r--r--lib/tasks/organisations.rake31
-rw-r--r--lib/tasks/users.rake40
2 files changed, 2 insertions, 69 deletions
diff --git a/lib/tasks/organisations.rake b/lib/tasks/organisations.rake
index 94a9215b7..1b21d7119 100644
--- a/lib/tasks/organisations.rake
+++ b/lib/tasks/organisations.rake
@@ -1,35 +1,6 @@
namespace :organisations do
- def api_retrieve_organisation
- conf = Rails.application.config.try(:stif_portail_api)
- raise 'Rails.application.config.stif_portail_api settings is not defined' unless conf
-
- conn = Faraday.new(:url => conf[:url]) do |c|
- c.headers['Authorization'] = "Token token=\"#{conf[:key]}\""
- c.adapter Faraday.default_adapter
- end
-
- resp = conn.get '/api/v1/organizations'
- if resp.status == 200
- JSON.parse resp.body
- else
- raise "Error on api request status : #{resp.status} => #{resp.body}"
- end
- end
-
- def sync_organisations data
- data.each do |el|
- Organisation.find_or_create_by(code: el['code']).tap do |org|
- org.name = el['name']
- org.synced_at = Time.now
- org.save if org.changed?
- puts "✓ Organisation #{org.name} has been updated" unless Rails.env.test?
- end
- end
- end
-
desc "Sync organisations from stif portail"
task sync: :environment do
- data = api_retrieve_organisation
- sync_organisations(data) if data
+ Organisation.portail_sync
end
end
diff --git a/lib/tasks/users.rake b/lib/tasks/users.rake
index 76250f0f0..c045639c1 100644
--- a/lib/tasks/users.rake
+++ b/lib/tasks/users.rake
@@ -1,44 +1,6 @@
namespace :users do
- def api_retrieve_user
- conf = Rails.application.config.try(:stif_portail_api)
- raise 'Rails.application.config.stif_portail_api settings is not defined' unless conf
-
- conn = Faraday.new(:url => conf[:url]) do |c|
- c.headers['Authorization'] = "Token token=\"#{conf[:key]}\""
- c.adapter Faraday.default_adapter
- end
-
- resp = conn.get '/api/v1/users'
- if resp.status == 200
- JSON.parse resp.body
- else
- raise "Error on api request status : #{resp.status} => #{resp.body}"
- end
- end
-
- def sync_users data
- data.each do |el|
- User.find_or_create_by(username: el['username']).tap do |user|
- user.name = "#{el['firstname']} #{el['lastname']}"
- user.email = el['email']
- user.locked_at = el['locked_at']
- user.synced_at = Time.now
-
- # Set organisation
- user.organisation = Organisation.find_or_create_by(code: el['organization_code']).tap do |org|
- org.name = el['organization_name']
- org.synced_at = Time.now
- end
-
- user.save if user.changed?
- puts "✓ user #{user.username} has been updated" unless Rails.env.test?
- end
- end
- end
-
desc "Sync users from stif portail"
task sync: :environment do
- data = api_retrieve_user
- sync_users(data) if data
+ User.portail_sync
end
end