about summary refs log tree commit diff stats
path: root/app/controllers/quotes_controller.rb
blob: 6fa03f22db7b73214476d23bf72465196fb9190d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
class QuotesController < ApplicationController
  protect_from_forgery with: :null_session, if: -> { request.format.json? or request.format.xml? }

  def index
    @quote = Quote.find(310)
    @qnumber = Quote.published.count
    @mnumber = Quote.pending.count
  end

  def latest
    @quotes = Quote.published.order(id: :desc).paginate(page: params[:page], per_page: 10)

    respond_to do |format|
      format.html { render :list }
      format.json { render :json => @quotes }
      format.xml { render :xml => @quotes }
      format.atom { render :atom => @quotes }
    end
  end

  def top
    @quotes = Quote.published.order(Arel.sql("(upvotes - downvotes) DESC")).paginate(page: params[:page], per_page: 10)

    respond_to do |format|
      format.html { render :list }
      format.json { render :json => @quotes }
      format.xml { render :xml => @quotes }
    end
  end

  def random
    picked = Quote.where(state: :published).ids.sample
    redirect_to quote_url(picked)
  end

  def tags
    @tags = Quote.published.tag_counts_on(:tags)
  end

  def tag
    @quotes = Quote.published.tagged_with(params[:id]).order(id: :desc).paginate(page: params[:page], per_page: 10)

    respond_to do |format|
      format.html { render :list }
      format.json { render :json => @quotes }
      format.xml { render :xml => @quotes }
    end
  end

  def stats
    @months = []
    0.upto(11) do |i|
      month = i.months.ago.month
      year = i.months.ago.year
      beginning = i.months.ago.beginning_of_month.beginning_of_day
      endtime = i.months.ago.end_of_month.end_of_day
      quotes = Quote.published.where("created_at >= :start_date AND created_at <= :end_date", { :start_date => beginning, :end_date => endtime }).all
      @months[11-i] = { :name => Date::MONTHNAMES[month], :number => quotes.count }
    end

    #@months2 = []
    #i = 0
    #while true
    #  month = i.months.ago.month
    #  year = i.months.ago.year
    #  beginning = i.months.ago.beginning_of_month.beginning_of_day
    #  endtime = i.months.ago.end_of_month.end_of_day
    #  quotes = Quote.where("created_at <= :end_date", { :end_date => endtime }).all
    #  @months2[i] = { :name => i.months.ago.strftime("%Y-%m"), :number => quotes.count }
    #
    #  break if month == 4 and year == 2008
    #
    #  i=i+1
    #end
    #
    #@months2.reverse!
    #
    #@upvotes = Vote.where(upvote: 1, votable_type: :quote).count
    #@downvotes = Vote.where(upvote: 0, votable_type: :quote).count

    hardcoded_aliases = {
      "hatkirby": "Hatkirby",
      "Gryphic": "Drifty",
      "DriftyBeyond": "Drifty",
      "Starla": "Hatkirby",
      "BleuM937": "Bluemonkey",
      "BlueM937": "Bluemonkey",
      "Drifty1": "Drifty",
      "Starla Insigna": "Hatkirby",
      "Starla Alice Insigna": "Hatkirby",
      "tamasys": "Tamasys",
      "Student 2": "Student",
      "Старла Эппрет": "Hatkirby",
      "Girl Without Slipper": "Hatkirby",
      "Actias": "Drifty",
      "Salaboy123": "Tamasys",
      "TaMACsys": "Tamasys",
      "RealityCheck": "Drifty",
      "Student 3": "Student",
      "toothpastecanyon": "ToothPasteCanyon",
      "eka-caesium": "eka_caesium",
    }

    person_count = {}
    Quote.published.each do |quote|
      person_in_quote = {}

      quote.content.split("\n").each do |line|
        check = line.chomp
        hi = /([\(\[][^\]\)]*[\]\)] )?([^:]*): /.match(check)
        if hi and hi[2] then
          person = hi[2]
          if hardcoded_aliases.has_key? person.intern
            person = hardcoded_aliases[person.intern]
          end
          unless person_in_quote.has_key? person
            person_count[person] ||= 0
            person_count[person] += 1
            person_in_quote[person] = 1
          end
        end
      end
    end

    @by_speaker = person_count.to_a.sort_by {|hi| hi[1]}.reverse.take(20)
  end

  def show
    @quote = Quote.published.find(params[:id])

    set_meta_tags(og: {
      title: "Quote \##{@quote.id}",
      type: "article",
      description: (@quote.content.length <= 300 ? @quote.content : @quote.content[0..299]),
      url: quote_url(@quote, host: "www.fourisland.com"),
      article: {
        published_time: @quote.created_at.iso8601,
        modified_time: @quote.updated_at.iso8601
      }
    })

    respond_to do |format|
      format.html
      format.json { render :json => @quote }
      format.xml { render :xml => @quote }
    end
  end

  def new
    @quote = Quote.new
  end

  def create
    @quote = Quote.new(quote_params)
    @quote.submitter = nil if @quote.submitter.empty?

    unless @quote.valid?
      flash.alert = "Error submitting quote."

      respond_to do |format|
        format.html { render :new }
        format.json { render json: { error: "Error submitting quote." }, status: :bad_request }
        format.xml { render xml: { error: "Error submitting quote." }, status: :bad_request }
      end

      return
    end

    if user_signed_in?
      @quote.state = :published
      @quote.save!

      flash[:notice] = "Thank you for submitting your quote!"
      respond_to do |format|
        format.html { redirect_to @quote }
        format.json { render json: @quote }
        format.xml { render xml: @quote }
      end
    else
      @quote.state = :pending
      @quote.save!

      # hacky little thing to reduce the number of emails I get
      unless @quote.submitter == "hatkirby"
        QuoteMailer.with(quote: @quote).pending_quote_email.deliver_later
      end

      flash[:notice] = "Your quote has been submitted and is pending moderation."
      respond_to do |format|
        format.html { redirect_to new_quote_url }
        format.json { render json: @quote }
        format.xml { render xml: @quote }
      end
    end
  end

  def upvote
    @quote = Quote.published.find(params[:id])

    respond_to do |format|
      if @quote.upvote! request.remote_ip
        format.html do
          flash[:notice] = "You have upvoted Quote \"#{@quote.id}\"."
          redirect_to @quote
        end
        format.js { render "voted" }
        format.xml { head :ok }
      else
        format.html do
          flash[:notice] = "You have already voted on Quote \"#{@quote.id}\"."
          redirect_to @quote
        end
        format.xml { render :xml => { :error => "Someone from your IP address has already voted on this quote."} }
      end
    end
  end

  def downvote
    @quote = Quote.published.find(params[:id])

    respond_to do |format|
      if @quote.downvote! request.remote_ip
        format.html do
          flash[:notice] = "You have downvoted Quote \"#{@quote.id}\"."
          redirect_to @quote
        end
        format.js { render "voted" }
        format.xml { head :ok }
      else
        format.html do
          flash[:notice] = "You have already voted on Quote \"#{@quote.id}\"."
          redirect_to @quote
        end
        format.xml { render :xml => { :error => "Someone from your IP address has already voted on this quote."} }
      end
    end
  end

  private

    def quote_params
      params.require(:quote).permit(:content, :notes, :submitter, :tag_list)
    end
end