X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=app%2Fmodels%2Fstory.rb;h=b655b67b1beb23be6c8071b9bc30a98c2e8d0176;hb=eb397c27a98c59c856b91a5b09d1316b1135a15c;hp=fc7e8b71cf886e8fccdb92b7a4a119b475807aa3;hpb=b7f9906380e4b62096d776fe9ad15ba3c4fd4ba4;p=pettanr%2Fpettanr.git diff --git a/app/models/story.rb b/app/models/story.rb index fc7e8b71..b655b67b 100644 --- a/app/models/story.rb +++ b/app/models/story.rb @@ -1,15 +1,26 @@ #ストーリー class Story < ActiveRecord::Base belongs_to :author - belongs_to :panel + has_many :story_sheets belongs_to :comic - validates :comic_id, :presence => true, :numericality => true, :existence => true - validates :panel_id, :presence => true, :numericality => true, :existence => true - validates :author_id, :presence => true, :numericality => true, :existence => true + validates :comic_id, :presence => true, :numericality => true, :existence => {:both => false} + validates :title, :presence => true, :length => {:maximum => 100} + validates :visible, :presence => true, :numericality => true, :inclusion => {:in => 0..1} + validates :author_id, :presence => true, :numericality => true, :existence => {:both => false} validates :t, :presence => true, :numericality => {:greater_than_or_equal_to => 0} + before_validation :valid_encode + + def valid_encode + ['title', 'description'].each do |a| + next if attributes[a] == nil + raise Pettanr::BadRequest unless attributes[a].valid_encoding? + end + end def supply_default + self.comic_id = nil + self.visible = 0 if self.visible.blank? self.t = nil end @@ -18,17 +29,136 @@ class Story < ActiveRecord::Base self.author_id = au.id end - def own? author - return false unless author - self.author_id == author.id + def own? roles + roles = [roles] unless roles.respond_to?(:each) + au = Story.get_author_from_roles roles + return false unless au + self.author_id == au.id + end + + def visible? roles + if MagicNumber['run_mode'] == 0 + return false unless guest_role_check(roles) + else + return false unless reader_role_check(roles) + end + return true if self.own?(roles) + self.visible > 0 + end + + def self.default_page_size + 25 + end + + def self.max_page_size + 100 + end + + def self.default_panel_size + 30 + end + + def self.max_panel_size + 200 + end + + def self.page prm = nil + page = prm.to_i + page = 1 if page < 1 + page + 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_where + 'stories.visible > 0' + end + + def self.mylist_where au + ['stories.author_id = ?', au.id] + end + + def self.himlist_where au + ['stories.author_id = ? and stories.visible > 0', au.id] + end + + def self.list page = 1, page_size = self.default_page_size + Story.where(self.list_where()).includes(Story.list_opt).order('stories.updated_at desc').offset((page -1) * page_size).limit(page_size) + end + + def self.mylist au, page = 1, page_size = Author.default_story_page_size + Story.where(self.mylist_where(au)).includes(Story.list_opt).order('stories.updated_at desc').offset((page -1) * page_size).limit(page_size) + end + + def self.himlist au, page = 1, page_size = Author.default_story_page_size + Story.where(self.himlist_where(au)).includes(Story.list_opt).order('stories.updated_at desc').offset((page -1) * page_size).limit(page_size) + end + + def self.list_paginate page = 1, page_size = self.default_page_size + Kaminari.paginate_array(Array.new(Story.where(self.list_where()).count, nil)).page(page).per(page_size) + end + + def self.mylist_paginate au, page = 1, page_size = Author.default_story_page_size + Kaminari.paginate_array(Array.new(Story.where(self.mylist_where(au)).count, nil)).page(page).per(page_size) + end + + def self.himlist_paginate au, page = 1, page_size = Author.default_story_page_size + Kaminari.paginate_array(Array.new(Story.where(self.himlist_where(au)).count, nil)).page(page).per(page_size) + end + + def self.list_opt + {:author => {}, :story_sheets => {:sheet => {}, :author => {}} } + end + + def self.list_json_opt + {:include => {:author => {}, :story_sheets => {:include => {:sheet => {}, :author => {}}} }} + end + + def self.show sid, roles + opt = {} + opt.merge!(Story.show_opt) + res = Story.find(sid, opt) + raise ActiveRecord::Forbidden unless res.visible?(roles) + res end def self.edit sid, au - res = Story.find sid + opt = {} + opt.merge!(Story.show_opt) + res = Story.find(sid, opt) raise ActiveRecord::Forbidden unless res.own?(au) res end + def self.show_opt + {:include => {:author => {}, :story_sheets => {:sheet => {}, :author => {}} }} + end + + def self.show_json_opt + {:include => {:author => {}, :story_sheets => {:include => {:sheet => {}, :author => {}}} }} + end + + def self.visible_count + Story.count 'visible > 0' + end + + def destroy_with_story_sheet + res = false + Story.transaction do + self.story_sheets.each do |story_sheet| + raise ActiveRecord::Rollback unless story_sheet.destroy + end + raise ActiveRecord::Rollback unless self.destroy + res = true + end + res + end + def self.new_t comic_id r = Story.max_t(comic_id) r.blank? ? 0 : r.to_i + 1 @@ -100,16 +230,20 @@ class Story < ActiveRecord::Base end def allow? - c = self.comic - pl = self.panel - c and c.own?(self.author) and pl and pl.usable?(self.author) + return nil if self.comic_id == nil + self.comic.own?(self.author) end def store old_t = nil res = false - raise ActiveRecord::Forbidden unless self.allow? Story.transaction do - self.rotate old_t + case self.allow? + when true + self.rotate old_t + when false + raise ActiveRecord::Forbidden + else + end res = self.save raise ActiveRecord::Rollback unless res res = Story.validate_t(self) @@ -122,98 +256,13 @@ class Story < ActiveRecord::Base end def destroy_and_shorten + res = false Story.transaction do Story.update_all('t = t - 1', ['comic_id = ? and (t > ?)', self.comic_id, self.t]) - raise ActiveRecord::Rollback unless self.destroy + raise ActiveRecord::Rollback unless self.destroy_with_story_sheet + res = true end - end - - def self.default_page_size - 25 - end - - def self.max_page_size - 100 - end - - def self.page prm = nil - page = prm.to_i - page = 1 if page < 1 - page - 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.default_panel_size - 30 - end - - def self.max_panel_size - 200 - end - - def self.offset cnt, prm = nil - offset = prm.to_i - offset = cnt - 1 if offset >= cnt - offset = cnt - offset.abs if offset < 0 - offset = 0 if offset < 0 - offset - end - - def self.panel_count cnt, prm = self.default_panel_size - count = prm.to_i - count = self.max_panel_size if count > self.max_panel_size - count = self.default_panel_size if count < 1 - count - end - - def self.list comic, author, offset = 0, limit = Story.default_panel_size - opt = self.list_opt - opt.merge!({:conditions => ['stories.comic_id = ? and panels.publish > 0', comic.id], :order => 'stories.t', :offset => offset, :limit => limit}) - Story.find(:all, opt) - end - - def self.list_opt - {:include => { - :author => {}, - :comic => { - :author => {} - }, - :panel => { - :author => {}, - :panel_pictures => {:picture => {:artist => {}, :license => {}}}, - :speech_balloons =>{:balloons => {}, :speeches => {}} - } - }} - end - - def self.list_json_opt - {:include => { - :author => {}, - :comic => { - :author => {} - }, - :panel => { - :author => {}, - :panel_pictures => {:picture => {:artist => {}, :license => {}}}, - :speech_balloons =>{:balloons => {}, :speeches => {}} - } - }} - end - - def self.mylist au, opt = {}, page = 1, story_page_size = Author.default_story_page_size - opt.merge!(self.list_opt) unless opt[:include] - opt.merge!({:conditions => ['stories.author_id = ?', au.id], :order => 'stories.updated_at desc', :limit => page_size, :offset => (page -1) * story_page_size}) - Story.find(:all, opt) - end - - def to_json_list - self.to_json( :include => {:author => {}, :panels => {:methods => :panel_element}}) + res end