12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- # Copyright (C) 2012-2023 Zammad Foundation, https://zammad-foundation.org/
- module SessionHelper
- def self.json_hash(user)
- collections, assets = default_collections(user)
- {
- session: user.filter_unauthorized_attributes(user.filter_attributes(user.attributes)),
- models: models(user),
- collections: collections,
- assets: assets,
- }
- end
- def self.json_hash_error(error)
- {
- error: error.message,
- models: models,
- collections: {
- Locale.to_app_model => Locale.where(active: true),
- PublicLink.to_app_model => PublicLink.all,
- }
- }
- end
- def self.default_collections(user)
- # auto population collections, store all here
- default_collection = {}
- assets = user.assets({})
- # load collections to deliver from external files
- dir = File.expand_path('..', __dir__)
- files = Dir.glob("#{dir}/lib/session_helper/collection_*.rb")
- files.each do |file|
- file =~ %r{/(session_helper/collection_.*)\.rb\z}
- class_name = $1.camelize
- next if !Object.const_defined?(class_name) && Rails.env.production?
- (default_collection, assets) = class_name.constantize.session(default_collection, assets, user)
- end
- [default_collection, assets]
- end
- def self.models(user = nil)
- models = {}
- objects = ObjectManager.list_objects
- objects.each do |object|
- # User related fields are needed for register.
- next if user.nil? && !object.eql?('User')
- attributes = ObjectManager::Object.new(object).attributes(user, skip_permission: user.nil?)
- models[object] = attributes
- end
- models
- end
- def self.cleanup_expired
- # delete temp. sessions
- ActiveRecord::SessionStore::Session.where('persistent IS NULL AND updated_at < ?', 2.hours.ago).delete_all
- # web sessions not updated the last x days
- ActiveRecord::SessionStore::Session.where('updated_at < ?', 60.days.ago).delete_all
- end
- def self.get(id)
- ActiveRecord::SessionStore::Session.find_by(id: id)
- end
- def self.list(limit = 10_000)
- ActiveRecord::SessionStore::Session.reorder(updated_at: :desc).limit(limit)
- end
- def self.destroy(id)
- session = ActiveRecord::SessionStore::Session.find_by(id: id)
- return if !session
- session.destroy
- end
- end
|