# Groups life cycle class OrgasController < ApplicationController has_scope :region, :tag has_scope :near, type: :hash, using: %i[location distance] before_action :set_orga, except: %i[index new create] before_action :set_mailer_host before_action :authenticate_user!, except: %i[index new create show], unless: :check_secret def index @unfiltered_orgas = apply_scopes(Orga.moderated) @search = @unfiltered_orgas.search params[:q] @search.sorts = 'updated_at desc' if @search.sorts.empty? @orgas = @search.result.page params[:page] end # GET /orgas/new def new @orga = Orga.new region_id: session[:region] end # POST /orgas # POST /orgas.json def create @orga = Orga.new orga_params respond_to do |format| if @orga.save format.html { redirect_to @orga, notice: t('.ok') } # 201 means :created format.json { render action: 'show', status: 201, location: @orga } else format.html { render action: 'new' } format.json { render json: @orga.errors, status: :unprocessable_entity } end end end def show @events_future = Event.moderated.future.tag @orga.name_as_tag @events_past = Event.moderated.past.tag @orga.name_as_tag end # PATCH/PUT /orgas/1 # PATCH/PUT /orgas/1.json def update respond_to do |format| if @orga.update orga_params format.html { redirect_to @orga, notice: t('.ok') } format.json { head :no_content } else format.html { render action: 'edit' } format.json { render json: @orga.errors, status: :unprocessable_entity } end end end # PATCH/PUT /accept/1 # PATCH/PUT /accept/1.json def accept @orga.update moderated: true respond_to do |format| format.html { redirect_to :moderations, notice: t('.ok') } format.json { head :no_content } end end # DELETE /orgas/1 # DELETE /orgas/1.json def destroy @orga.destroy respond_to do |format| format.html { redirect_to :moderations, notice: t('.ok') } format.json { head :no_content } end end private # Use callbacks to share common setup or constraints between actions. def set_orga @orga = Orga.find params[:id] end # Never trust parameters from the scary internet, only allow the white list # through def orga_params params.require(:orga) .permit :lock_version, :kind_id, :name, :description, :place_name, :address, :city, :department, :region_id, :url, :diaspora, :feed, :contact, :submitter, :tag_list, :active end # Check that you can only edit an existing event if you know its secret def check_secret !%w[validate refuse].include?(action_name) && (!@orga.secret || @orga.secret == params[:secret]) end end