1 class ApplicationController < ActionController::Base
3 layout :devise_layout if MagicNumber['test_layout']
23 :location => {:controller => params[:controller], :action => params[:action]}
25 @server_result[:location][:id] = params[:id] if params[:id]
26 if Admin.count.to_i == 0 or License.count.to_i == 0
27 if params[:controller] == 'system' and params[:action] == 'start'
29 redirect_to :controller => '/system', :action => 'start'
34 @author = @user.author
35 @artist = if @author and @author.artist?
41 @admin = if admin_signed_in?
46 @demand_user = if demand_user_signed_in?
54 def authenticate_reader
55 authenticate_user! unless (@user || @admin)
59 authenticate_user! unless (@user)
62 def authenticate_resource_reader
63 authenticate_user! unless (@user || @admin || @demand_user)
66 def authenticate_author
70 respond_to do |format|
71 format.html { redirect_to main_app.new_author_path, :status => :found }
72 format.js { render "authors/new" }
74 raise ActiveRecord::Forbidden
81 def authenticate_artist
85 respond_to do |format|
86 format.html { redirect_to main_app.new_artist_path, :status => :found }
87 format.js { render "artists/new" }
89 raise ActiveRecord::Forbidden
96 def format_prof format
98 render :template => 'system/prof', :locals => {
99 :item => @item, :roles => [@user, @admin]
105 if file.respond_to?(:read)
108 Base64.decode64(file.to_s.gsub(' ', '+'))
112 def ymd_to_time ymd_str
113 return nil if ymd_str.blank?
116 date = Time.parse(ymd_str[0..3] + '/' + ymd_str[4..5] + '/' + ymd_str[6..7])
123 def export_url demander_url, action, token, date
124 u = demander_url + (demander_url[-1] == '/' ? '' : '/')
125 prm = '?auth_token=' + token
126 prm = prm + '&date=' + date.strftime("%Y%m%d") unless date.blank?
127 u = URI.join(u, action + '.json' + prm)
131 def export_from_provider url
134 json = RestClient.get url
135 res = JSON.parse json
141 def export_by action, provider_status, ymd
143 url = export_url provider_status.provider.demander_url, action, provider_status.token, t
144 export_from_provider(url)
147 rescue_from Pettanr::NotWork, :with => :render_not_work
148 def render_not_work(exception = nil)
150 logger.info "Rendering , :: #{exception.message}"
152 respond_to do |format|
154 render :file => "#{Rails.root}/public/not_work.html", :layout => false
157 render :text => "400 Not work", :status => 400
162 if Rails.env == 'production'
163 rescue_from ActiveRecord::RecordNotFound, :with => :render_404
164 rescue_from ActiveRecord::Forbidden, :with => :render_403
167 def render_404(exception = nil)
169 logger.info "Rendering 404: #{exception.message}"
171 respond_to do |format|
173 render :file => "#{Rails.root}/public/404.html", :status => 404, :layout => false
176 render :text => "404 Not found", :status => 404
181 def render_403(exception = nil)
183 logger.info "Rendering 403: #{exception.message}"
185 respond_to do |format|
187 render :file => "#{Rails.root}/public/403.html", :status => 404, :layout => false
190 render :text => "403 Forbidden", :status => 403