cms_controller.rb 1.04 KB
require_dependency 'cms_controller'

class CmsController

protect_if :only => :edit_visibility do |c, user, profile|
  article = c.environment.articles.find_by_id(c.params[:article_id])
  (user && !article.nil? && (user.is_member_of? article.profile) &&
  article.parent.allow_privacy_edition && article.folder? &&
  (article.author == user || user.has_permission?('view_private_content', profile)))
end

def edit_visibility
  unless params[:article_id].blank?
    folder = profile.environment.articles.find_by_id(params[:article_id])
    @back_to = url_for(folder.parent.url)
    unless params[:article].blank?
      folder.published = params[:article][:published]
      unless params[:q].nil?
        folder.article_privacy_exceptions = params[:q].split(/,/).map{|n| environment.people.find n.to_i}
      end
      folder.save!
      redirect_to @back_to
    end    
  end
 end

def self.add_as_exception?(action)
    actions = "edit_visibility, search_article_privacy_exceptions"
    if actions.include? action
      true
    else
      false
    end
  end

end