OSDN Git Service

merge v04
[pettanr/pettanr.git] / app / controllers / original_pictures_controller.rb
index 0b651ff..c5bb41a 100644 (file)
@@ -1,32 +1,32 @@
 class OriginalPicturesController < ApplicationController
-  before_filter :authenticate_author!, :except => [:index, :show]
-
+  layout 'test' if Pettanr::TestLayout
+  before_filter :authenticate_user!, :only => [:index, :show, :new, :edit, :create, :update, :destroy]
+  before_filter :authenticate_admin!, :only => [:list, :browse]
+  before_filter :authenticate_artist, :only => [:index, :show, :new, :edit, :create, :update, :destroy]
+  
   private
   
-  def set_image(prm)
-    img = nil
-    if (f = prm[:original_picture][:file]).respond_to?(:read)
-      if f.size > 1000000
-        @original_picture.width = 0
-        @original_picture.height = 0
-        @original_picture.ext = 'none'
-        @original_picture.filesize = 1.megabytes
-      else
-        img = Magick::Image.from_blob(f.read).shift
-        @original_picture.width = img.columns
-        @original_picture.height = img.rows
-        @original_picture.ext = img.format.downcase
-        @original_picture.filesize = f.size
-      end
+  def set_image(file)
+    if file.respond_to?(:read)
+      file.read
     else
-      dat = Base64.decode64(prm[:original_picture][:file].to_s.gsub(' ', '+')) #rubyのバグ?+でデコードされるべきキャラがスペースになる
-      img = Magick::Image.from_blob(dat).shift
-      @original_picture.width = img.columns
-      @original_picture.height = img.rows
-      @original_picture.ext = img.format.downcase
-      @original_picture.filesize = 1000
+      Base64.decode64(file.to_s.gsub(' ', '+')) #rubyのバグ?+でデコードされるべきキャラがスペースになる
+    end
+  end
+  
+  def authenticate_artist
+    if @author.artist?
+      true
+    else
+      respond_to do |format|
+        format.html { redirect_to new_artist_path, :status => :found }
+        format.js { render "artists/new" }
+        format.json { 
+          raise ActiveRecord::Forbidden
+        }
+      end
+      false
     end
-    img
   end
   
   public
@@ -34,30 +34,50 @@ class OriginalPicturesController < ApplicationController
   # GET /original_pictures
   # GET /original_pictures.json
   def index
-    @original_pictures = OriginalPicture.all
+    @page = OriginalPicture.page params[:page]
+    @page_size = OriginalPicture.page_size params[:page_size]
+    @original_pictures = OriginalPicture.list(@artist.id, {}, @page, @page_size)
 
     respond_to do |format|
       format.html # index.html.erb
-      format.json { render json: @original_pictures }
+      format.json { render json: @original_pictures.to_json(OriginalPicture.list_json_opt) }
     end
   end
 
   # GET /original_pictures/1
   # GET /original_pictures/1.json
   def show
-    @original_picture = OriginalPicture.find(params[:id])
-#    if params[:subdir] == 'refresh'
-#      refresh 
-#      return
-#    end
-
+    @original_picture = OriginalPicture.show(params[:id], @artist)
+    
     respond_to do |format|
       opt = {:type => @original_picture.mime_type, :disposition=>"inline"}
       format.png { send_data(@original_picture.restore, opt ) }
       format.gif { send_data(@original_picture.restore, opt ) }
       format.jpeg { send_data(@original_picture.restore, opt ) }
-      format.html # show.html.erb
-      format.json { render json: @original_picture}
+      format.html {
+        #ライセンス付与のために原画ライセンスグループ作成準備
+        @original_picture_license_group  = OriginalPictureLicenseGroup.new :original_picture_id => @original_picture.id
+        render
+      }
+      format.json { render json: @original_picture.to_json(OriginalPicture.show_json_include_opt)}
+    end
+  end
+
+  def list
+    @original_pictures = OriginalPicture.all
+
+    respond_to do |format|
+      format.html { render layout: 'system' }
+      format.json { render json: @original_pictures }
+    end
+  end
+
+  def browse
+    @original_picture = OriginalPicture.find(params[:id])
+
+    respond_to do |format|
+      format.html { render layout: 'system' }
+      format.json { render json: @original_picture }
     end
   end
 
@@ -74,46 +94,38 @@ class OriginalPicturesController < ApplicationController
   # GET /original_pictures/new.json
   def new
     @original_picture = OriginalPicture.new
+    @original_picture.supply_default @artist
 
     respond_to do |format|
       format.html # new.html.erb
