# app/controllers/admin_request_controller.rb: # Controller for viewing FOI requests from the admin interface. # # Copyright (c) 2007 UK Citizens Online Democracy. All rights reserved. # Email: francis@mysociety.org; WWW: http://www.mysociety.org/ # # $Id: admin_request_controller.rb,v 1.27 2008-11-04 00:13:25 francis Exp $ class AdminRequestController < ApplicationController layout "admin" before_filter :assign_http_auth_user def index list render :action => 'list' end def list @query = params[:query] @info_requests = InfoRequest.paginate :order => "created_at desc", :page => params[:page], :per_page => 100, :conditions => @query.nil? ? nil : ["lower(title) like lower('%'||?||'%')", @query] end def show @info_request = InfoRequest.find(params[:id]) end def resend @outgoing_message = OutgoingMessage.find(params[:outgoing_message_id]) @outgoing_message.resend_message flash[:notice] = "Outgoing message resent" redirect_to request_admin_url(@outgoing_message.info_request) end def edit @info_request = InfoRequest.find(params[:id]) end def update @info_request = InfoRequest.find(params[:id]) old_title = @info_request.title old_prominence = @info_request.prominence old_described_state = @info_request.described_state old_awaiting_description = @info_request.awaiting_description old_stop_new_responses = @info_request.stop_new_responses @info_request.title = params[:info_request][:title] @info_request.prominence = params[:info_request][:prominence] if @info_request.described_state != params[:info_request][:described_state] @info_request.set_described_state(params[:info_request][:described_state]) end @info_request.awaiting_description = params[:info_request][:awaiting_description] == "true" ? true : false @info_request.stop_new_responses = params[:info_request][:stop_new_responses] == "true" ? true : false if @info_request.valid? @info_request.save! @info_request.log_event("edit", { :editor => admin_http_auth_user(), :old_title => old_title, :title => @info_request.title, :old_prominence => old_prominence, :prominence => @info_request.prominence, :old_described_state => old_described_state, :described_state => @info_request.described_state, :old_awaiting_description => old_awaiting_description, :awaiting_description => @info_request.awaiting_description, :old_stop_new_responses => old_stop_new_responses, :stop_new_responses => @info_request.stop_new_responses }) flash[:notice] = 'Request successfully updated.' redirect_to request_admin_url(@info_request) else render :action => 'edit' end end def fully_destroy @info_request = InfoRequest.find(params[:id]) user = @info_request.user url_title = @info_request.url_title @info_request.fully_destroy flash[:notice] = "Request #{url_title} has been completely destroyed. Email of user who made request: " + user.email redirect_to admin_url('request/list') end def edit_outgoing @outgoing_message = OutgoingMessage.find(params[:id]) end def update_outgoing @outgoing_message = OutgoingMessage.find(params[:id]) old_body = @outgoing_message.body if @outgoing_message.update_attributes(params[:outgoing_message]) @outgoing_message.info_request.log_event("edit_outgoing", { :outgoing_message_id => @outgoing_message.id, :editor => admin_http_auth_user(), :old_body => old_body, :body => @outgoing_message.body }) flash[:notice] = 'Outgoing message successfully updated.' redirect_to request_admin_url(@outgoing_message.info_request) else render :action => 'edit_outgoing' end end def edit_comment @comment = Comment.find(params[:id]) end def update_comment @comment = Comment.find(params[:id]) old_body = @comment.body old_visible = @comment.visible @comment.visible = params[:comment][:visible] == "true" ? true : false if @comment.update_attributes(params[:comment]) @comment.info_request.log_event("edit_comment", { :comment_if => @comment.id, :editor => admin_http_auth_user(), :old_body => old_body, :body => @comment.body, :old_visible => old_visible, :visible => @comment.visible, }) flash[:notice] = 'Comment successfully updated.' redirect_to request_admin_url(@comment.info_request) else render :action => 'edit_comment' end end def destroy_incoming @incoming_message = IncomingMessage.find(params[:incoming_message_id]) @info_request = @incoming_message.info_request incoming_message_id = @incoming_message.id @incoming_message.fully_destroy @incoming_message.info_request.log_event("destroy_incoming", { :editor => admin_http_auth_user(), :deleted_incoming_message_id => incoming_message_id }) flash[:notice] = 'Incoming message successfully destroyed.' redirect_to request_admin_url(@info_request) end def redeliver_incoming incoming_message = IncomingMessage.find(params[:redeliver_incoming_message_id]) if params[:url_title].match(/^[0-9]+$/) destination_request = InfoRequest.find(params[:url_title].to_i) else destination_request = InfoRequest.find_by_url_title(params[:url_title]) end if destination_request.nil? flash[:error] = "Failed to find destination request '" + params[:url_title] + "'" redirect_to request_admin_url(incoming_message.info_request) end raw_email_data = incoming_message.raw_email.data mail = TMail::Mail.parse(raw_email_data) mail.base64_decode destination_request.receive(mail, raw_email_data) incoming_message_id = incoming_message.id incoming_message.fully_destroy incoming_message.info_request.log_event("redeliver_incoming", { :editor => admin_http_auth_user(), :destination_request => destination_request.id, :deleted_incoming_message_id => incoming_message_id }) flash[:notice] = "Message has been moved to this request" redirect_to request_admin_url(destination_request) end def generate_upload_url info_request = InfoRequest.find(params[:id]) if params[:incoming_message_id] incoming_message = IncomingMessage.find(params[:incoming_message_id]) email = incoming_message.mail.from_addrs[0].address name = incoming_message.safe_mail_from || info_request.public_body.name else email = info_request.public_body.request_email name = info_request.public_body.name end user = User.find_user_by_email(email) if not user user = User.new(:name => name, :email => email, :password => PostRedirect.generate_random_token) user.save! end if !info_request.public_body.is_foi_officer?(user) flash[:notice] = user.email + " is not an email at the domain @" + info_request.public_body.foi_officer_domain_required + ", so won't be able to upload." redirect_to request_admin_url(info_request) return end # Bejeeps, look, sometimes a URL is something that belongs in a model, jesus. # XXX hammer this square peg into the round MVC hole - should be calling main_url(upload_response_url()) post_redirect = PostRedirect.new( :uri => upload_response_url(:url_title => info_request.url_title), :user_id => user.id) post_redirect.save! url = confirm_url(:email_token => post_redirect.email_token) flash[:notice] = 'Send "' + name + '" <' + email + '> this URL: ' + url + " - it will log them in and let them upload a response to this request." redirect_to request_admin_url(info_request) end def show_raw_email @raw_email = RawEmail.find(params[:id]) # For the holding pen, use domain of email to try and guess which public body it # is associated with, so we can display that. @holding_pen = false if (@raw_email.incoming_message.info_request == InfoRequest.holding_pen_request && @raw_email.incoming_message.mail.from_addrs.size > 0) @holding_pen = true email = @raw_email.incoming_message.mail.from_addrs[0].spec domain = email domain =~ /@(.*)/ domain = $1 @public_bodies = PublicBody.find(:all, :order => "name", :conditions => [ "lower(request_email) like lower('%'||?||'%')", domain ]) end end def download_raw_email @raw_email = RawEmail.find(params[:id]) response.content_type = 'message/rfc822' render :text => @raw_email.data end private end