OSDN Git Service

fix profiler extend system
[pettanr/pettanr.git] / app / controllers / application_controller.rb
index 5c5b63a..55f54d1 100644 (file)
@@ -1,6 +1,6 @@
 class ApplicationController < ActionController::Base
   protect_from_forgery
-  layout :devise_layout if MagicNumber['test_layout']
+  layout :devise_layout
   before_filter :bf
   
   def devise_layout
@@ -29,42 +29,53 @@ class ApplicationController < ActionController::Base
         redirect_to :controller => '/system', :action => 'start'
       end
     else
-      if user_signed_in?
-        @user = current_user
-        @author = @user.author
-        @artist = if @author and @author.artist?
-          @author.artist
-        else
-          nil
-        end
+      user = if user_signed_in?
+        current_user
+      else
+        nil
+      end
+      author = if user
+        user.author
+      else
+        nil
+      end
+      artist = if user
+        user.artist
+      else
+        nil
       end
-      @admin = if admin_signed_in?
+      admin = if admin_signed_in?
         current_admin
       else
         nil
       end
-      @demand_user = if demand_user_signed_in?
+      demand_user = if demand_user_signed_in?
         current_demand_user
       else
         nil
       end
+      @operators = Operator.new [user, author, artist, admin, demand_user]
     end
   end
   
   def authenticate_reader
-    authenticate_user! unless (@user || @admin)
+    authenticate_user! unless @operators.reader?
   end
   
   def authenticate_user
-    authenticate_user! unless (@user)
+    authenticate_user! unless @operators.user?
   end
   
   def authenticate_resource_reader
-    authenticate_user! unless (@user || @admin || @demand_user)
+    authenticate_user! unless @operators.resource_reader?
+  end
+  
+  def authenticate_admin
+    authenticate_admin! unless @operators.admin?
   end
   
   def authenticate_author
-    if @author
+    if @operators.author
       true
     else
       respond_to do |format|
@@ -79,7 +90,7 @@ class ApplicationController < ActionController::Base
   end
       
   def authenticate_artist
-    if @artist
+    if @operators.artist
       true
     else
       respond_to do |format|
@@ -93,6 +104,133 @@ class ApplicationController < ActionController::Base
     end
   end
   
+  def self.controller
+    Manifest.manifest.controllers[self.model.item_name]
+  end
+  
+  def self.profiler_manager
+    Manifest.manifest.profiler_managers[self.model.item_name]
+  end
+  
+  def set_model
+    @my_controller = Manifest.manifest.controllers[params[:controller].to_s]
+    @my_action = @my_controller.actions[params[:action].to_s]
+    @my_model = Manifest.manifest.models[@my_action.item_name]
+    @my_model_class = @my_model.classify
+  end
+  
+  def set_list
+    set_model
+    @list = Locmare::ListGroup.list @my_action.item_name, @my_action.list_name
+  end
+  
+  def filer_list
+    set_list
+    list_result = @list.open(@operators, {:id => params[:id]})
+    @items = list_result.items 
+    respond_to do |format|
+      format.html {
+        @filer = Locmare::Filer.new @list.item_name, list_result.items, list_result.paginate, @operators
+        render @filer.template_name, :locals => {
+          :filer => @filer
+        }
+      }
+      format.json { render json: @items.to_json(@my_model_class.list_json_opt) }
+      format.atom 
+      format.rss
+    end
+  end
+  
+  def set_show
+    set_model
+    @item = @my_model_class.show(params[:id], @operators)
+  end
+  
+ def show_prof_format format
+    format.prof {
+      self.formats = [:html]
+      @profiler = Locmare::Profiler.new @my_model.model_name, @item, @operators
+      render @profiler.template_name, :locals => {
+        :profiler => @profiler
+      }
+    }
+  end
+  
+  def show_json_format format
+    format.json { render json: @item.to_json(@my_model_class.show_json_opt) }
+  end
+  
+  def set_new
+    set_model
+    @item = @my_model_class.new
+    @item.supply_default
+  end
+  
+  def set_edit
+    set_model
+    @item = @my_model_class.edit(params[:id], @operators)
+  end
+  
+  def render_form
+    respond_to do |format|
+      format.html { 
+        @form = Locmare::Form.new @item.item_name, @item, true, true, @operators
+        render @form.template_name, :locals => {
+          :form => @form
+        }
+      }
+      format.json { render json: @item.to_json(@my_model_class.show_json_opt) }
+    end
+  end
+  
+  def form_new
+    set_new
+    render_form
+  end
+  
+  def form_edit
+    set_edit
+    render_form
+  end
+  
+  def list_count
+    set_list
+    j = {:count => @list.count(@operators, {:id => params[:id]})}
+    respond_to do |format|
+      format.json { render json: j.to_json }
+    end
+  end
+  
+  def format_filer format
+    format.html {
+      @paginate = @@model.list_paginate(@page, @page_size)
+      render :template => 'system/filer', :locals => {
+        :items => @items, :model => @@model, 
+        :operators => @operators, :pager => @paginate
+      }
+    }
+  end
+  
+  def format_prof format
+    format.prof { 
+      @profiler = self.class.profiler_manager.open(@item, @operators)
+      render :template => 'system/prof', :locals => {
+        :profiler => @profiler
+      }
+    }
+  end
+  
+  def assist_items item_name, list_name
+    list = Locmare::ListGroup.list item_name, list_name
+    list_result = list.open(@operators, {:id => @item.id, :page => 1, :page_size => 5})
+    list_result.items
+  end
+  
+  def assist_filer item_name, items
+    filer_manager = Pettanr::Application::manifest.filer_managers[item_name]
+    filer_manager.open(item_name, items, @operators, nil)
+  end
+  
   def set_image(file)
     if file.respond_to?(:read)
       file.read