OSDN Git Service

fix anything
[pettanr/pettanr.git] / app / models / resource_picture.rb
index dec37a0..f2052c2 100644 (file)
@@ -1,9 +1,9 @@
 #素材
-class ResourcePicture < ActiveRecord::Base
+class ResourcePicture < Peta::Content
+  load_manifest
   belongs_to :artist
   belongs_to :license
   belongs_to :picture
-  has_many :panel_pictures
   belongs_to :original_picture
   
   validates :ext, :presence => true, :length => {:maximum => 4}, :inclusion => {:in => ['png', 'jpeg', 'gif']}
@@ -18,15 +18,6 @@ class ResourcePicture < ActiveRecord::Base
   validates :classname, :presence => true, :length => {:maximum => 50}
   validates :picture_id, :presence => true, :numericality => true, :existence => {:both => false}
   
-  before_validation :valid_encode
-  
-  def valid_encode
-    ['artist_name', 'classname', 'credit', 'settings'].each do |a|
-      next if attributes[a] == nil
-      raise Pettanr::BadRequest unless attributes[a].valid_encoding?
-    end
-  end
-  
   def supply_default
   end
   
@@ -37,19 +28,8 @@ class ResourcePicture < ActiveRecord::Base
     self.attributes = attr
   end
   
-  def own? roles
-    roles = [roles] unless roles.respond_to?(:each)
-    ar = ResourcePicture.get_artist_from_roles roles
-    return false unless ar
-    self.artist_id == ar.id
-  end
-  
-  def visible? roles
-    if MagicNumber['run_mode'] == 0
-      return false unless guest_role_check(roles)
-    else
-      return false unless resource_reader_role_check(roles)
-    end
+  def visible? operators
+    return false unless super
     true
   end
   
@@ -74,7 +54,7 @@ class ResourcePicture < ActiveRecord::Base
   end
   
   def thumbnail(imager)
-    tw, th = ResourcePicture.fix_size_both(MagicNumber['thumbnail_width'], MagicNumber['thumbnail_height'], rimg.columns, rimg.rows)
+    tw, th = ResourcePicture.fix_size_both(Manifest.manifest.magic_numbers['thumbnail_width'], Manifest.manifest.magic_numbers['thumbnail_height'], rimg.columns, rimg.rows)
     ResourcePicture.resize(rimg.to_blob, tw, th).to_blob
   end
   
@@ -87,59 +67,26 @@ class ResourcePicture < ActiveRecord::Base
     {:src => self.url('full'), :width => self.width, :height => self.height}
   end
   
-  def self.default_page_size
-    125
-  end
-  
-  def self.max_page_size
-    100
+  def symbol_option
+    self.tmb_opt_img_tag
   end
   
-  def self.page prm = nil
-    page = prm.to_i
-    page = 1 if page < 1
-    page
+  def self.list_order
+    'resource_pictures.updated_at desc'
   end
   
-  def self.page_size prm = self.default_page_size
-    page_size = prm.to_i
-    page_size = self.max_page_size if page_size > self.max_page_size
-    page_size = self.default_page_size if page_size < 1
-    page_size
-  end
-  
-  def self.list page = 1, page_size = self.default_page_size
-    opt = {}
-    opt.merge!(self.list_opt)
-    opt.merge!({:limit => page_size, :offset => (page -1) * page_size}) if page_size > 0
-    opt.merge!({:order => 'updated_at desc'})
-    ResourcePicture.find(:all, opt)
+  def self.list_where
+    ''
   end
   
   def self.list_opt
-    {:include => {:license => {}, :artist => {}, :picture => {}} }
+    {:license => {}, :artist => {}, :picture => {} }
   end
   
   def self.list_json_opt
     {:include => {:license => {}, :artist => {}, :picture => {}} }
   end
   
-  def self.mylist ar, page = 1, page_size = Author.default_resource_picture_page_size
-    opt = {}
-    opt.merge!(ResourcePicture.list_opt)
-    opt.merge!({:limit => page_size, :offset => (page -1) * page_size}) if page_size > 0
-    opt.merge!({:conditions => ['resource_pictures.artist_id = ?', ar.id], :order => 'resource_pictures.updated_at desc'})
-    ResourcePicture.find(:all, opt)
-  end
-  
-  def self.show rid, roles
-    opt = {}
-    opt.merge!(self.show_opt)
-    r = ResourcePicture.find(rid, opt)
-    raise ActiveRecord::Forbidden unless r.visible?(roles)
-    r
-  end
-  
   def self.show_opt
     {:include => {:license => {}, :artist => {}, :picture => {}} }
   end
@@ -148,14 +95,6 @@ class ResourcePicture < ActiveRecord::Base
     {:include => {:license => {}, :artist => {}, :picture => {}} }
   end
   
-  def self.edit rid, ar
-    opt = {}
-    opt.merge!(self.show_opt)
-    r = ResourcePicture.find(rid, opt)
-    raise ActiveRecord::Forbidden unless r.own?(ar)
-    r
-  end
-  
   def new_picture imager
     pc = Picture.new
     pc.supply_default