Mercurial > zeropaste
annotate app/models/paste.rb @ 377:4e6afc8140fb
Use Time.zone as per rubocop recommendation.
| author | nanaya <me@myconan.net> |
|---|---|
| date | Sat, 06 Jun 2015 22:35:21 +0900 |
| parents | 02903dc8214d |
| children | 2ad092e60975 |
| rev | line source |
|---|---|
| 2 | 1 class Paste < ActiveRecord::Base |
|
210
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
2 attr_accessor :is_private |
|
70
8f0fb869e770
Limit pastes to 100/hour per IP address.
Edho Arief <edho@myconan.net>
parents:
51
diff
changeset
|
3 before_validation :paste_limit |
|
22
032686a0c995
Added newline converter, integrity fixups.
Edho Arief <edho@myconan.net>
parents:
2
diff
changeset
|
4 before_validation :convert_newlines |
| 2 | 5 before_validation :set_paste_hash |
|
176
a9dba6a3008b
Initial work to add paste deletion.
Edho Arief <edho@myconan.net>
parents:
71
diff
changeset
|
6 before_validation :set_paste_key |
|
210
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
7 before_validation :set_paste_secret |
|
176
a9dba6a3008b
Initial work to add paste deletion.
Edho Arief <edho@myconan.net>
parents:
71
diff
changeset
|
8 validates :paste, :paste_hash, :key, :ip, :presence => true |
|
267
0bf1d6f75baa
Accidentally limited pastes to 0 characters.
edogawaconan <me@myconan.net>
parents:
265
diff
changeset
|
9 validates :paste, :length => { :maximum => 1_000_000 } |
| 2 | 10 |
|
210
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
11 def to_param |
|
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
12 path |
|
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
13 end |
|
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
14 |
|
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
15 def self.safe_find(raw_id) |
| 247 | 16 id, secret = raw_id.to_s.split("-") |
|
210
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
17 return unless id.to_i.to_s == id |
|
229
388504e43bcf
Properly return 404 when requesting invalid paste.
Edho Arief <edho@myconan.net>
parents:
210
diff
changeset
|
18 begin |
| 330 | 19 where(:secret => secret).find(id) |
|
229
388504e43bcf
Properly return 404 when requesting invalid paste.
Edho Arief <edho@myconan.net>
parents:
210
diff
changeset
|
20 rescue ActiveRecord::RecordNotFound |
|
388504e43bcf
Properly return 404 when requesting invalid paste.
Edho Arief <edho@myconan.net>
parents:
210
diff
changeset
|
21 nil |
|
388504e43bcf
Properly return 404 when requesting invalid paste.
Edho Arief <edho@myconan.net>
parents:
210
diff
changeset
|
22 end |
|
210
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
23 end |
|
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
24 |
|
373
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
25 def self.graceful_create(params) |
| 376 | 26 paste = new(params) |
|
373
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
27 fresh = true |
|
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
28 created = true |
|
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
29 |
|
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
30 begin |
|
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
31 created = paste.save |
|
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
32 rescue ActiveRecord::RecordNotUnique |
| 376 | 33 paste = find_by(:ip => paste.ip, :paste_hash => paste.paste_hash) |
|
373
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
34 fresh = false |
|
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
35 end |
|
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
36 |
| 376 | 37 [created, paste, fresh] |
|
373
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
38 end |
|
6e3e1e7b0212
Handle unique error in model instead of controller.
nanaya <me@myconan.net>
parents:
330
diff
changeset
|
39 |
|
316
61f7f258a6fb
Move from-gzip paste parsing to model.
edogawaconan <me@myconan.net>
parents:
290
diff
changeset
|
40 def paste_gzip=(paste) |
|
61f7f258a6fb
Move from-gzip paste parsing to model.
edogawaconan <me@myconan.net>
parents:
290
diff
changeset
|
41 self.paste = ActiveSupport::Gzip.decompress paste |
|
61f7f258a6fb
Move from-gzip paste parsing to model.
edogawaconan <me@myconan.net>
parents:
290
diff
changeset
|
42 end |
|
61f7f258a6fb
Move from-gzip paste parsing to model.
edogawaconan <me@myconan.net>
parents:
290
diff
changeset
|
43 |
|
61f7f258a6fb
Move from-gzip paste parsing to model.
edogawaconan <me@myconan.net>
parents:
290
diff
changeset
|
44 def paste_gzip_base64=(paste) |
|
61f7f258a6fb
Move from-gzip paste parsing to model.
edogawaconan <me@myconan.net>
parents:
290
diff
changeset
|
45 self.paste_gzip = Base64.decode64(paste) |
|
61f7f258a6fb
Move from-gzip paste parsing to model.
edogawaconan <me@myconan.net>
parents:
290
diff
changeset
|
46 end |
|
61f7f258a6fb
Move from-gzip paste parsing to model.
edogawaconan <me@myconan.net>
parents:
290
diff
changeset
|
47 |
|
265
6cca1ab53337
Infinitely better error messages and notice.
edogawaconan <me@myconan.net>
parents:
255
diff
changeset
|
48 def safe_destroy(param_key) |
|
6cca1ab53337
Infinitely better error messages and notice.
edogawaconan <me@myconan.net>
parents:
255
diff
changeset
|
49 if key == param_key |
|
6cca1ab53337
Infinitely better error messages and notice.
edogawaconan <me@myconan.net>
parents:
255
diff
changeset
|
50 destroy |
|
6cca1ab53337
Infinitely better error messages and notice.
edogawaconan <me@myconan.net>
parents:
255
diff
changeset
|
51 else |
|
6cca1ab53337
Infinitely better error messages and notice.
edogawaconan <me@myconan.net>
parents:
255
diff
changeset
|
52 errors.add(:key, "is invalid") |
|
6cca1ab53337
Infinitely better error messages and notice.
edogawaconan <me@myconan.net>
parents:
255
diff
changeset
|
53 false |
|
6cca1ab53337
Infinitely better error messages and notice.
edogawaconan <me@myconan.net>
parents:
255
diff
changeset
|
54 end |
|
6cca1ab53337
Infinitely better error messages and notice.
edogawaconan <me@myconan.net>
parents:
255
diff
changeset
|
55 end |
|
6cca1ab53337
Infinitely better error messages and notice.
edogawaconan <me@myconan.net>
parents:
255
diff
changeset
|
56 |
|
210
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
57 def path |
|
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
58 [id, secret.presence].compact.join("-") |
|
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
59 end |
|
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
60 |
| 2 | 61 def set_paste_hash |
|
51
36d07f047ec2
Or maybe not. Still too long with b62. Backed out changeset ba29d6394863
Edho Arief <edho@myconan.net>
parents:
46
diff
changeset
|
62 self.paste_hash = Digest::SHA512.hexdigest("#{paste}\n") |
| 2 | 63 end |
|
22
032686a0c995
Added newline converter, integrity fixups.
Edho Arief <edho@myconan.net>
parents:
2
diff
changeset
|
64 |
|
176
a9dba6a3008b
Initial work to add paste deletion.
Edho Arief <edho@myconan.net>
parents:
71
diff
changeset
|
65 def set_paste_key |
|
a9dba6a3008b
Initial work to add paste deletion.
Edho Arief <edho@myconan.net>
parents:
71
diff
changeset
|
66 self.key ||= SecureRandom.hex(4) |
|
a9dba6a3008b
Initial work to add paste deletion.
Edho Arief <edho@myconan.net>
parents:
71
diff
changeset
|
67 end |
|
a9dba6a3008b
Initial work to add paste deletion.
Edho Arief <edho@myconan.net>
parents:
71
diff
changeset
|
68 |
|
210
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
69 def set_paste_secret |
| 330 | 70 self.secret = SecureRandom.hex(4) if is_private? |
|
230
1c750d3cde1b
Correct way to test is_private flag.
Edho Arief <edho@myconan.net>
parents:
229
diff
changeset
|
71 end |
|
1c750d3cde1b
Correct way to test is_private flag.
Edho Arief <edho@myconan.net>
parents:
229
diff
changeset
|
72 |
|
1c750d3cde1b
Correct way to test is_private flag.
Edho Arief <edho@myconan.net>
parents:
229
diff
changeset
|
73 def is_private? |
| 330 | 74 is_private == "1" |
|
210
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
75 end |
|
d59731c3c7bf
Add support for is_private flag
Edho Arief <edho@myconan.net>
parents:
197
diff
changeset
|
76 |
|
22
032686a0c995
Added newline converter, integrity fixups.
Edho Arief <edho@myconan.net>
parents:
2
diff
changeset
|
77 def convert_newlines |
| 330 | 78 self.paste = paste.to_s.gsub("\r\n", "\n").gsub("\r", "\n") |
|
22
032686a0c995
Added newline converter, integrity fixups.
Edho Arief <edho@myconan.net>
parents:
2
diff
changeset
|
79 end |
|
032686a0c995
Added newline converter, integrity fixups.
Edho Arief <edho@myconan.net>
parents:
2
diff
changeset
|
80 |
|
70
8f0fb869e770
Limit pastes to 100/hour per IP address.
Edho Arief <edho@myconan.net>
parents:
51
diff
changeset
|
81 def paste_limit |
|
377
4e6afc8140fb
Use Time.zone as per rubocop recommendation.
nanaya <me@myconan.net>
parents:
376
diff
changeset
|
82 ip_post_recent_count = self.class.where(:ip => ip).where("created_at > ?", Time.zone.now - 1.hour).count |
|
70
8f0fb869e770
Limit pastes to 100/hour per IP address.
Edho Arief <edho@myconan.net>
parents:
51
diff
changeset
|
83 errors.add :base, :limit if ip_post_recent_count > 100 |
|
8f0fb869e770
Limit pastes to 100/hour per IP address.
Edho Arief <edho@myconan.net>
parents:
51
diff
changeset
|
84 end |
|
8f0fb869e770
Limit pastes to 100/hour per IP address.
Edho Arief <edho@myconan.net>
parents:
51
diff
changeset
|
85 |
|
22
032686a0c995
Added newline converter, integrity fixups.
Edho Arief <edho@myconan.net>
parents:
2
diff
changeset
|
86 def self.fix_all |
|
255
a894d7696b7e
More useful return of Paste.fix_all.
edogawaconan <me@myconan.net>
parents:
247
diff
changeset
|
87 stats = Hash.new(0) |
| 376 | 88 all.find_each do |p| |
|
22
032686a0c995
Added newline converter, integrity fixups.
Edho Arief <edho@myconan.net>
parents:
2
diff
changeset
|
89 p.save |
|
255
a894d7696b7e
More useful return of Paste.fix_all.
edogawaconan <me@myconan.net>
parents:
247
diff
changeset
|
90 stats[:count] += 1 |
|
a894d7696b7e
More useful return of Paste.fix_all.
edogawaconan <me@myconan.net>
parents:
247
diff
changeset
|
91 stats[:private] += 1 if p.secret |
|
22
032686a0c995
Added newline converter, integrity fixups.
Edho Arief <edho@myconan.net>
parents:
2
diff
changeset
|
92 end |
| 330 | 93 stats |
|
22
032686a0c995
Added newline converter, integrity fixups.
Edho Arief <edho@myconan.net>
parents:
2
diff
changeset
|
94 end |
| 2 | 95 end |
