# frozen_string_literal: true class TeamsController < ApplicationController include ProjectsHelper attr_reader :current_folder helper_method :current_folder before_action :load_vars, only: %i(sidebar export_projects export_projects_modal) before_action :load_current_folder, only: :sidebar before_action :check_read_permissions before_action :check_export_projects_permissions, only: %i(export_projects_modal export_projects) def sidebar respond_to do |format| format.json do render json: { html: render_to_string( partial: 'shared/sidebar/projects.html.erb', locals: { team: current_team, sort: params[:sort] } ) } end end end def export_projects if current_user.has_available_exports? current_user.increase_daily_exports_counter! generate_export_projects_zip Activities::CreateActivityService .call(activity_type: :export_projects, owner: current_user, subject: @team, team: @team, message_items: { team: @team.id, projects: @exp_projects.map(&:name).join(', ') }) render json: { flash: t('projects.export_projects.success_flash') }, status: :ok end end def export_projects_modal if @exp_projects.present? if current_user.has_available_exports? render json: { html: render_to_string( partial: 'projects/export/modal.html.erb', locals: { num_projects: @exp_projects.size, limit: TeamZipExport.exports_limit, num_of_requests_left: current_user.exports_left - 1 } ), title: t('projects.export_projects.modal_title') } else render json: { html: render_to_string( partial: 'projects/export/error.html.erb', locals: { limit: TeamZipExport.exports_limit } ), title: t('projects.export_projects.error_title'), status: 'error' } end else render json: { flash: I18n.t('projects.export_projects.zero_projects_flash') }, status: :unprocessable_entity end end def routing_error(error = 'Routing error', status = :not_found, exception=nil) redirect_to root_path end private def load_vars @team = current_user.teams.find_by(id: params[:id]) render_404 unless @team end def export_projects_params params.permit(:id, project_ids: [], project_folder_ids: []) end def check_read_permissions render_403 unless can_read_team?(@team) end def load_current_folder if current_team && params[:project_folder_id].present? @current_folder = current_team.project_folders.find_by(id: params[:project_folder_id]) end end def check_export_projects_permissions @exp_projects = [] if export_projects_params[:project_ids] @exp_projects = @team.projects.where(id: export_projects_params[:project_ids]).to_a end if export_projects_params[:project_folder_ids] folders = @team.project_folders.where(id: export_projects_params[:project_folder_ids]) folders.each do |folder| @exp_projects += folder.inner_projects.visible_to(current_user, @team) end end @exp_projects.each do |project| return render_403 unless can_export_project?(current_user, project) end end def generate_export_projects_zip ids = @exp_projects.index_by(&:id) options = { team: @team } zip = TeamZipExport.create(user: current_user) zip.generate_exportable_zip( current_user, ids, :teams, options ) ids end end