class LettingsLogsController < LogsController include DuplicateLogsHelper rescue_from ActiveRecord::RecordNotFound, with: :render_not_found before_action :find_resource, only: %i[update show] before_action :session_filters, if: :current_user, only: %i[index email_csv download_csv bulk_uploads] before_action -> { filter_manager.serialize_filters_to_session }, if: :current_user, only: %i[index email_csv download_csv bulk_uploads] before_action :authenticate_scope!, only: %i[download_csv email_csv] before_action :extract_bulk_upload_from_session_filters, only: [:index] before_action :redirect_if_bulk_upload_resolved, only: [:index] def index all_logs = current_user.lettings_logs.visible.filter_by_years_or_nil(FormHandler.instance.years_of_available_lettings_forms) unpaginated_filtered_logs = filter_manager.filtered_logs(all_logs, search_term, session_filters) @delete_logs_path = delete_logs_lettings_logs_path(search: search_term) @pagy, @logs = pagy(unpaginated_filtered_logs) @searched = search_term.presence @total_count = all_logs.size @unresolved_count = all_logs.unresolved.assigned_to(current_user).count @filter_type = "lettings_logs" @duplicate_sets_count = !current_user.support? ? duplicate_sets_count(current_user, current_user.organisation) : 0 render "logs/index" end def create super { LettingsLog.new(log_params) } end def update if @log if @log.update(api_log_params) render json: @log, status: :ok else render json: { errors: @log.errors.messages }, status: :unprocessable_entity end else render_not_found_json("Log", params[:id]) end end def show respond_to do |format| # We don't have a dedicated non-editable show view resolve_logs! format.html { edit } format.json do if @log render json: @log, status: :ok else render_not_found_json("Log", params[:id]) end end end end def edit @log = current_user.lettings_logs.find(params[:id]) if @log.unresolved redirect_to(send(@log.form.unresolved_log_path, @log)) elsif @log.collection_closed_for_editing? redirect_to review_lettings_log_path(@log) else render("logs/edit", locals: { current_user:, bulk_upload_filter_applied: session_filters["bulk_upload_id"].present? }) end end def destroy @log = LettingsLog.visible.find(params[:id]) authorize @log @log.discard! redirect_to lettings_logs_path, notice: "Log #{@log.id} has been deleted." end def delete_confirmation @log = LettingsLog.visible.find(params[:lettings_log_id]) authorize @log, :destroy? render "logs/delete_confirmation" end def download_csv redirect_to filters_years_lettings_logs_path(search: search_term, codes_only: codes_only_export?) and return if session_filters["years"].blank? || session_filters["years"].count != 1 unpaginated_filtered_logs = filter_manager.filtered_logs(current_user.lettings_logs.visible, search_term, session_filters) render "download_csv", locals: { search_term:, count: unpaginated_filtered_logs.size, post_path: email_csv_lettings_logs_path, codes_only: codes_only_export?, session_filters:, filter_type: "lettings_logs", download_csv_back_link: lettings_logs_path } end def email_csv all_orgs = params["organisation_select"] == "all" EmailCsvJob.perform_later(current_user, search_term, session_filters, all_orgs, nil, codes_only_export?, "lettings", session_filters["years"].first.to_i) redirect_to csv_confirmation_lettings_logs_path end def csv_confirmation; end def update_logs respond_to do |format| format.html do impacted_logs = current_user.lettings_logs.unresolved.assigned_to(current_user) @pagy, @logs = pagy(impacted_logs) @total_count = impacted_logs.size render "logs/update_logs" end end end def bulk_uploads return render_not_authorized unless current_user.support? @filter_type = "lettings_bulk_uploads" if params[:organisation_id].present? && params[:clear_old_filters].present? redirect_to clear_filters_path(filter_type: @filter_type, organisation_id: params[:organisation_id]) and return end uploads = BulkUpload.lettings.where("created_at >= ?", 30.days.ago) unpaginated_filtered_uploads = filter_manager.filtered_uploads(uploads, search_term, filter_manager.session_filters) @pagy, @bulk_uploads = pagy(unpaginated_filtered_uploads) @search_term = search_term @total_count = uploads.size @searched = search_term.presence render "bulk_upload_shared/uploads" end def download_bulk_upload return render_not_authorized unless current_user.support? bulk_upload = BulkUpload.find(params[:id]) downloader = BulkUpload::Downloader.new(bulk_upload:) if Rails.env.development? downloader.call send_file downloader.path, filename: bulk_upload.filename, type: "text/csv" else presigned_url = downloader.presigned_url redirect_to presigned_url, allow_other_host: true end end def create_test_log return render_not_found unless FeatureToggle.create_test_logs_enabled? log = FactoryBot.create(:lettings_log, :completed, assigned_to: current_user, ppostcode_full: "SW1A 1AA") redirect_to lettings_log_path(log) end def create_setup_test_log return render_not_found unless FeatureToggle.create_test_logs_enabled? log = FactoryBot.create(:lettings_log, :setup_completed, assigned_to: current_user) redirect_to lettings_log_path(log) end private def session_filters filter_manager.session_filters end def filter_manager if request.path.include?("bulk-uploads") FilterManager.new(current_user:, session:, params:, filter_type: "lettings_bulk_uploads") else FilterManager.new(current_user:, session:, params:, filter_type: "lettings_logs") end end def authenticate_scope! head :unauthorized and return if codes_only_export? && !current_user.support? end def redirect_if_bulk_upload_resolved if @bulk_upload&.lettings? && @bulk_upload.lettings_logs.in_progress.count.zero? redirect_to resume_bulk_upload_lettings_result_path(@bulk_upload) end end def extract_bulk_upload_from_session_filters @bulk_upload = filter_manager.bulk_upload end def permitted_log_params params.require(:lettings_log).permit(LettingsLog.editable_fields) end def find_resource @log = LettingsLog.visible.find_by(id: params[:id]) end def post_create_redirect_url(log) lettings_log_url(log) end def resolve_logs! if @log&.unresolved && @log.location.present? && @log.scheme.present? && @log&.resolve! unresolved_logs_count_for_user = current_user.lettings_logs.unresolved.assigned_to(current_user).count flash.now[:notice] = helpers.flash_notice_for_resolved_logs(unresolved_logs_count_for_user) end end end