Mercurial > zeropaste
annotate app/models/paste.rb @ 375:66ee2f5e793e
Exclude bin/ from rubocop.
| author | nanaya <me@myconan.net> | 
|---|---|
| date | Sat, 06 Jun 2015 22:22:41 +0900 | 
| parents | 6e3e1e7b0212 | 
| children | 02903dc8214d | 
| 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) | 
| 
 
6e3e1e7b0212
Handle unique error in model instead of controller.
 
nanaya <me@myconan.net> 
parents: 
330 
diff
changeset
 | 
26 paste = self.new(params) | 
| 
 
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 | 
| 
 
6e3e1e7b0212
Handle unique error in model instead of controller.
 
nanaya <me@myconan.net> 
parents: 
330 
diff
changeset
 | 
33 paste = self.find_by(:ip => paste.ip, :paste_hash => paste.paste_hash) | 
| 
 
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 | 
| 
 
6e3e1e7b0212
Handle unique error in model instead of controller.
 
nanaya <me@myconan.net> 
parents: 
330 
diff
changeset
 | 
37 return [created, paste, fresh] | 
| 
 
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 | 
| 330 | 82 ip_post_recent_count = self.class.where(:ip => ip).where("created_at > ?", Time.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) | 
| 330 | 88 all.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 | 
