This repository has been archived on 2024-03-16. You can view files and clone it, but cannot push or open issues or pull requests.
orbit-4-1/app/controllers/application_controller.rb

208 lines
5.0 KiB
Ruby
Raw Normal View History

2009-05-07 16:53:18 +00:00
class ApplicationController < ActionController::Base
protect_from_forgery
2010-03-08 08:04:05 +00:00
2011-12-23 10:34:21 +00:00
include ParserFrontEnd, ParserBackEnd
2012-02-19 08:33:22 +00:00
layout :layout_by_resource
2010-03-08 08:04:05 +00:00
helper :all
2011-05-13 01:08:42 +00:00
before_filter :set_locale, :set_site
2012-01-05 08:20:51 +00:00
def set_current_user
2012-08-23 08:05:14 +00:00
User.current = current_or_guest_user
end
2012-01-05 08:20:51 +00:00
def front_end_available(module_app_title='')
app_controller = ModuleApp.first(conditions: {:key => module_app_title} )
2012-01-05 08:20:51 +00:00
unless app_controller.enable_frontend?
2012-01-18 13:34:26 +00:00
render :nothing => true
2012-01-05 08:20:51 +00:00
end
end
def get_all_app_engines
2012-01-10 10:29:11 +00:00
ary = ["vender/plugins/new_blog"]
app_engines = ary.collect{|t|
Rails::Engine.find t
}
app_engines.each{ |t|
# t.
}
end
def flaten_controller
ary=[]
Find.find(File.join(Rails.root , 'vendor/plugins/')) { |name|
require_dependency(name) if /_controller\.rb$/ =~ name
ary << name
}
ary
end
# Find the parent for the given item
def find_parent_item
@parent_item = Item.first(:conditions => { :id => BSON::ObjectId(params[:parent_id]) }) rescue nil
end
2009-06-19 09:31:10 +00:00
def auth_failed_in_backend
#redirect_to admin_dashboards_url
redirect_to root_path
end
# Check if the current_user is admin
def is_admin?
2012-08-23 08:05:14 +00:00
current_or_guest_user.admin? ? true : auth_failed_in_backend
end
def is_manager?
2012-08-23 08:05:14 +00:00
@module_app.is_manager?(current_or_guest_user) || is_admin?
end
# Check if the current_user is admin
def is_member?
if (current_user rescue false)
return true
end
return false
end
def is_guest?
if session[:guest_user_id]
return true
end
return false
end
def for_admin_only
if is_admin?
true
else
flash[:error] = t("admin.access.denied.not_admin")
auth_failed_in_backend
end
end
def for_app_manager
if is_manager?
true
else
flash[:error] = t("admin.access.denied.app.not_manager")
auth_failed_in_backend
end
end
def for_app_sub_manager
2012-08-23 08:05:14 +00:00
if (@module_app.sub_managing_users.include?(current_or_guest_user) || is_manager?)
true
else
flash[:error] = t("admin.access.denied.app.not_sub_manager")
auth_failed_in_backend
end
end
def for_app_user
2012-08-23 08:05:14 +00:00
if (@module_app.app_auth.auth_users.include?(current_or_guest_user) || for_app_sub_manager )
true
else
flash[:error] = t("admin.access.denied.app.not_authed_user")
auth_failed_in_backend
end
end
def check_object_premission(obj,title)
flash[:error] = t("admin.access.denied.object")
2012-08-23 08:05:14 +00:00
auth_failed_in_backend unless (obj.get_object_auth_by_title(title).auth_users.include?(current_or_guest_user) || is_manager? || is_admin? )
end
# Render the page
2012-05-13 11:32:05 +00:00
def render_page
if @item
2012-05-13 11:32:05 +00:00
render :text => parse_page_noko(@item), :layout => 'page_layout'
else
render :text => '404 Not Found'
end
end
2011-08-18 05:43:33 +00:00
protected
# Set I18n.locale
2009-06-19 09:31:10 +00:00
def set_locale
# update session if passed
session[:locale] = params[:locale] if params[:locale]
2009-06-19 09:31:10 +00:00
# set locale based on session or default
begin
# check if locale is valid for non site pages
if LIST[:forbidden_item_names].include?(env['PATH_INFO'].split('/')[1].to_s) && !VALID_LOCALES.include?(session[:locale])
I18n.locale = I18n.default_locale
else
I18n.locale = session[:locale]
end
rescue
I18n.locale = I18n.default_locale
end
2010-01-11 09:09:50 +00:00
end
2010-03-08 08:04:05 +00:00
# Set the site variables
def set_site
# set site if exist or create site
@site = Site.first || Site.create({:valid_locales => [], :in_use_locales => []})
session[:site] = @site.id
@site_in_use_locales = site_locales_default_head(@site.in_use_locales)
@site_valid_locales = site_locales_default_head(@site.valid_locales)
end
2011-05-13 01:08:42 +00:00
def set_current_item
session[:current_page] = params[:id] || @item.id rescue nil
2011-05-13 01:08:42 +00:00
end
2011-08-18 05:43:33 +00:00
def decrypt_data(encrypted_data, encrypted_key, encrypted_iv)
site = Site.find(session[:site])
if encrypted_data
private_key = OpenSSL::PKey::RSA.new(site.private_key)
cipher = OpenSSL::Cipher.new('aes-256-cbc')
cipher.decrypt
cipher.key = private_key.private_decrypt(encrypted_key)
cipher.iv = private_key.private_decrypt(encrypted_iv)
decrypted_data = cipher.update(encrypted_data)
decrypted_data << cipher.final
else
''
end
end
2011-09-01 01:12:41 +00:00
def get_homepage
2012-05-22 06:45:49 +00:00
Page.root
2011-09-01 01:12:41 +00:00
end
2012-02-19 08:33:22 +00:00
def layout_by_resource
if devise_controller?
"devise"
else
"application"
end
end
def site_locales_default_head(locales)
if locales[0].eql? I18n.locale.to_s
locales
else
a = Array.new(locales)
shift_out = a.delete(I18n.locale.to_s)
[shift_out] + a
end
end
2012-08-23 08:05:14 +00:00
# called (once) when the user logs in, insert any code your application needs
# to hand off from guest_user to current_user.
def logging_in
# For example:
# guest_comments = guest_user.comments.all
# guest_comments.each do |comment|
# comment.user_id = current_user.id
# comment.save
# end
end
2009-05-07 16:53:18 +00:00
end