OSDN Git Service

merge v04
[pettanr/pettanr.git] / app / controllers / original_pictures_controller.rb
index efcd36e..c5bb41a 100644 (file)
@@ -1,34 +1,17 @@
 class OriginalPicturesController < ApplicationController
+  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
-    img
   end
   
   def authenticate_artist
@@ -64,23 +47,19 @@ class OriginalPicturesController < ApplicationController
   # GET /original_pictures/1
   # GET /original_pictures/1.json
   def show
-    @original_picture = OriginalPicture.show(params[:id])
-#    if params[:subdir] == 'refresh'
-#      refresh 
-#      return
-#    end
-
+    @original_picture = OriginalPicture.show(params[:id], @artist)
+    
     respond_to do |format|
-      if @original_picture.own?(@author)
-        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}
-      else
-        raise ActiveRecord::Forbidden
-      end
+      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 {
+        #ライセンス付与のために原画ライセンスグループ作成準備
+        @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
 
@@ -126,8 +105,7 @@ class OriginalPicturesController < ApplicationController
 
   # GET /original_pictures/1/edit
   def edit
-    @original_picture = OriginalPicture.show(params[:id])
-    raise ActiveRecord::Forbidden unless @original_picture.own?(@author)
+    @original_picture = OriginalPicture.show(params[:id], @author)
     respond_to do |format|
       format.html
       format.js
@@ -137,25 +115,17 @@ class OriginalPicturesController < ApplicationController
   # POST /original_pictures
   # POST /original_pictures.json
   def create
+    @picture_data = set_image params[:original_picture][:file]
     @original_picture = OriginalPicture.new
-    img = set_image params
-    @original_picture.artist_id = @author.artist.id
-    @original_picture.license_id = @author.artist.default_license_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
@@ -163,24 +133,17 @@ class OriginalPicturesController < ApplicationController
   # PUT /original_pictures/1
   # PUT /original_pictures/1.json
   def update
-    @original_picture = OriginalPicture.show(params[:id])
-    raise ActiveRecord::Forbidden unless @original_picture.own?(@author)
-    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
@@ -188,8 +151,7 @@ class OriginalPicturesController < ApplicationController
   # DELETE /original_pictures/1
   # DELETE /original_pictures/1.json
   def destroy
-    @original_picture = OriginalPicture.find(params[:id])
-    raise ActiveRecord::Forbidden unless @original_picture.own?(@author)
+    @original_picture = OriginalPicture.edit(params[:id], @author)
     OriginalPicture.transaction do
       @original_picture.destroy
     end