+      format.js
       format.json { render json: @original_picture }
     end
   end
 
   # GET /original_pictures/1/edit
   def edit
-    @original_picture = OriginalPicture.find(params[:id])
+    @original_picture = OriginalPicture.show(params[:id], @author)
+    respond_to do |format|
+      format.html
+      format.js
+    end
   end
 
   # POST /original_pictures
   # POST /original_pictures.json
   def create
-    unless @artist
-      respond_to do |format|
-        format.html { redirect_to @original_picture, notice: 'Failed! author does not artist.' }
-        format.json { render json: @original_picture.errors, status: :unprocessable_entity }
-      end
-      return
-    end
+    @picture_data = set_image params[:original_picture][:file]
     @original_picture = OriginalPicture.new
-    img = set_image params
-    @original_picture.artist_id = current_author.artist.id
+    @original_picture.supply_default @artist
 
     respond_to do |format|
-      OriginalPicture.transaction do
-        if @original_picture.save
-          if @original_picture.store(img)
-            format.html { redirect_to @original_picture, notice: 'Original picture was successfully created.' }
-            format.json { render json: @original_picture, status: :created, location: @original_picture }
-          else
-            format.html { redirect_to @original_picture, notice: 'Failed! Original picture was NOT created.' }
-            format.json { render json: @original_picture.errors, status: :unprocessable_entity }
-          end
-        else
-          format.html { render action: "new" }
-          format.json { render json: @original_picture.errors, status: :unprocessable_entity }
-        end
+      if @original_picture.store(@picture_data, @artist)
+        format.html { redirect_to @original_picture, notice: 'Original picture was successfully created.' }
+        format.json { render json: @original_picture, status: :created, location: @original_picture }
+      else
+        format.html { render action: "new" }
+        format.json { render json: @original_picture.errors, status: :unprocessable_entity }
       end
     end
   end
@@ -121,37 +133,17 @@ class OriginalPicturesController < ApplicationController
   # PUT /original_pictures/1
   # PUT /original_pictures/1.json
   def update
-    unless @artist
-      respond_to do |format|
-        format.html { redirect_to @original_picture, notice: 'Failed! author does not artist.' }
-        format.json { render json: @original_picture.errors, status: :unprocessable_entity }
-      end
-      return
-    end
-    @original_picture = OriginalPicture.find(params[:id])
-    unless @original_picture.own? current_author
-      respond_to do |format|
-        format.html { redirect_to @original_picture, notice: 'Failed! ' }
-        format.json { render json: @original_picture.errors, status: :unprocessable_entity }
-      end
-      return
-    end
-    img = set_image params
+    @picture_data = set_image params[:original_picture][:file]
+    @original_picture = OriginalPicture.edit(params[:id], @author)
+    @original_picture.supply_default @artist
 
     respond_to do |format|
-      OriginalPicture.transaction do
-        if @original_picture.save
-          if @original_picture.store(img)
-            format.html { redirect_to @original_picture, notice: 'Original picture was successfully updated.' }
-            format.json { head :ok }
-          else
-            format.html { redirect_to @original_picture, notice: 'Failed! Original picture was NOT created.' }
-            format.json { render json: @original_picture.errors, status: :unprocessable_entity }
-          end
-        else
-          format.html { render action: "edit" }
-          format.json { render json: @original_picture.errors, status: :unprocessable_entity }
-        end
+      if @original_picture.store(@picture_data, @artist)
+        format.html { redirect_to @original_picture, notice: 'Original picture was successfully created.' }
+        format.json { render json: @original_picture, status: :created, location: @original_picture }
+      else
+        format.html { render action: "edit" }
+        format.json { render json: @original_picture.errors, status: :unprocessable_entity }
       end
     end
   end
@@ -159,21 +151,7 @@ class OriginalPicturesController < ApplicationController
   # DELETE /original_pictures/1
   # DELETE /original_pictures/1.json
   def destroy
-    unless @artist
-      respond_to do |format|
-        format.html { redirect_to @original_picture, notice: 'Failed! author does not artist.' }
-        format.json { render json: @original_picture.errors, status: :unprocessable_entity }
-      end
-      return
-    end
-    @original_picture = OriginalPicture.find(params[:id])
-    unless @original_picture.own? current_author
-      respond_to do |format|
-        format.html { redirect_to @original_picture, notice: 'Failed! ' }
-        format.json { render json: @original_picture.errors, status: :unprocessable_entity }
-      end
-      return
-    end
+    @original_picture = OriginalPicture.edit(params[:id], @author)
     OriginalPicture.transaction do
       @original_picture.destroy
     end