2019-02-13 12:59:28 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
# SSO and authentication relative tasks
|
|
|
|
namespace :fablab do
|
|
|
|
namespace :auth do
|
|
|
|
desc 'switch the active authentication provider'
|
|
|
|
task :switch_provider, [:provider] => :environment do |_task, args|
|
|
|
|
|
|
|
|
# disable previous provider
|
2021-03-23 11:49:05 +01:00
|
|
|
prev_prev = AuthProvider.previous
|
2023-03-22 17:30:37 +01:00
|
|
|
prev_prev&.update(status: 'pending')
|
2019-02-13 12:59:28 +01:00
|
|
|
|
2023-03-22 17:30:37 +01:00
|
|
|
AuthProvider.active.update(status: 'previous') unless AuthProvider.active.name == 'DatabaseProvider::SimpleAuthProvider'
|
2019-02-13 12:59:28 +01:00
|
|
|
|
|
|
|
# enable given provider
|
2024-01-08 09:20:52 +01:00
|
|
|
AuthProvider.find_by(name: 'FabManager').update(status: 'active')
|
2019-02-13 12:59:28 +01:00
|
|
|
|
|
|
|
# migrate the current users.
|
2022-07-26 17:27:33 +02:00
|
|
|
if AuthProvider.active.providable_type == DatabaseProvider.name
|
2019-02-13 12:59:28 +01:00
|
|
|
User.all.each do |user|
|
|
|
|
# Concerns local database provider
|
2023-03-22 17:30:37 +01:00
|
|
|
user.update(auth_token: nil)
|
2019-02-13 12:59:28 +01:00
|
|
|
end
|
2022-07-26 17:27:33 +02:00
|
|
|
else
|
|
|
|
# Concerns any providers except local database
|
|
|
|
User.all.each(&:generate_auth_migration_token)
|
2019-02-13 12:59:28 +01:00
|
|
|
end
|
|
|
|
|
2023-03-29 18:01:16 +02:00
|
|
|
# write the configuration to file
|
|
|
|
require 'provider_config'
|
|
|
|
ProviderConfig.write_active_provider
|
|
|
|
|
2019-02-13 12:59:28 +01:00
|
|
|
# ask the user to restart the application
|
2020-06-30 14:25:51 +02:00
|
|
|
next if Rails.env.test?
|
|
|
|
|
2022-04-19 16:52:05 +02:00
|
|
|
puts "\n\e[0;32m#{args.provider} successfully enabled\e[0m"
|
2019-02-13 12:59:28 +01:00
|
|
|
|
2022-04-19 16:52:05 +02:00
|
|
|
puts "\n\e[0;33m⚠ WARNING\e[0m: Please consider the following, otherwise the authentication will be bogus:"
|
|
|
|
puts "\t1) RESTART the application"
|
|
|
|
puts "\t2) NOTIFY the current users with `rails fablab:auth:notify_changed`\n\n"
|
2019-02-13 12:59:28 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
desc 'notify users that the auth provider has changed'
|
|
|
|
task notify_changed: :environment do
|
|
|
|
I18n.locale = I18n.default_locale
|
|
|
|
|
|
|
|
# notify every users if the provider is not local database provider
|
|
|
|
if AuthProvider.active.providable_type != DatabaseProvider.name
|
|
|
|
User.all.each do |user|
|
|
|
|
NotificationCenter.call type: 'notify_user_auth_migration',
|
|
|
|
receiver: user,
|
|
|
|
attached_object: user
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
puts "\nUsers successfully notified\n\n"
|
|
|
|
end
|
2022-04-19 16:52:05 +02:00
|
|
|
|
|
|
|
desc 'display the current active authentication provider'
|
|
|
|
task current: :environment do
|
|
|
|
puts "Current active authentication provider: #{AuthProvider.active.name}"
|
|
|
|
end
|
2023-03-29 18:01:16 +02:00
|
|
|
|
|
|
|
desc 'write the provider config to a configuration file'
|
|
|
|
task write_provider: :environment do
|
|
|
|
require 'provider_config'
|
|
|
|
ProviderConfig.write_active_provider
|
|
|
|
end
|
2019-02-13 12:59:28 +01:00
|
|
|
end
|
|
|
|
end
|