108 lines
2.9 KiB
Ruby
Executable File
108 lines
2.9 KiB
Ruby
Executable File
class ApplicationController < ActionController::Base
|
|
include LoginVerification
|
|
#before_action :check_installation
|
|
protect_from_forgery with: :exception
|
|
|
|
# lookup domain for db from provision
|
|
before_action :check_license, :lookup_domain, :set_locale
|
|
|
|
helper_method :current_company,:current_login_employee,:current_user
|
|
# alias_method :current_user, :current_login_employee,:current_user
|
|
#this is base api base controller to need to inherit.
|
|
#all token authentication must be done here
|
|
#response format must be set to JSON
|
|
|
|
#change locallization
|
|
def set_locale
|
|
I18n.locale = params[:locale] || I18n.default_locale
|
|
end
|
|
|
|
# RESTful url for localize
|
|
def default_url_options
|
|
{ locale: I18n.locale }
|
|
end
|
|
|
|
def lookup_domain
|
|
if request.subdomain.present? && request.subdomain != "www"
|
|
@license = current_license(ENV["SX_PROVISION_URL"], request.subdomain.downcase) # request.subdomain.downcase
|
|
if (!@license.nil?)
|
|
# logger.info "Location - " + @license.name
|
|
ActiveRecord::Base.establish_connection(website_connection(@license))
|
|
# logger.info "Connecting to - " + @license.subdomain + " - "+ @license.dbhost + "@" + @license.dbschema
|
|
else
|
|
# reconnect_default_db
|
|
logger.info 'License is nil'
|
|
# redirect_to root_url(:host => request.domain) + "store_error"
|
|
render :json => [{ status: false, message: 'Invalid Access!'}]
|
|
end
|
|
end
|
|
end
|
|
|
|
def current_license(url, key)
|
|
@license = License.new(url, key)
|
|
|
|
# Export for Key
|
|
passphrase = key + ENV["secret_key_base"]
|
|
key, iv = AESEncDec.export_key(passphrase)
|
|
|
|
if (@license.detail_with_local_file(key, key, iv) == true)
|
|
#if (@license.detail == true)
|
|
|
|
return @license
|
|
else
|
|
return nil
|
|
end
|
|
end
|
|
|
|
def website_connection(license)
|
|
default_connection.dup.update(:host => license.dbhost, :database => license.dbschema.to_s.downcase,
|
|
:username => license.dbusername, :password => license.dbpassword)
|
|
|
|
end
|
|
|
|
def reconnect_default_db
|
|
ActiveRecord::Base.establish_connection(Rails.env)
|
|
end
|
|
|
|
# Regular database.yml configuration hash
|
|
def default_connection
|
|
@default_config ||= ActiveRecord::Base.connection.instance_variable_get("@config").dup
|
|
end
|
|
|
|
rescue_from CanCan::AccessDenied do |exception|
|
|
flash[:warning] = exception.message
|
|
redirect_to root_path
|
|
end
|
|
|
|
def current_user
|
|
@current_user ||= Employee.find_by_token_session(session[:session_token]) if session[:session_token]
|
|
end
|
|
|
|
def current_company
|
|
begin
|
|
return Company.first
|
|
rescue
|
|
return nil
|
|
end
|
|
|
|
end
|
|
|
|
def current_login_employee
|
|
if (!session[:session_token].nil?)
|
|
@employee = Employee.find_by_token_session(session[:session_token])
|
|
end
|
|
end
|
|
|
|
private
|
|
def check_license
|
|
if License.check_license_file
|
|
|
|
else
|
|
redirect_to install_path
|
|
end
|
|
end
|
|
end
|
|
|
|
|
|
|