OSDN Git Service

temp
[pettanr/pettanr.git] / app / controllers / application_controller.rb
1 class ApplicationController < ActionController::Base
2   protect_from_forgery
3   layout :devise_layout if MagicNumber['test_layout']
4   before_filter :bf
5   
6   def devise_layout
7     if devise_controller?
8       case resource_name
9       when :admin
10         'guest'
11       when :user
12         'guest'
13       when :demand_user
14         'guest'
15       end
16     else
17       'application'
18     end
19   end
20   
21   def bf
22     @server_result = {
23       :location => {:controller => params[:controller], :action => params[:action]}
24     }
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'
28       else
29         redirect_to :controller => '/system', :action => 'start'
30       end
31     else
32       user = if user_signed_in?
33         current_user
34       else
35         nil
36       end
37       author = if user
38         user.author
39       else
40         nil
41       end
42       artist = if user
43         user.artist
44       else
45         nil
46       end
47       admin = if admin_signed_in?
48         current_admin
49       else
50         nil
51       end
52       demand_user = if demand_user_signed_in?
53         current_demand_user
54       else
55         nil
56       end
57       @operators = Operator.new [user, author, artist, admin, demand_user]
58     end
59   end
60   
61   def authenticate_reader
62     authenticate_user! unless @operators.reader?
63   end
64   
65   def authenticate_user
66     authenticate_user! unless @operators.user?
67   end
68   
69   def authenticate_resource_reader
70     authenticate_user! unless @operators.resource_reader?
71   end
72   
73   def authenticate_author
74     if @operators.author
75       true
76     else
77       respond_to do |format|
78         format.html { redirect_to main_app.new_author_path, :status => :found }
79         format.js { render "authors/new" }
80         format.json { 
81           raise ActiveRecord::Forbidden
82         }
83       end
84       false
85     end
86   end
87       
88   def authenticate_artist
89     if @operators.artist
90       true
91     else
92       respond_to do |format|
93         format.html { redirect_to main_app.new_artist_path, :status => :found }
94         format.js { render "artists/new" }
95         format.json { 
96           raise ActiveRecord::Forbidden
97         }
98       end
99       false
100     end
101   end
102   
103   def self.controller
104     Pettanr::Application::manifest.controller_managers[self.model.item_name]
105   end
106   
107   def self.profiler_manager
108     Pettanr::Application::manifest.profiler_managers[self.model.item_name]
109   end
110   
111   def public_list
112     action_name = params[:action]
113     @action = self.class.controller.open(action_name, params, @operators)
114     @items = @action.items 
115     respond_to do |format|
116       format.html {
117         @filer = @action.filer
118         render :template => 'system/filer', :locals => {
119           :filer => @filer
120         }
121       }
122       format.json { render json: @items.to_json(self.class.model.list_json_opt) }
123       format.atom 
124       format.rss
125     end
126   end
127   
128   def format_filer format
129     format.html {
130       @paginate = @@model.list_paginate(@page, @page_size)
131       render :template => 'system/filer', :locals => {
132         :items => @items, :model => @@model, 
133         :operators => @operators, :pager => @paginate
134       }
135     }
136   end
137   
138   def set_filer_by_anybody 
139     @page = @@model.page_number params[:page]
140     @page_size = @@model.page_size params[:page_size]
141     list_method = 'himlist' || configurations['models'][@@model.to_s.underscore]['select']['method']
142     @items = @@model.__send__(list_method, @operators, @page, @page_size)
143   end
144   
145   def format_filer_by_anybody format
146     format.html {
147       @paginate = @@model.himlist_paginate(@operators, @page, @page_size)
148       render :template => 'system/filer', :locals => {
149         :items => @items, :model => @@model, 
150         :operators => @operators, :pager => @paginate
151       }
152     }
153   end
154   
155   def format_prof format
156     format.prof { 
157       render :template => 'system/prof', :locals => {
158         :item => @item, :operators => @operators
159       }
160     }
161   end
162   
163   def set_image(file)
164     if file.respond_to?(:read)
165       file.read
166     else
167       Base64.decode64(file.to_s.gsub(' ', '+'))
168     end
169   end
170   
171   def ymd_to_time ymd_str
172     return nil if ymd_str.blank?
173     date = nil
174     begin
175       date = Time.parse(ymd_str[0..3] + '/' + ymd_str[4..5] + '/' + ymd_str[6..7])
176     rescue
177       date = nil
178     end
179     date
180   end
181   
182   def export_url demander_url, action, token, date
183     u = demander_url + (demander_url[-1] == '/' ? '' : '/')
184     prm = '?auth_token=' + token
185     prm = prm + '&date=' + date.strftime("%Y%m%d") unless date.blank?
186     u = URI.join(u, action + '.json' + prm)
187     u.to_s
188   end
189   
190   def export_from_provider url
191     res = nil
192     begin
193       json = RestClient.get url
194       res = JSON.parse json
195     rescue
196     end
197     res
198   end
199   
200   def export_by action, provider_status, ymd
201     t = ymd_to_time ymd
202     url = export_url provider_status.provider.demander_url, action, provider_status.token, t
203     export_from_provider(url)
204   end
205   
206     rescue_from Pettanr::NotWork, :with => :render_not_work
207     def render_not_work(exception = nil)
208       if exception
209         logger.info "Rendering , :: #{exception.message}"
210       end
211       respond_to do |format|
212         format.html { 
213           render :file => "#{Rails.root}/public/not_work.html", :layout => false
214         }
215         format.json { 
216           render :text => "400 Not work", :status => 400
217         }
218       end
219     end
220     
221   if Rails.env == 'production'
222     rescue_from ActiveRecord::RecordNotFound, :with => :render_404
223     rescue_from ActiveRecord::Forbidden, :with => :render_403
224     
225     private
226     def render_404(exception = nil)
227       if exception
228         logger.info "Rendering 404: #{exception.message}"
229       end
230       respond_to do |format|
231         format.html { 
232           render :file => "#{Rails.root}/public/404.html", :status => 404, :layout => false
233         }
234         format.json { 
235           render :text => "404 Not found", :status => 404
236         }
237       end
238     end
239     
240     def render_403(exception = nil)
241       if exception
242         logger.info "Rendering 403: #{exception.message}"
243       end
244       respond_to do |format|
245         format.html { 
246           render :file => "#{Rails.root}/public/403.html", :status => 404, :layout => false
247         }
248         format.json { 
249           render :text => "403 Forbidden", :status => 403
250         }
251       end
252     end
253   end
254 end