2 class ResourcePicture < ActiveRecord::Base
6 has_many :panel_pictures
7 belongs_to :original_picture
9 validates :ext, :presence => true, :length => {:maximum => 4}, :inclusion => {:in => ['png', 'jpeg', 'gif']}
10 validates :width, :presence => true, :numericality => true, :natural_number => true
11 validates :height, :presence => true, :numericality => true, :natural_number => true
12 validates :filesize, :presence => true, :numericality => {:greater_than => 0, :less_than_or_equal_to => 2000000}, :natural_number => true
13 validates :md5, :presence => true, :length => {:minimum => 32, :maximum => 32}
14 validates :artist_id, :presence => true, :numericality => true, :existence => {:both => false}
15 validates :license_id, :presence => true, :numericality => true, :existence => {:both => false}
16 validates :original_picture_id, :presence => true, :numericality => true, :existence => {:both => false}
17 validates :artist_name, :presence => true
18 validates :classname, :presence => true, :length => {:maximum => 50}
19 validates :picture_id, :presence => true, :numericality => true, :existence => {:both => false}
21 before_validation :valid_encode
24 ['artist_name', 'classname', 'credit', 'settings'].each do |a|
25 next if attributes[a] == nil
26 raise Pettanr::BadRequest unless attributes[a].valid_encoding?
34 attr = {:width => op.width, :height => op.height, :ext => op.ext, :filesize => op.filesize,
35 :original_picture_id => op.id, :artist_id => op.artist_id, :md5 => op.md5
37 self.attributes = attr
41 roles = [roles] unless roles.respond_to?(:each)
42 ar = ResourcePicture.get_artist_from_roles roles
43 return false unless ar
44 self.artist_id == ar.id
48 if MagicNumber['run_mode'] == 0
49 return false unless guest_role_check(roles)
51 return false unless resource_reader_role_check(roles)
57 "#{self.id}.#{self.ext}"
69 '/resource_pictures/' + (subdir.to_s.empty? ? '' : subdir.to_s + '/' ) + filename
73 self.ext == 'png' and self.flag_gif_convert >= 0
77 tw, th = ResourcePicture.fix_size_both(MagicNumber['thumbnail_width'], MagicNumber['thumbnail_height'], rimg.columns, rimg.rows)
78 ResourcePicture.resize(rimg.to_blob, tw, th).to_blob
82 tw, th = PettanImager.thumbnail_size(self.width, self.height)
83 {:src => self.url, :width => tw, :height => th}
87 {:src => self.url('full'), :width => self.width, :height => self.height}
90 def self.default_page_size
94 def self.max_page_size
98 def self.page prm = nil
104 def self.page_size prm = self.default_page_size
106 page_size = self.max_page_size if page_size > self.max_page_size
107 page_size = self.default_page_size if page_size < 1
111 def self.mylist_where ar
112 ['resource_pictures.artist_id = ?', ar.id]
115 def self.himlist_where ar
116 ['resource_pictures.artist_id = ?', ar.id]
119 def self.list page = 1, page_size = self.default_page_size
120 ResourcePicture.includes(ResourcePicture.list_opt).order('resource_pictures.updated_at desc').offset((page -1) * page_size).limit(page_size)
123 def self.mylist ar, page = 1, page_size = Author.default_resource_picture_page_size
124 ResourcePicture.where(self.mylist_where(ar)).includes(ResourcePicture.list_opt).order('resource_pictures.updated_at desc').offset((page -1) * page_size).limit(page_size)
127 def self.himlist ar, page = 1, page_size = Author.default_resource_picture_page_size
128 ResourcePicture.where(self.himlist_where(ar)).includes(ResourcePicture.list_opt).order('resource_pictures.updated_at desc').offset((page -1) * page_size).limit(page_size)
131 def self.list_paginate page = 1, page_size = self.default_page_size
132 Kaminari.paginate_array(Array.new(ResourcePicture.count, nil)).page(page).per(page_size)
135 def self.mylist_paginate ar, page = 1, page_size = Author.default_resource_picture_page_size
136 Kaminari.paginate_array(Array.new(ResourcePicture.where(self.mylist_where(ar)).count, nil)).page(page).per(page_size)
139 def self.himlist_paginate ar, page = 1, page_size = Author.default_resource_picture_page_size
140 Kaminari.paginate_array(Array.new(ResourcePicture.where(self.himlist_where(ar)).count, nil)).page(page).per(page_size)
144 {:license => {}, :artist => {}, :picture => {} }
147 def self.list_json_opt
148 {:include => {:license => {}, :artist => {}, :picture => {}} }
151 def self.show rid, roles
153 opt.merge!(self.show_opt)
154 r = ResourcePicture.find(rid, opt)
155 raise ActiveRecord::Forbidden unless r.visible?(roles)
160 {:include => {:license => {}, :artist => {}, :picture => {}} }
163 def self.show_json_opt
164 {:include => {:license => {}, :artist => {}, :picture => {}} }
167 def self.edit rid, ar
169 opt.merge!(self.show_opt)
170 r = ResourcePicture.find(rid, opt)
171 raise ActiveRecord::Forbidden unless r.own?(ar)
175 def new_picture imager
181 self.errors.add :base, Picture.model_name.human + I18n.t('errors.not_create')
186 return false unless imager
188 self.overwrite self.original_picture
189 ResourcePicture.transaction do
190 self.original_picture.published_at = Time.now
191 self.original_picture.stopped_at = nil
192 raise ActiveRecord::Rollback unless self.original_picture.save
193 pc = self.new_picture imager
195 self.picture_id = pc.id
197 res = self.store_picture_with_gif(imager)
201 raise ActiveRecord::Rollback unless res
206 def store_picture_with_gif(imager)
207 if res = self.store_picture(imager, self.filename)
209 if gifimager = imager.to_gif
210 if res = self.store_picture(gifimager, self.gifname)
212 self.errors.add :base, I18n.t('picture_io.error')
215 self.errors.add :base, I18n.t('errors.not_convert')
220 self.errors.add :base, I18n.t('picture_io.error')
225 def store_picture(imager, fn)
227 thumbnail_imager = self.flag_thumbnail >= 0 ? imager.to_thumbnail : imager
228 return false unless thumbnail_imager
230 PictureIO.resource_picture_io.put(thumbnail_imager.binary, fn)
231 PictureIO.resource_picture_io.put(imager.binary, fn, 'full')
233 rescue PictureIO::Error
239 def restore(subdir = nil)
240 PictureIO.resource_picture_io.get self.filename, subdir
245 ResourcePicture.transaction do
246 self.original_picture.published_at = nil
247 self.original_picture.stopped_at = Time.now
248 raise ActiveRecord::Rollback unless self.original_picture.save
250 PictureIO.resource_picture_io.delete(self.filename) if PictureIO.resource_picture_io.exist?(self.filename)
251 PictureIO.resource_picture_io.delete(self.filename, 'full') if PictureIO.resource_picture_io.exist?(self.filename, 'full')
252 rescue PictureIO::Error
254 raise ActiveRecord::Rollback
257 raise ActiveRecord::Rollback unless res
262 def self.visible_count
263 ResourcePicture.count
267 Base64.encode64(self.restore 'full')
271 "#{self.classname.tableize}/attributes/credit"
274 def full_credit_template
275 "#{self.classname.tableize}/attributes/full_credit"
280 @credit_data = JSON.parse(self.credit) unless @credit_data
288 @flags = JSON.parse(self.settings) unless @flags
299 @flag_open = flags["open"] unless @flag_open
304 @flag_commercial = flags["commercial"] unless @flag_commercial
309 @flag_official = flags["official"] unless @flag_official
314 @flag_attribution = flags["attribution"] unless @flag_attribution
319 @flag_derive = flags["derive"] unless @flag_derive
324 @flag_thumbnail = flags["thumbnail"] unless @flag_thumbnail
329 @flag_gif_convert = flags["gif_convert"] unless @flag_gif_convert
334 @flag_reverse = flags["reverse"] unless @flag_reverse
339 @flag_resize = flags["resize"] unless @flag_resize
344 @flag_sync_vh = flags["sync_vh"] unless @flag_sync_vh
349 @flag_overlap = flags["overlap"] unless @flag_overlap