hackerone-client 0.16.0 → 0.20.1

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 99cdf21603a490301a3901f5f62430f10fc7a8425ee7ffe08944ac046d85c2d8
4
- data.tar.gz: d390b20bc3611d74ab4d94a3fc22292f4c419ec7be9a6a0fc151b518fc713fa0
3
+ metadata.gz: 8bc7c771f9513ac464c291fcd7aff64f7bac61f07a599bc3df69fa50b5620aef
4
+ data.tar.gz: 2e1bfeee93c61b44b0852a49c24297b8c75cfc1a44fe74482961682e8de57225
5
5
  SHA512:
6
- metadata.gz: 500e402f964f2e5bf53ec230e598ec9418846f4abcc45683e2e2e0b7dec220c05b406213b4a934f82a59ac6a2425d6fe35021c1aa8a0b8963a8a8cfd0d2d888e
7
- data.tar.gz: 3d1fe92e5a018419a6d4c04b0651ffe0453c6d9f3194a26e8f4cf446ab20d029e6dda18e375bf5ebfd72373818f94a3f65f733db204a2341db118c1276db7a62
6
+ metadata.gz: 6e432abcb996c438be845f68f46785a8d58d5cad4ea30623fd4878358f8ae5d2857b9ba00f6bc33393c1ee30d35e92db49bbf0a4432ffb7a62b4021a4eb676c8
7
+ data.tar.gz: 483858e438178da5283d87b29df8bd3281a73f9716936dce4620be7b8420baf1c8f9afa59aa4d78f32426e248465fd5f106d5e2473d0b79e0a32c749a18dcbcc
@@ -7,13 +7,14 @@ jobs:
7
7
  runs-on: ubuntu-latest
8
8
  strategy:
9
9
  matrix:
10
- ruby: [ '2.4', '2.5', '2.6', '2.7']
10
+ ruby: [ '2.4.0', '2.5.0', '2.6.0', '2.7.2', '3.0.0']
11
11
  steps:
12
- - uses: actions/checkout@master
12
+ - uses: actions/checkout@v2
13
13
  - name: Set up Ruby ${{ matrix.ruby }}
14
- uses: actions/setup-ruby@v1
14
+ uses: ruby/setup-ruby@v1.64.1
15
15
  with:
16
16
  ruby-version: ${{ matrix.ruby }}
17
+ bundler-cache: true
17
18
  - name: Build and test with Rake with Ruby ${{ matrix.ruby }}
18
19
  run: |
19
20
  gem install bundler
@@ -23,7 +24,7 @@ jobs:
23
24
  name: Rubocop
24
25
  runs-on: ubuntu-latest
25
26
  steps:
26
- - uses: actions/checkout@master
27
+ - uses: actions/checkout@v2
27
28
  - name: Set up Ruby 2.6
28
29
  uses: actions/setup-ruby@v1
29
30
  with:
data/CHANGELOG.md CHANGED
@@ -1,6 +1,23 @@
1
+ ## [0.20.0] - 2020-10-21
2
+
3
+ [Add ability to lock a report](https://github.com/oreoshake/hackerone-client/pull/59) (@rzhade3)
4
+ [Add ability to list attachments on a report](https://github.com/oreoshake/hackerone-client/pull/58) (@rzhade3)
5
+
6
+ ## [0.19.0] - 2020-05-08
7
+
8
+ [Add ability to create a report](https://github.com/oreoshake/hackerone-client/pull/57) (@rzhade3)
9
+
10
+ ## [0.18.0] - 2020-03-23
11
+
12
+ [Add ability to filter reports on states other than "new"](https://github.com/oreoshake/hackerone-client/pull/54) (@rzhade3)
13
+
14
+ ## [0.17.0] - 2020-03-23
15
+
16
+ [Add support for updating the severity of an issue](https://github.com/oreoshake/hackerone-client/pull/50) (@rzhade3)
17
+
1
18
  ## [0.16.0] - 2020-03-23
2
19
 
3
- - [Add support for updating the severity of an issue](https://github.com/oreoshake/hackerone-client/pull/50) (@rzhade3)
20
+ - Whooops, no change
4
21
 
5
22
  ## [0.15.0] - 2020-03-09
6
23
 
data/Gemfile CHANGED
@@ -10,8 +10,8 @@ group :developement do
10
10
  end
11
11
 
12
12
  group :test do
13
- gem "rubocop", "< 0.68"
14
- gem "rubocop-github"
13
+ gem "rubocop"
14
+ gem "rubocop-github", ">= 0.16.0"
15
15
  gem "rubocop-performance"
16
16
  end
17
17
 
data/README.md CHANGED
@@ -5,8 +5,11 @@ A limited client library for interacting with HackerOne. Currently only supports
5
5
  ```ruby
6
6
  client = HackerOne::Client::Api.new("github")
7
7
 
8
- # GET '/reports' returns all reports in the "new" state for a given program
9
- client.reports
8
+ # POST '/reports' creates a new report
9
+ client.create_report(title: "hi", summary: "hi", impact: "string", severity_rating: :high, source: "api")
10
+
11
+ # GET '/reports' returns all reports in a given state for a program, by default :new
12
+ client.reports(state: :new)
10
13
 
11
14
  # GET '/report/{id}' returns report data for a given report
12
15
  report = client.report(id)
@@ -29,6 +32,9 @@ report.add_report_reference(reference)
29
32
  # Triage an issue (add a reference and set state to :triaged)
30
33
  report.triage(reference)
31
34
 
35
+ # Set the severity on a report (rating can be :none, :low, :medium, :high or :critical)
36
+ report.update_severity(rating: :high)
37
+
32
38
  # POST /reports/{id}/bounty_suggestions
33
39
  report.suggest_bounty(message: "I suggest $500 with a small bonus. Report is well-written.", amount: 500, bonus_amount: 50)
34
40
 
@@ -48,6 +54,9 @@ program.common_responses
48
54
 
49
55
  # Updates a program's policy
50
56
  program.update_policy(policy: "Please submit valid vulnerabilities")
57
+
58
+ # Gets a program's balance
59
+ program.balance
51
60
  ```
52
61
 
53
62
  ## State change hooks
@@ -0,0 +1,81 @@
1
+ ---
2
+ http_interactions:
3
+ - request:
4
+ method: post
5
+ uri: https://api.hackerone.com/v1/reports
6
+ body:
7
+ encoding: UTF-8
8
+ string: '{"data":{"type":"report","attributes":{"team_handle":"github","title":"hi","vulnerability_information":"hi","impact":"string","severity_rating":"none","source":"api"}}}'
9
+ headers:
10
+ Authorization:
11
+ - Basic NOPE
12
+ User-Agent:
13
+ - Faraday v1.0.1
14
+ Content-Type:
15
+ - application/json
16
+ Accept-Encoding:
17
+ - gzip;q=1.0,deflate;q=0.6,identity;q=0.3
18
+ Accept:
19
+ - "*/*"
20
+ response:
21
+ status:
22
+ code: 201
23
+ message: Created
24
+ headers:
25
+ Date:
26
+ - Wed, 06 May 2020 23:02:54 GMT
27
+ Content-Type:
28
+ - application/json; charset=utf-8
29
+ Transfer-Encoding:
30
+ - chunked
31
+ Connection:
32
+ - keep-alive
33
+ Set-Cookie:
34
+ - __cfduid=d31f31bc632e337f7fa240d7a863f92a01588806173; expires=Fri, 05-Jun-20
35
+ 23:02:53 GMT; path=/; Domain=api.hackerone.com; HttpOnly; SameSite=Lax; Secure
36
+ X-Request-Id:
37
+ - 55676c0a-2510-4787-9e47-7f74c1e9b2ac
38
+ Etag:
39
+ - W/"1f8bd995ef79550e2f8c8484301fadcc"
40
+ Cache-Control:
41
+ - max-age=0, private, must-revalidate
42
+ Strict-Transport-Security:
43
+ - max-age=31536000; includeSubDomains; preload
44
+ X-Frame-Options:
45
+ - DENY
46
+ X-Content-Type-Options:
47
+ - nosniff
48
+ X-Xss-Protection:
49
+ - 1; mode=block
50
+ X-Download-Options:
51
+ - noopen
52
+ X-Permitted-Cross-Domain-Policies:
53
+ - none
54
+ Referrer-Policy:
55
+ - strict-origin-when-cross-origin
56
+ Expect-Ct:
57
+ - enforce, max-age=86400
58
+ Content-Security-Policy:
59
+ - 'default-src ''none''; base-uri ''self''; block-all-mixed-content; child-src
60
+ www.youtube-nocookie.com; connect-src ''self'' www.google-analytics.com errors.hackerone.net;
61
+ font-src ''self''; form-action ''self''; frame-ancestors ''none''; img-src
62
+ ''self'' data: cover-photos.hackerone-user-content.com hackathon-photos.hackerone-user-content.com
63
+ profile-photos.hackerone-user-content.com hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
64
+ media-src ''self'' hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
65
+ script-src ''self'' www.google-analytics.com; style-src ''self'' ''unsafe-inline'';
66
+ report-uri https://errors.hackerone.net/api/30/csp-report/?sentry_key=61c1e2f50d21487c97a071737701f598'
67
+ Cf-Cache-Status:
68
+ - DYNAMIC
69
+ Server:
70
+ - cloudflare
71
+ Cf-Ray:
72
+ - 58f654d83ea1bc9c-SEA
73
+ Cf-Request-Id:
74
+ - '028dd35b1e0000bc9c75365200000001'
75
+ body:
76
+ encoding: ASCII-8BIT
77
+ string: !binary |-
78
+ {"data":{"id":"867479","type":"report","attributes":{"title":"hi","state":"new","created_at":"2020-05-06T23:02:53.615Z","vulnerability_information":"hi\n\n## Impact\n\nstring","triaged_at":null,"closed_at":null,"last_reporter_activity_at":"2020-05-06T23:02:53.679Z","first_program_activity_at":"2020-05-06T23:02:53.679Z","last_program_activity_at":"2020-05-06T23:02:53.679Z","bounty_awarded_at":null,"swag_awarded_at":null,"disclosed_at":null,"reporter_agreed_on_going_public_at":null,"last_public_activity_at":"2020-05-06T23:02:53.679Z","last_activity_at":"2020-05-06T23:02:53.679Z","cve_ids":[],"source":"api"},"relationships":{"reporter":{"data":{"id":"1013596","type":"user","attributes":{"username":"rzhade3-tester","name":null,"disabled":false,"created_at":"2020-03-30T15:21:10.873Z","profile_picture":{"62x62":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","82x82":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","110x110":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","260x260":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png"},"bio":null,"website":null,"location":null,"hackerone_triager":false}}},"program":{"data":{"id":"11767","type":"program","attributes":{"handle":"github-test","policy":"# GitHub Security Bug Bounty\n\nSoftware security researchers are increasingly engaging with Internet companies to hunt down vulnerabilities. Our bounty program gives a tip of the hat to these researchers and provides rewards of  $30,000 or more for critical vulnerabilities.\n\n\nYou can find more information in our [rules](https://bounty.github.com/#rules), [scope](https://bounty.github.com/#scope), [targets](https://bounty.github.com/#targets), and [FAQ](https://bounty.github.com/#faqs) sections. You can also check the current rankings on the [leaderboard](https://bounty.github.com/#leaderboard).\n\nHappy hacking!\n\n\n## Rules\n\n### Before you start\n\n* Check the list of bugs that have been [classified as ineligible](https://bounty.github.com/ineligible.html). Submissions which are ineligible will likely be closed as `Not Applicable`.\n* Check the [GitHub Changelog](https://github.blog/changelog/) for recently launched features.\n* Never attempt non-technical attacks such as social engineering, phishing, or physical attacks against our employees, users, or infrastructure.\n* When in doubt, contact us at `bounty@github.com`.\n* By participating in GitHub's Bug Bounty program (the \"Program\"), you acknowledge that you have read and agree to GitHub's [Terms of Service](https://help.github.com/articles/github-terms-of-service) as well as the following:\n\n  * you're not participating from a country against which the United States has issued export sanctions or other trade restrictions, including Cuba, Iran, North Korea, Sudan, and Syria.\n\n  * your participation in the Program will not violate any law applicable to you, or disrupt or compromise any data that is not your own.\n\n  * you are solely responsible for any applicable taxes, withholding or otherwise, arising from or relating to your participation in the Program, including from any bounty payments.\n\n  * GitHub reserves the right to terminate or discontinue the Program at its discretion.\n\n  * Only test for vulnerabilities on sites you know to be operated by GitHub and are [in-scope](https://bounty.github.com#scope). Some sites hosted on subdomains of `GitHub.com` are operated by third parties and should not be tested.\n\n\n### Legal safe harbor\n\nYour research is covered by the [GitHub Bug Bounty Program Legal Safe Harbor](https://help.github.com/articles/github-bug-bounty-program-legal-safe-harbor/) policy. In summary:\n* We consider security research and vulnerability disclosure activities conducted consistent with this policy as “authorized” conduct under the Computer Fraud and Abuse Act, the DMCA, and other applicable computer use laws such as Cal. Penal Code 502(c). We waive any potential DMCA claim against you for circumventing the technological measures we have used to protect the applications in this bug bounty program's scope.\n* We want you to responsibly disclose through our bug bounty program, and don't want researchers put in fear of legal consequences because of their good faith attempts to comply with our bug bounty policy. We cannot bind any third party, so do not assume this protection extends to any third party. If in doubt, ask us before engaging in any specific action you think might go outside the bounds of our policy.\n* Because both identifying and non-identifying information can put a researcher at risk, we limit what we share with third parties. We may provide non-identifying substantive information from your report to an affected third party, but only after notifying you and receiving a commitment that the third party will not pursue legal action against you. We will only share identifying information (name, email address, phone number, etc.) with a third party if you give your written permission.\n* If your security research as part of the bug bounty program violates certain restrictions in our site policies, the safe harbor terms permit a limited exemption.\n\n\n### Performing your research\n\n* Do not impact other users with your testing, this includes testing vulnerabilities in repositories or organizations you do not own. If you are attempting to find an authorization bypass, you must use accounts you own.\n* The following are **never** allowed and are ineligible for reward. We may suspend your GitHub account and ban your IP address for:\n\n  * Performing distributed denial of service (DDoS) or other volumetric attacks\n  * Spamming content\n  * Large-scale vulnerability scanners, scrapers, or automated tools which produce excessive amounts of traffic.\n    * Note: We _do_ allow the use of automated tools so long as they do not produce excessive amounts of traffic. For example, running one `nmap` scan against one host is allowed, but sending 65,000 requests in two minutes using Burp Suite Intruder is excessive.\n* Researching denial-of-service attacks is allowed and eligible for rewards only if you follow these rules:\n\n  * Research **must** be performed in organizations or repositories you own\n  * Stop **immediately** if you believe you have affected the availability of our services. Don't worry about demonstrating the full impact of your vulnerability, GitHub's security team will be able to determine the impact.\n  * There are no limits for researching denial of service vulnerabilities against your own instance of [GitHub Enterprise Server](https://bounty.github.com/targets/github-enterprise-server.html)\n\n\n### Handling personally identifiable information (PII)\n\n* Personally identifying information (PII) includes:\n  * legal and/or full names\n  * names or usernames combined with other identifiers like phone numbers or email addresses\n  * health or financial information (including insurance information, social security numbers, etc.)\n  * information about political or religious affiliations\n  * information about race, ethnicity, sexual orientation, gender, or other identifying information that could be used for discriminatory purposes\n* Do not intentionally access others' PII. If you suspect a service provides access to PII, limit queries to your own personal information.\n* Report the vulnerability *immediately* and do not attempt to access any other data. The GitHub Security team will assess the scope and impact of the PII exposure.\n* Limit the amount of data returned from services. For SQL injection, for example, limit the number of rows returned\n* You must delete all your local, stored, or cached copies of data containing PII as soon as possible. We may ask you to sign a certificate of deletion and confidentiality agreement regarding the exact information you accessed. This agreement will not affect your bounty reward.\n* We may ask you for the usernames and IP addresses used during your testing to assess the impact of the vulnerability\n\n\n### Reporting your vulnerability\n\n* Submissions must include written instructions for reproducing the vulnerability. Submissions without clear reproduction steps or which only include reproduction steps in video form may be ineligible for a reward.\n* When reporting vulnerabilities you must keep all information on HackerOne. Do not post information to video-sharing or pastebin sites. Videos and images can be uploaded directly via HackerOne.\n* For vulnerabilities involving personally identifiable information, please explain the kind of PII you believe is exposed and limit the amount of PII data included in your submissions. For textual information and screenshots, please only include redacted data in your submission.\n* Do not publicly disclose your submission until GitHub has evaluated the impact.\n\n\n### Receiving your award\n\n* All reward amounts are determined by our [severity guidelines](https://bounty.github.com/#severity-guidelines).\n* When duplicates occur, we only award the first report that was received (provided that it can be fully reproduced).\n* You are free to publish write-ups about your vulnerability and GitHub will not limit what you write. We may pay out your reward before the vulnerability is patched so we may ask that you delay publishing to keep other GitHub users safe.\n* Medium, high, and critical severity issues will be written up on the GitHub Bug Bounty site and included in our leaderboard. We don't currently post write-ups for low severity vulnerabilities.\n* GitHub is a CVE Numbering Authority (CNA) for GitHub Enterprise Server. Eligible Bug Bounty submissions that affect GitHub Enterprise Server may be assigned CVEs. These CVEs will be shared with submitters via HackerOne, included in [bounty write-ups](https://bounty.github.com/bounty-hunters.html) and listed in the GitHub Enterprise Server [release notes](https://enterprise.github.com/releases).\n* You may prefer the reward go toward helping others. If you choose to do so, GitHub will donate your reward to an established 501(c)(3) charitable organization of your choice. GitHub will also match your donation - subject to our discretion. Any rewards that go unclaimed after 12 months will be donated to a charity of GitHub's choosing.\n\n\n## Scope\n\nGitHub runs a number of services but only submissions under the following domains are eligible for rewards. Any GitHub-owned domains not listed below are *not* in-scope, *not* eligible for rewards and *not* covered by our [legal safe harbor](https://bounty.github.com#legal_safe_harbor).\n\n\n### github.com\n\nOur main domain hosting user-facing GitHub services.. All subdomains under `github.com` are in-scope *except*:\n* `blog.github.com`\n* `community.github.com`\n* `email.enterprise.github.com`\n* `email.finance.github.com`\n* `email.staging.finance.github.com`\n* `email.support.github.com`\n* `email.verify.github.com`\n* `google7650dcf6146f04d8.github.com`\n* `k1._domainkey.github.com`\n* `k1._domainkey.mcmail.github.com`\n* `mcmail.github.com`\n* `resources.github.com`\n* `*.resources.github.com`\n* `sgmail.github.com`\n* `*.sgmail.github.com`\n* `shop.github.com`\n* `smtp.github.com`\n* `*.smtp.github.com`\n* `support.github.com`\n\n### githubassets.com\n\nOur domain for hosting static assets.. All subdomains under `githubassets.com` are in-scope\n\n### githubusercontent.com\n\nOur domain for hosting and rendering users' data.. All subdomains under `githubusercontent.com` are in-scope\n\n### githubapp.com\n\nOur domain for hosting employee-facing services.. All subdomains under `githubapp.com` are in-scope *except*:\n* `atom-io.githubapp.com`\n* `atom-io-staging.githubapp.com`\n* `email.enterprise-staging.githubapp.com`\n* `email.haystack.githubapp.com`\n* `reply.githubapp.com`\n\n### github.net\n\nOur domain for hosting GitHub's internal production services. Many of these services are not accessible from outside our internal network.. All subdomains under `github.net` are in-scope\n\n### semmle.com\n\nOur main domain for Semmle and LGTM services. All subdomains under `semmle.com` are in-scope *except*:\n* `dev.semmle.com`\n* `git.semmle.com`\n* `jira.semmle.com`\n* `wiki.semmle.com`\n\n### semmle.net\n\nOur domain for non-production Semmle services. All subdomains under `semmle.net` are in-scope\n\n### downloads.lgtm.com\n\nOur domain for serving LGTM downloads.. All subdomains under `downloads.lgtm.com` are in-scope\n\n### lgtm-com.pentesting.semmle.net\n\nAn instance of [LGTM](https://bounty.github.com/targets/lgtm.html) especially for Bug Bounty research.. All subdomains under `lgtm-com.pentesting.semmle.net` are in-scope\n\n### backend-dot-lgtm-penetration-testing.appspot.com\n\nAn instance of [LGTM](https://bounty.github.com/targets/lgtm.html)'s backend used for triggering automated tasks.. All subdomains under `backend-dot-lgtm-penetration-testing.appspot.com` are in-scope\n\n## Severity Guidelines\n\nAll bounty submissions are rated by GitHub using a purposefully simple scale. Each vulnerability is unique but the following is a rough guideline we use internally for rating and rewarding submissions:\n\n\n### Critical: $20,000 - $30,000\n\nCritical severity issues present a direct and immediate risk to a broad array of our users or to GitHub itself. They often affect relatively low-level/foundational components in one of our application stacks or infrastructure. For example:\n* arbitrary code/command execution on a GitHub server in our production network.\n* arbitrary SQL queries on the GitHub production database.\n* bypassing the GitHub login process, either password or 2FA.\n* access to sensitive production user data or access to internal production systems.\n* accessing another user's data in the GitHub Actions service.\n\nThe upper bound for critical vulnerabilities, $30,000, is only a guideline and GitHub may reward higher amounts for exceptional reports.\n\n\n### High: $10,000 - $20,000\n\nHigh severity issues allow an attacker to read or modify highly sensitive data that they are not authorized to access. They are generally more narrow in scope than critical issues, though they may still grant an attacker extensive access. For example:\n* injecting attacker controlled content into GitHub.com (XSS) which bypasses CSP.\n* bypassing authorization logic to grant a repository collaborator more access than intended.\n* discovering sensitive user or GitHub data in a publicly exposed resource, such as an S3 bucket.\n* gaining access to a non-critical resource that only GitHub employees should be able to reach.\n* using the GitHub Actions repo-scoped GitHub token to access high-risk private content outside of that repository.\n* code execution in a desktop app that requires no user interaction.\n\n\n### Medium: $4,000 - $10,000\n\nMedium severity issues allow an attacker to read or modify limited amounts of data that they are not authorized to access. They generally grant access to less sensitive information than high severity issues. For example:\n* disclosing the title of issues in private repositories which should be be inaccessible.\n* injecting attacker controlled content into GitHub.com (XSS) but not bypassing CSP or executing sensitive actions with another user's session.\n* bypassing CSRF validation for low risk actions, such as starring a repository or unsubscribing from a mailing list.\n* escaping the LGTM worker sandbox to access other user's data or private networked resources\n\n\n### Low: $617 - $2,000\n\nLow severity issues allow an attacker to access extremely limited amounts of data. They may violate an expectation for how something is intended to work, but it allows nearly no escalation of privilege or ability to trigger unintended behavior by an attacker. For example:\n* signing up arbitrary users for access to an \"early access feature\" without their consent.\n* creating an issue comment that bypasses our image proxying filter by providing a malformed URL.\n* bypassing community-and-safety features such as locked conversations.\n* bypassing billing \u0026 plan restrictions to gain access to paid features.\n* triggering verbose or debug error pages without proof of exploitability or obtaining sensitive information.\n* triggering application exceptions that could affect many GitHub users.\n* triggering XSS or CSRF vulnerabilities in LGTM\n\n","created_at":"2016-04-15T17:10:31.261Z","updated_at":"2020-04-08T13:45:49.548Z"}}},"severity":{"data":{"id":"713568","type":"severity","attributes":{"rating":"none","author_type":"User","user_id":1013596,"created_at":"2020-05-06T23:02:53.634Z"}}},"swag":{"data":[]},"attachments":{"data":[]},"activities":{"data":[]},"bounties":{"data":[]},"summaries":{"data":[]},"custom_field_values":{"data":[]}}}}
79
+ http_version: null
80
+ recorded_at: Wed, 06 May 2020 23:02:53 GMT
81
+ recorded_with: VCR 5.1.0
@@ -0,0 +1,79 @@
1
+ ---
2
+ http_interactions:
3
+ - request:
4
+ method: post
5
+ uri: https://api.hackerone.com/v1/reports
6
+ body:
7
+ encoding: UTF-8
8
+ string: '{"data":{"type":"report","attributes":{"team_handle":"github","title":"hi","vulnerability_information":"hi","impact":"string","severity_rating":"invalid_severity","source":"api"}}}'
9
+ headers:
10
+ Authorization:
11
+ - Basic NOPE
12
+ User-Agent:
13
+ - Faraday v1.0.1
14
+ Content-Type:
15
+ - application/json
16
+ Accept-Encoding:
17
+ - gzip;q=1.0,deflate;q=0.6,identity;q=0.3
18
+ Accept:
19
+ - "*/*"
20
+ response:
21
+ status:
22
+ code: 400
23
+ message: Bad Request
24
+ headers:
25
+ Date:
26
+ - Wed, 06 May 2020 23:18:54 GMT
27
+ Content-Type:
28
+ - application/json; charset=utf-8
29
+ Transfer-Encoding:
30
+ - chunked
31
+ Connection:
32
+ - keep-alive
33
+ Set-Cookie:
34
+ - __cfduid=de6cf45714928bec4f073b32dab8dddec1588807134; expires=Fri, 05-Jun-20
35
+ 23:18:54 GMT; path=/; Domain=api.hackerone.com; HttpOnly; SameSite=Lax; Secure
36
+ X-Request-Id:
37
+ - ef6a977c-7273-4682-86ac-97a6af3d8ba0
38
+ Cache-Control:
39
+ - no-cache
40
+ Strict-Transport-Security:
41
+ - max-age=31536000; includeSubDomains; preload
42
+ X-Frame-Options:
43
+ - DENY
44
+ X-Content-Type-Options:
45
+ - nosniff
46
+ X-Xss-Protection:
47
+ - 1; mode=block
48
+ X-Download-Options:
49
+ - noopen
50
+ X-Permitted-Cross-Domain-Policies:
51
+ - none
52
+ Referrer-Policy:
53
+ - strict-origin-when-cross-origin
54
+ Expect-Ct:
55
+ - enforce, max-age=86400
56
+ Content-Security-Policy:
57
+ - 'default-src ''none''; base-uri ''self''; block-all-mixed-content; child-src
58
+ www.youtube-nocookie.com; connect-src ''self'' www.google-analytics.com errors.hackerone.net;
59
+ font-src ''self''; form-action ''self''; frame-ancestors ''none''; img-src
60
+ ''self'' data: cover-photos.hackerone-user-content.com hackathon-photos.hackerone-user-content.com
61
+ profile-photos.hackerone-user-content.com hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
62
+ media-src ''self'' hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
63
+ script-src ''self'' www.google-analytics.com; style-src ''self'' ''unsafe-inline'';
64
+ report-uri https://errors.hackerone.net/api/30/csp-report/?sentry_key=61c1e2f50d21487c97a071737701f598'
65
+ Cf-Cache-Status:
66
+ - DYNAMIC
67
+ Server:
68
+ - cloudflare
69
+ Cf-Ray:
70
+ - 58f66c4e6cd3f56d-SEA
71
+ Cf-Request-Id:
72
+ - '028de204fe0000f56dae94e200000001'
73
+ body:
74
+ encoding: UTF-8
75
+ string: '{"errors":[{"status":400,"title":"Invalid Parameter","detail":"The
76
+ parameter ''severity_rating'' is invalid.","source":{"parameter":"severity_rating"}}]}'
77
+ http_version: null
78
+ recorded_at: Wed, 06 May 2020 23:18:54 GMT
79
+ recorded_with: VCR 5.1.0
@@ -0,0 +1,80 @@
1
+ ---
2
+ http_interactions:
3
+ - request:
4
+ method: get
5
+ uri: https://api.hackerone.com/v1/programs/18969/billing/balance
6
+ body:
7
+ encoding: US-ASCII
8
+ string: ''
9
+ headers:
10
+ Authorization:
11
+ - Basic NOPE
12
+ User-Agent:
13
+ - Faraday v0.17.3
14
+ Content-Type:
15
+ - application/json
16
+ Accept-Encoding:
17
+ - gzip;q=1.0,deflate;q=0.6,identity;q=0.3
18
+ Accept:
19
+ - "*/*"
20
+ response:
21
+ status:
22
+ code: 200
23
+ message: OK
24
+ headers:
25
+ Date:
26
+ - Fri, 12 Feb 2021 20:37:48 GMT
27
+ Content-Type:
28
+ - application/json; charset=utf-8
29
+ Transfer-Encoding:
30
+ - chunked
31
+ Connection:
32
+ - keep-alive
33
+ Set-Cookie:
34
+ - __cfduid=d64ff625fe5f42c2547caf518714b001c1613162268; expires=Sun, 14-Mar-21
35
+ 20:37:48 GMT; path=/; Domain=api.hackerone.com; HttpOnly; SameSite=Lax; Secure
36
+ X-Request-Id:
37
+ - 49e5c329-cf7f-4723-9853-a47db4c6ef4d
38
+ Etag:
39
+ - W/"623ba11e90acdaa5bfcf60eb7743af10"
40
+ Cache-Control:
41
+ - max-age=0, private, must-revalidate
42
+ Strict-Transport-Security:
43
+ - max-age=31536000; includeSubDomains; preload
44
+ X-Frame-Options:
45
+ - DENY
46
+ X-Content-Type-Options:
47
+ - nosniff
48
+ X-Xss-Protection:
49
+ - 1; mode=block
50
+ X-Download-Options:
51
+ - noopen
52
+ X-Permitted-Cross-Domain-Policies:
53
+ - none
54
+ Referrer-Policy:
55
+ - strict-origin-when-cross-origin
56
+ Expect-Ct:
57
+ - enforce, max-age=86400
58
+ Content-Security-Policy:
59
+ - 'default-src ''none''; base-uri ''self''; block-all-mixed-content; child-src
60
+ www.youtube-nocookie.com; connect-src ''self'' www.google-analytics.com errors.hackerone.net;
61
+ font-src ''self''; form-action ''self''; frame-ancestors ''none''; img-src
62
+ ''self'' data: cover-photos.hackerone-user-content.com hackathon-photos.hackerone-user-content.com
63
+ profile-photos.hackerone-user-content.com hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
64
+ media-src ''self'' hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
65
+ script-src ''self'' www.google-analytics.com; style-src ''self'' ''unsafe-inline'';
66
+ report-uri https://errors.hackerone.net/api/30/csp-report/?sentry_key=374aea95847f4040a69f9c8d49a3a59d'
67
+ Cf-Cache-Status:
68
+ - DYNAMIC
69
+ Cf-Request-Id:
70
+ - '08398fde1c000027e4d90cd000000001'
71
+ Server:
72
+ - cloudflare
73
+ Cf-Ray:
74
+ - 62091c102ef927e4-SLC
75
+ body:
76
+ encoding: ASCII-8BIT
77
+ string: '{"data":{"id":"1894","type":"program-balance","attributes":{"balance":"118386.40"}}}'
78
+ http_version:
79
+ recorded_at: Fri, 12 Feb 2021 20:37:48 GMT
80
+ recorded_with: VCR 3.0.3
@@ -0,0 +1,156 @@
1
+ ---
2
+ http_interactions:
3
+ - request:
4
+ method: post
5
+ uri: https://api.hackerone.com/v1/reports/200/state_changes
6
+ body:
7
+ encoding: UTF-8
8
+ string: '{"data":{"type":"state-change","attributes":{"state":"resolved","message":""}}}'
9
+ headers:
10
+ Authorization:
11
+ - Basic NOPE=
12
+ User-Agent:
13
+ - Faraday v1.0.1
14
+ Content-Type:
15
+ - application/json
16
+ Accept-Encoding:
17
+ - gzip;q=1.0,deflate;q=0.6,identity;q=0.3
18
+ Accept:
19
+ - "*/*"
20
+ response:
21
+ status:
22
+ code: 201
23
+ message: Created
24
+ headers:
25
+ Date:
26
+ - Tue, 04 Aug 2020 20:22:57 GMT
27
+ Content-Type:
28
+ - application/json; charset=utf-8
29
+ Transfer-Encoding:
30
+ - chunked
31
+ Connection:
32
+ - keep-alive
33
+ Set-Cookie:
34
+ - __cfduid=d5217b52e915c7a8c7008d9acee5e37701596572577; expires=Thu, 03-Sep-20
35
+ 20:22:57 GMT; path=/; Domain=api.hackerone.com; HttpOnly; SameSite=Lax; Secure
36
+ X-Request-Id:
37
+ - 2667dcb8-451b-4c3c-a3a0-c8a6571cf5ff
38
+ Etag:
39
+ - W/"90fc4eba1716b554d0709bafb6b998ed"
40
+ Cache-Control:
41
+ - max-age=0, private, must-revalidate
42
+ Strict-Transport-Security:
43
+ - max-age=31536000; includeSubDomains; preload
44
+ X-Frame-Options:
45
+ - DENY
46
+ X-Content-Type-Options:
47
+ - nosniff
48
+ X-Xss-Protection:
49
+ - 1; mode=block
50
+ X-Download-Options:
51
+ - noopen
52
+ X-Permitted-Cross-Domain-Policies:
53
+ - none
54
+ Referrer-Policy:
55
+ - strict-origin-when-cross-origin
56
+ Expect-Ct:
57
+ - enforce, max-age=86400
58
+ Content-Security-Policy:
59
+ - 'default-src ''none''; base-uri ''self''; block-all-mixed-content; child-src
60
+ www.youtube-nocookie.com; connect-src ''self'' www.google-analytics.com errors.hackerone.net;
61
+ font-src ''self''; form-action ''self''; frame-ancestors ''none''; img-src
62
+ ''self'' data: cover-photos.hackerone-user-content.com hackathon-photos.hackerone-user-content.com
63
+ profile-photos.hackerone-user-content.com hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
64
+ media-src ''self'' hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
65
+ script-src ''self'' www.google-analytics.com; style-src ''self'' ''unsafe-inline'';
66
+ report-uri https://errors.hackerone.net/api/30/csp-report/?sentry_key=61c1e2f50d21487c97a071737701f598'
67
+ Cf-Cache-Status:
68
+ - DYNAMIC
69
+ Cf-Request-Id:
70
+ - 045cbd44e40000934c0c8d6200000001
71
+ Server:
72
+ - cloudflare
73
+ Cf-Ray:
74
+ - 5bdafe4e3b7c934c-SJC
75
+ body:
76
+ encoding: ASCII-8BIT
77
+ string: !binary |-
78
+ {"data":{"id":"200","type":"report","attributes":{"title":"ya","state":"resolved","created_at":"2020-08-04T18:34:42.899Z","vulnerability_information":"alright alright alright alright\n\n## Impact\n\nalright alright alright alright","triaged_at":null,"closed_at":"2020-08-04T20:22:57.217Z","last_reporter_activity_at":"2020-08-04T18:34:43.063Z","first_program_activity_at":"2020-08-04T18:34:43.063Z","last_program_activity_at":"2020-08-04T20:22:57.217Z","bounty_awarded_at":null,"swag_awarded_at":null,"disclosed_at":null,"reporter_agreed_on_going_public_at":null,"last_public_activity_at":"2020-08-04T20:22:57.217Z","last_activity_at":"2020-08-04T20:22:57.217Z","cve_ids":[],"source":null},"relationships":{"reporter":{"data":{"id":"291079","type":"user","attributes":{"username":"rzhade3","name":"Rahul Zhade","disabled":false,"created_at":"2018-06-12T17:43:40.852Z","profile_picture":{"62x62":"https://profile-photos.hackerone-user-content.com/variants/000/291/079/b79c3c343130bd631131f690e2f04bc0d1fde8bf_original.png/3afcb5c896247e7ee8ada31b1c1eb8657e22241f911093acfe4ec7e97a3a959a","82x82":"https://profile-photos.hackerone-user-content.com/variants/000/291/079/b79c3c343130bd631131f690e2f04bc0d1fde8bf_original.png/eb31823a4cc9f6b6bb4db930ffdf512533928a68a4255fb50a83180281a60da5","110x110":"https://profile-photos.hackerone-user-content.com/variants/000/291/079/b79c3c343130bd631131f690e2f04bc0d1fde8bf_original.png/692237eb9691fbde92a17174cdb809a788ace02bc77c72803f17d32b41e4f213","260x260":"https://profile-photos.hackerone-user-content.com/variants/000/291/079/b79c3c343130bd631131f690e2f04bc0d1fde8bf_original.png/cf1e4b5d44005cb61fab358dd6968415f20545de5f055ba4ed33ca4387948cdc"},"bio":"Application Security @GitHub","website":"https://zhade.dev","location":"","hackerone_triager":false}}},"program":{"data":{"id":"11767","type":"program","attributes":{"handle":"github-test","policy":"# GitHub Security Bug Bounty\n\nSoftware security researchers are increasingly engaging with Internet companies to hunt down vulnerabilities. Our bounty program gives a tip of the hat to these researchers and provides rewards of  $30,000 or more for critical vulnerabilities.\n\n\nYou can find more information in our [rules](https://bounty.github.com/#rules), [scope](https://bounty.github.com/#scope), [targets](https://bounty.github.com/#targets), and [FAQ](https://bounty.github.com/#faqs) sections. You can also check the current rankings on the [leaderboard](https://bounty.github.com/#leaderboard).\n\nHappy hacking!\n\n\n## Rules\n\n### Before you start\n\n* Check the list of bugs that have been [classified as ineligible](https://bounty.github.com/ineligible.html). Submissions which are ineligible will likely be closed as `Not Applicable`.\n* Check the [GitHub Changelog](https://github.blog/changelog/) for recently launched features.\n* Never attempt non-technical attacks such as social engineering, phishing, or physical attacks against our employees, users, or infrastructure.\n* When in doubt, contact us at `bounty@github.com`.\n* By participating in GitHub's Bug Bounty program (the \"Program\"), you acknowledge that you have read and agree to GitHub's [Terms of Service](https://help.github.com/articles/github-terms-of-service) as well as the following:\n\n  * you're not participating from a country against which the United States has issued export sanctions or other trade restrictions, including Cuba, Iran, North Korea, Sudan, and Syria.\n\n  * your participation in the Program will not violate any law applicable to you, or disrupt or compromise any data that is not your own.\n\n  * you are solely responsible for any applicable taxes, withholding or otherwise, arising from or relating to your participation in the Program, including from any bounty payments.\n\n  * GitHub reserves the right to terminate or discontinue the Program at its discretion.\n\n  * Only test for vulnerabilities on sites you know to be operated by GitHub and are [in-scope](https://bounty.github.com#scope). Some sites hosted on subdomains of `GitHub.com` are operated by third parties and should not be tested.\n\n\n### Legal safe harbor\n\nYour research is covered by the [GitHub Bug Bounty Program Legal Safe Harbor](https://help.github.com/articles/github-bug-bounty-program-legal-safe-harbor/) policy. In summary:\n* We consider security research and vulnerability disclosure activities conducted consistent with this policy as “authorized” conduct under the Computer Fraud and Abuse Act, the DMCA, and other applicable computer use laws such as Cal. Penal Code 502(c). We waive any potential DMCA claim against you for circumventing the technological measures we have used to protect the applications in this bug bounty program's scope.\n* We want you to responsibly disclose through our bug bounty program, and don't want researchers put in fear of legal consequences because of their good faith attempts to comply with our bug bounty policy. We cannot bind any third party, so do not assume this protection extends to any third party. If in doubt, ask us before engaging in any specific action you think might go outside the bounds of our policy.\n* Because both identifying and non-identifying information can put a researcher at risk, we limit what we share with third parties. We may provide non-identifying substantive information from your report to an affected third party, but only after notifying you and receiving a commitment that the third party will not pursue legal action against you. We will only share identifying information (name, email address, phone number, etc.) with a third party if you give your written permission.\n* If your security research as part of the bug bounty program violates certain restrictions in our site policies, the safe harbor terms permit a limited exemption.\n\n\n### Performing your research\n\n* Do not impact other users with your testing, this includes testing vulnerabilities in repositories or organizations you do not own. If you are attempting to find an authorization bypass, you must use accounts you own.\n* The following are **never** allowed and are ineligible for reward. We may suspend your GitHub account and ban your IP address for:\n\n  * Performing distributed denial of service (DDoS) or other volumetric attacks\n  * Spamming content\n  * Large-scale vulnerability scanners, scrapers, or automated tools which produce excessive amounts of traffic.\n    * Note: We _do_ allow the use of automated tools so long as they do not produce excessive amounts of traffic. For example, running one `nmap` scan against one host is allowed, but sending 65,000 requests in two minutes using Burp Suite Intruder is excessive.\n* Researching denial-of-service attacks is allowed and eligible for rewards only if you follow these rules:\n\n  * Research **must** be performed in organizations or repositories you own\n  * Stop **immediately** if you believe you have affected the availability of our services. Don't worry about demonstrating the full impact of your vulnerability, GitHub's security team will be able to determine the impact.\n  * There are no limits for researching denial of service vulnerabilities against your own instance of [GitHub Enterprise Server](https://bounty.github.com/targets/github-enterprise-server.html)\n\n\n### Handling personally identifiable information (PII)\n\n* Personally identifying information (PII) includes:\n  * legal and/or full names\n  * names or usernames combined with other identifiers like phone numbers or email addresses\n  * health or financial information (including insurance information, social security numbers, etc.)\n  * information about political or religious affiliations\n  * information about race, ethnicity, sexual orientation, gender, or other identifying information that could be used for discriminatory purposes\n* Do not intentionally access others' PII. If you suspect a service provides access to PII, limit queries to your own personal information.\n* Report the vulnerability *immediately* and do not attempt to access any other data. The GitHub Security team will assess the scope and impact of the PII exposure.\n* Limit the amount of data returned from services. For SQL injection, for example, limit the number of rows returned\n* You must delete all your local, stored, or cached copies of data containing PII as soon as possible. We may ask you to sign a certificate of deletion and confidentiality agreement regarding the exact information you accessed. This agreement will not affect your bounty reward.\n* We may ask you for the usernames and IP addresses used during your testing to assess the impact of the vulnerability\n\n\n### Reporting your vulnerability\n\n* Submissions must include written instructions for reproducing the vulnerability. Submissions without clear reproduction steps or which only include reproduction steps in video form may be ineligible for a reward.\n* When reporting vulnerabilities you must keep all information on HackerOne. Do not post information to video-sharing or pastebin sites. Videos and images can be uploaded directly via HackerOne.\n* For vulnerabilities involving personally identifiable information, please explain the kind of PII you believe is exposed and limit the amount of PII data included in your submissions. For textual information and screenshots, please only include redacted data in your submission.\n* Do not publicly disclose your submission until GitHub has evaluated the impact.\n\n\n### Receiving your award\n\n* All reward amounts are determined by our [severity guidelines](https://bounty.github.com/#severity-guidelines).\n* When duplicates occur, we only award the first report that was received (provided that it can be fully reproduced).\n* You are free to publish write-ups about your vulnerability and GitHub will not limit what you write. We may pay out your reward before the vulnerability is patched so we may ask that you delay publishing to keep other GitHub users safe.\n* Medium, high, and critical severity issues will be written up on the GitHub Bug Bounty site and included in our leaderboard. We don't currently post write-ups for low severity vulnerabilities.\n* GitHub is a CVE Numbering Authority (CNA) for GitHub Enterprise Server. Eligible Bug Bounty submissions that affect GitHub Enterprise Server may be assigned CVEs. These CVEs will be shared with submitters via HackerOne, included in [bounty write-ups](https://bounty.github.com/bounty-hunters.html) and listed in the GitHub Enterprise Server [release notes](https://enterprise.github.com/releases).\n* You may prefer the reward go toward helping others. If you choose to do so, GitHub will donate your reward to an established 501(c)(3) charitable organization of your choice. GitHub will also match your donation - subject to our discretion. Any rewards that go unclaimed after 12 months will be donated to a charity of GitHub's choosing.\n\n\n## Scope\n\nGitHub runs a number of services but only submissions under the following domains are eligible for rewards. Any GitHub-owned domains not listed below are *not* in-scope, *not* eligible for rewards and *not* covered by our [legal safe harbor](https://bounty.github.com#legal_safe_harbor).\n\n\n### github.com\n\nOur main domain hosting user-facing GitHub services.. All subdomains under `github.com` are in-scope *except*:\n* `blog.github.com`\n* `community.github.com`\n* `email.enterprise.github.com`\n* `email.finance.github.com`\n* `email.staging.finance.github.com`\n* `email.support.github.com`\n* `email.verify.github.com`\n* `google7650dcf6146f04d8.github.com`\n* `k1._domainkey.github.com`\n* `k1._domainkey.mcmail.github.com`\n* `mcmail.github.com`\n* `resources.github.com`\n* `*.resources.github.com`\n* `sgmail.github.com`\n* `*.sgmail.github.com`\n* `shop.github.com`\n* `smtp.github.com`\n* `*.smtp.github.com`\n* `support.github.com`\n\n### githubassets.com\n\nOur domain for hosting static assets.. All subdomains under `githubassets.com` are in-scope\n\n### githubusercontent.com\n\nOur domain for hosting and rendering users' data.. All subdomains under `githubusercontent.com` are in-scope\n\n### githubapp.com\n\nOur domain for hosting employee-facing services.. All subdomains under `githubapp.com` are in-scope *except*:\n* `atom-io.githubapp.com`\n* `atom-io-staging.githubapp.com`\n* `email.enterprise-staging.githubapp.com`\n* `email.haystack.githubapp.com`\n* `reply.githubapp.com`\n\n### github.net\n\nOur domain for hosting GitHub's internal production services. Many of these services are not accessible from outside our internal network.. All subdomains under `github.net` are in-scope\n\n### semmle.com\n\nOur main domain for Semmle and LGTM services. All subdomains under `semmle.com` are in-scope *except*:\n* `dev.semmle.com`\n* `git.semmle.com`\n* `jira.semmle.com`\n* `wiki.semmle.com`\n\n### semmle.net\n\nOur domain for non-production Semmle services. All subdomains under `semmle.net` are in-scope\n\n### downloads.lgtm.com\n\nOur domain for serving LGTM downloads.. All subdomains under `downloads.lgtm.com` are in-scope\n\n### lgtm-com.pentesting.semmle.net\n\nAn instance of [LGTM](https://bounty.github.com/targets/lgtm.html) especially for Bug Bounty research.. All subdomains under `lgtm-com.pentesting.semmle.net` are in-scope\n\n### backend-dot-lgtm-penetration-testing.appspot.com\n\nAn instance of [LGTM](https://bounty.github.com/targets/lgtm.html)'s backend used for triggering automated tasks.. All subdomains under `backend-dot-lgtm-penetration-testing.appspot.com` are in-scope\n\n## Severity Guidelines\n\nAll bounty submissions are rated by GitHub using a purposefully simple scale. Each vulnerability is unique but the following is a rough guideline we use internally for rating and rewarding submissions:\n\n\n### Critical: $20,000 - $30,000\n\nCritical severity issues present a direct and immediate risk to a broad array of our users or to GitHub itself. They often affect relatively low-level/foundational components in one of our application stacks or infrastructure. For example:\n* arbitrary code/command execution on a GitHub server in our production network.\n* arbitrary SQL queries on the GitHub production database.\n* bypassing the GitHub login process, either password or 2FA.\n* access to sensitive production user data or access to internal production systems.\n* accessing another user's data in the GitHub Actions service.\n\nThe upper bound for critical vulnerabilities, $30,000, is only a guideline and GitHub may reward higher amounts for exceptional reports.\n\n\n### High: $10,000 - $20,000\n\nHigh severity issues allow an attacker to read or modify highly sensitive data that they are not authorized to access. They are generally more narrow in scope than critical issues, though they may still grant an attacker extensive access. For example:\n* injecting attacker controlled content into GitHub.com (XSS) which bypasses CSP.\n* bypassing authorization logic to grant a repository collaborator more access than intended.\n* discovering sensitive user or GitHub data in a publicly exposed resource, such as an S3 bucket.\n* gaining access to a non-critical resource that only GitHub employees should be able to reach.\n* using the GitHub Actions repo-scoped GitHub token to access high-risk private content outside of that repository.\n* code execution in a desktop app that requires no user interaction.\n\n\n### Medium: $4,000 - $10,000\n\nMedium severity issues allow an attacker to read or modify limited amounts of data that they are not authorized to access. They generally grant access to less sensitive information than high severity issues. For example:\n* disclosing the title of issues in private repositories which should be be inaccessible.\n* injecting attacker controlled content into GitHub.com (XSS) but not bypassing CSP or executing sensitive actions with another user's session.\n* bypassing CSRF validation for low risk actions, such as starring a repository or unsubscribing from a mailing list.\n* escaping the LGTM worker sandbox to access other user's data or private networked resources\n\n\n### Low: $617 - $2,000\n\nLow severity issues allow an attacker to access extremely limited amounts of data. They may violate an expectation for how something is intended to work, but it allows nearly no escalation of privilege or ability to trigger unintended behavior by an attacker. For example:\n* signing up arbitrary users for access to an \"early access feature\" without their consent.\n* creating an issue comment that bypasses our image proxying filter by providing a malformed URL.\n* bypassing community-and-safety features such as locked conversations.\n* bypassing billing \u0026 plan restrictions to gain access to paid features.\n* triggering verbose or debug error pages without proof of exploitability or obtaining sensitive information.\n* triggering application exceptions that could affect many GitHub users.\n* triggering XSS or CSRF vulnerabilities in LGTM\n\n","created_at":"2016-04-15T17:10:31.261Z","updated_at":"2020-04-08T13:45:49.548Z"}}},"severity":{"data":{"id":"809412","type":"severity","attributes":{"rating":"high","author_type":"User","user_id":291079,"created_at":"2020-08-04T18:34:42.970Z"}}},"swag":{"data":[]},"attachments":{"data":[{"id":"936424","type":"attachment","attributes":{"expiring_url":"https://hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com/jLM93BfL4CBDGfvwtEDVxY3b?response-content-disposition=attachment%3B%20filename%3D%222182_FtX8VdFq.jpg%22%3B%20filename%2A%3DUTF-8%27%272182_FtX8VdFq.jpg\u0026response-content-type=image%2Fjpeg\u0026X-Amz-Algorithm=AWS4-HMAC-SHA256\u0026X-Amz-Credential=ASIAQGK6FURQ2AEIVD2J%2F20200804%2Fus-west-2%2Fs3%2Faws4_request\u0026X-Amz-Date=20200804T202257Z\u0026X-Amz-Expires=3600\u0026X-Amz-SignedHeaders=host\u0026X-Amz-Security-Token=IQoJb3JpZ2luX2VjEOP%2F%2F%2F%2F%2F%2F%2F%2F%2F%2FwEaCXVzLXdlc3QtMiJGMEQCICMlILIy3UXTs86SekIOeH1QNW0fp0yM4%2B5SU3ERwvxEAiAlL8mRvFptX72G7EZHilb96S4xmiU37LbXIhpuPnFOEyq9Awis%2F%2F%2F%2F%2F%2F%2F%2F%2F%2F8BEAEaDDAxMzYxOTI3NDg0OSIMH3RzU0ZZUI%2B9xxcWKpEDAtFT%2FwHQGYecvhV7oJS1h4NBGvASgrV9WQsIfDyws69%2B3HKiIq8%2FBexub7rk9q%2F7q%2Bup6PObiG0TTLIphy5oZcDFk%2B4Bt0YIu3Ohg%2FFqADbvZHv31HTsFmISaPR%2BzDb2KddtwDJ33ah71C2tZ3BvHwGvFJpucJZUdircUEYM3uVP6ZnsCIs32CEpIjaMTJHREuT6O3bOXjW%2BTvhKGKoFrZakg4faijlxoiZr4NKIjFsPJtPDSE1Xb4kfqseIToL2YjQ93IR%2FWaJTnvza05vtH4LjF2tPsyWxOOjmbNojWgyL8xETWUWxphEAQ%2FyulgZR%2Bfb4kHbAF9Tjy7kpIuDqoLy64NbGsF8cX2zT%2BSaqIaam2MdJz0H97v22nYE2xo6tbiedUTJz57H03v6FiqnVpgk7czdKC2jjrbTFI80z8gatOeRgi5lSCPmFEvxzCrLWLF%2Bv8B0B7av0emCg9hcdV02DdyN9QIProi1pK6jL518QeX%2BWjIV4umCo5RqDiChJS547rx8fwndM22JlABmLxXkwuuOm%2BQU67AGen5nbLfqAVucmlxfWzxA8S9%2FGg24KZOYNR5e%2BZEoyG4saP32ga4W1X0wrpaZOuy%2F7YLeqDjSM214K8UQrvFd0K%2FGodUYpekQkvuZ8JNkZNqwXNzzs7Pu5G1fgUu2hA6wAvMbI7TEsZaxphW5ut4F5YVKvG8%2BTSJcE%2FVUIwPhKfalR0szGHDkHhH9j4RF2WDS2Fe1g8vAW9lrCCrCOgXa4eUp6g2KBcgXBysMt1o8RnJGBUJ9%2BCz6pClRCugDpjBERUuSwthlCjyFib6lTJaCffoKGz%2FS0PgnyoFh4XFk81%2B065srPOfj8prVn3g%3D%3D\u0026X-Amz-Signature=a6abd0dc897719da1bcba01c9a19c13ecabc027bf34a8f6df09d46da71001cc4","created_at":"2020-08-04T18:34:09.446Z","file_name":"2182_FtX8VdFq.jpg","content_type":"image/jpeg","file_size":653695}},{"id":"936425","type":"attachment","attributes":{"expiring_url":"https://hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com/NwhHZXSgRnoqibhBXNz9HxmN?response-content-disposition=attachment%3B%20filename%3D%22swagger_parse.py%22%3B%20filename%2A%3DUTF-8%27%27swagger_parse.py\u0026response-content-type=text%2Fx-python-script\u0026X-Amz-Algorithm=AWS4-HMAC-SHA256\u0026X-Amz-Credential=ASIAQGK6FURQ2AEIVD2J%2F20200804%2Fus-west-2%2Fs3%2Faws4_request\u0026X-Amz-Date=20200804T202257Z\u0026X-Amz-Expires=3600\u0026X-Amz-SignedHeaders=host\u0026X-Amz-Security-Token=IQoJb3JpZ2luX2VjEOP%2F%2F%2F%2F%2F%2F%2F%2F%2F%2FwEaCXVzLXdlc3QtMiJGMEQCICMlILIy3UXTs86SekIOeH1QNW0fp0yM4%2B5SU3ERwvxEAiAlL8mRvFptX72G7EZHilb96S4xmiU37LbXIhpuPnFOEyq9Awis%2F%2F%2F%2F%2F%2F%2F%2F%2F%2F8BEAEaDDAxMzYxOTI3NDg0OSIMH3RzU0ZZUI%2B9xxcWKpEDAtFT%2FwHQGYecvhV7oJS1h4NBGvASgrV9WQsIfDyws69%2B3HKiIq8%2FBexub7rk9q%2F7q%2Bup6PObiG0TTLIphy5oZcDFk%2B4Bt0YIu3Ohg%2FFqADbvZHv31HTsFmISaPR%2BzDb2KddtwDJ33ah71C2tZ3BvHwGvFJpucJZUdircUEYM3uVP6ZnsCIs32CEpIjaMTJHREuT6O3bOXjW%2BTvhKGKoFrZakg4faijlxoiZr4NKIjFsPJtPDSE1Xb4kfqseIToL2YjQ93IR%2FWaJTnvza05vtH4LjF2tPsyWxOOjmbNojWgyL8xETWUWxphEAQ%2FyulgZR%2Bfb4kHbAF9Tjy7kpIuDqoLy64NbGsF8cX2zT%2BSaqIaam2MdJz0H97v22nYE2xo6tbiedUTJz57H03v6FiqnVpgk7czdKC2jjrbTFI80z8gatOeRgi5lSCPmFEvxzCrLWLF%2Bv8B0B7av0emCg9hcdV02DdyN9QIProi1pK6jL518QeX%2BWjIV4umCo5RqDiChJS547rx8fwndM22JlABmLxXkwuuOm%2BQU67AGen5nbLfqAVucmlxfWzxA8S9%2FGg24KZOYNR5e%2BZEoyG4saP32ga4W1X0wrpaZOuy%2F7YLeqDjSM214K8UQrvFd0K%2FGodUYpekQkvuZ8JNkZNqwXNzzs7Pu5G1fgUu2hA6wAvMbI7TEsZaxphW5ut4F5YVKvG8%2BTSJcE%2FVUIwPhKfalR0szGHDkHhH9j4RF2WDS2Fe1g8vAW9lrCCrCOgXa4eUp6g2KBcgXBysMt1o8RnJGBUJ9%2BCz6pClRCugDpjBERUuSwthlCjyFib6lTJaCffoKGz%2FS0PgnyoFh4XFk81%2B065srPOfj8prVn3g%3D%3D\u0026X-Amz-Signature=99950d1402eeee7d2df10c68fcd4d8f4f84732885b5db2c2417842eb266d0a19","created_at":"2020-08-04T18:34:28.970Z","file_name":"swagger_parse.py","content_type":"text/x-python-script","file_size":482}}]},"weakness":{"data":{"id":"31","type":"weakness","attributes":{"name":"Brute Force","description":"The software does not implement sufficient measures to prevent multiple failed authentication attempts within in a short time frame, making it more susceptible to brute force attacks.","external_id":"cwe-307","created_at":"2017-01-05T01:51:19.000Z"}}},"structured_scope":{"data":{"id":"15455","type":"structured-scope","attributes":{"asset_type":"URL","asset_identifier":"render.github.com","eligible_for_bounty":true,"eligible_for_submission":true,"instruction":"","max_severity":"critical","created_at":"2018-10-10T00:40:51.479Z","updated_at":"2018-10-10T00:40:51.479Z","reference":"","confidentiality_requirement":"medium","integrity_requirement":"medium","availability_requirement":"low"}}},"activities":{"data":[{"type":"activity-bug-resolved","id":"8848231","attributes":{"message":"","created_at":"2020-08-04T20:22:57.217Z","updated_at":"2020-08-04T20:22:57.217Z","internal":false},"relationships":{"actor":{"data":{"id":"1273903","type":"user","attributes":{"username":"rzhade3-tester","name":null,"disabled":false,"created_at":"2020-08-04T06:26:42.491Z","profile_picture":{"62x62":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","82x82":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","110x110":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","260x260":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png"},"signal":null,"impact":null,"reputation":null,"bio":null,"website":null,"location":null,"hackerone_triager":false}}}}}]},"bounties":{"data":[]},"summaries":{"data":[]},"custom_field_values":{"data":[]}}}}
79
+ recorded_at: Tue, 04 Aug 2020 20:22:57 GMT
80
+ - request:
81
+ method: put
82
+ uri: https://api.hackerone.com/v1/reports/200/close_comments
83
+ body:
84
+ encoding: UTF-8
85
+ string: '{"data":{"type":"activity-comments-closed"}}'
86
+ headers:
87
+ Authorization:
88
+ - Basic NOPE=
89
+ User-Agent:
90
+ - Faraday v1.0.1
91
+ Content-Type:
92
+ - application/json
93
+ Accept-Encoding:
94
+ - gzip;q=1.0,deflate;q=0.6,identity;q=0.3
95
+ Accept:
96
+ - "*/*"
97
+ response:
98
+ status:
99
+ code: 200
100
+ message: OK
101
+ headers:
102
+ Date:
103
+ - Tue, 04 Aug 2020 20:22:58 GMT
104
+ Content-Type:
105
+ - application/json; charset=utf-8
106
+ Transfer-Encoding:
107
+ - chunked
108
+ Connection:
109
+ - keep-alive
110
+ Set-Cookie:
111
+ - __cfduid=d2984afa39f16a0fa59898d5a119139eb1596572577; expires=Thu, 03-Sep-20
112
+ 20:22:57 GMT; path=/; Domain=api.hackerone.com; HttpOnly; SameSite=Lax; Secure
113
+ X-Request-Id:
114
+ - cfc4b577-2ac0-4466-9018-821da6d76939
115
+ Etag:
116
+ - W/"f008fe54d1f034fdb39ac356b76f029e"
117
+ Cache-Control:
118
+ - max-age=0, private, must-revalidate
119
+ Strict-Transport-Security:
120
+ - max-age=31536000; includeSubDomains; preload
121
+ X-Frame-Options:
122
+ - DENY
123
+ X-Content-Type-Options:
124
+ - nosniff
125
+ X-Xss-Protection:
126
+ - 1; mode=block
127
+ X-Download-Options:
128
+ - noopen
129
+ X-Permitted-Cross-Domain-Policies:
130
+ - none
131
+ Referrer-Policy:
132
+ - strict-origin-when-cross-origin
133
+ Expect-Ct:
134
+ - enforce, max-age=86400
135
+ Content-Security-Policy:
136
+ - 'default-src ''none''; base-uri ''self''; block-all-mixed-content; child-src
137
+ www.youtube-nocookie.com; connect-src ''self'' www.google-analytics.com errors.hackerone.net;
138
+ font-src ''self''; form-action ''self''; frame-ancestors ''none''; img-src
139
+ ''self'' data: cover-photos.hackerone-user-content.com hackathon-photos.hackerone-user-content.com
140
+ profile-photos.hackerone-user-content.com hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
141
+ media-src ''self'' hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
142
+ script-src ''self'' www.google-analytics.com; style-src ''self'' ''unsafe-inline'';
143
+ report-uri https://errors.hackerone.net/api/30/csp-report/?sentry_key=61c1e2f50d21487c97a071737701f598'
144
+ Cf-Cache-Status:
145
+ - DYNAMIC
146
+ Cf-Request-Id:
147
+ - 045cbd479000000293bd38e200000001
148
+ Server:
149
+ - cloudflare
150
+ Cf-Ray:
151
+ - 5bdafe528d570293-SJC
152
+ body:
153
+ encoding: ASCII-8BIT
154
+ string: '{"data":{"type":"activity-comments-closed","id":"8848232","attributes":{"message":"","created_at":"2020-08-04T20:22:57.889Z","updated_at":"2020-08-04T20:22:57.889Z","internal":false},"relationships":{"actor":{"data":{"id":"1273903","type":"user","attributes":{"username":"rzhade3-tester","name":null,"disabled":false,"created_at":"2020-08-04T06:26:42.491Z","profile_picture":{"62x62":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","82x82":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","110x110":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","260x260":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png"},"signal":null,"impact":null,"reputation":null,"bio":null,"website":null,"location":null,"hackerone_triager":false}}}}}}'
155
+ recorded_at: Tue, 04 Aug 2020 20:22:58 GMT
156
+ recorded_with: VCR 6.0.0
@@ -191,7 +191,28 @@ http_interactions:
191
191
  },
192
192
  "attachments": {
193
193
  "data": [
194
-
194
+ {
195
+ "id": "936424",
196
+ "type": "attachment",
197
+ "attributes": {
198
+ "expiring_url": "https://redacted.aws.s3.link",
199
+ "created_at": "2020-08-04T18:34:09.446Z",
200
+ "file_name": "2182_FtX8VdFq.jpg",
201
+ "content_type": "image/jpeg",
202
+ "file_size": 653695
203
+ }
204
+ },
205
+ {
206
+ "id": "936425",
207
+ "type": "attachment",
208
+ "attributes": {
209
+ "expiring_url": "https://redacted.aws.s3.link",
210
+ "created_at": "2020-08-04T18:34:28.970Z",
211
+ "file_name": "swagger_parse.py",
212
+ "content_type": "text/x-python-script",
213
+ "file_size": 482
214
+ }
215
+ }
195
216
  ]
196
217
  },
197
218
  "vulnerability_types": {
@@ -0,0 +1,77 @@
1
+ ---
2
+ http_interactions:
3
+ - request:
4
+ method: get
5
+ uri: https://api.hackerone.com/v1/reports?filter%5Bcreated_at__gt%5D=2017-02-11T16:00:44-10:00&filter%5Bprogram%5D%5B0%5D=github&filter%5Bstate%5D%5B0%5D=triaged
6
+ body:
7
+ encoding: US-ASCII
8
+ string: ''
9
+ headers:
10
+ Authorization:
11
+ - Basic NOPE
12
+ User-Agent:
13
+ - Faraday v1.0.0
14
+ Accept-Encoding:
15
+ - gzip;q=1.0,deflate;q=0.6,identity;q=0.3
16
+ Accept:
17
+ - "*/*"
18
+ response:
19
+ status:
20
+ code: 200
21
+ message: OK
22
+ headers:
23
+ Date:
24
+ - Tue, 24 Mar 2020 14:11:47 GMT
25
+ Content-Type:
26
+ - application/json; charset=utf-8
27
+ Transfer-Encoding:
28
+ - chunked
29
+ Connection:
30
+ - keep-alive
31
+ Set-Cookie:
32
+ - __cfduid=dabd0c152e7e92db1c896d18efb3473911585059107; expires=Thu, 23-Apr-20
33
+ 14:11:47 GMT; path=/; Domain=api.hackerone.com; HttpOnly; SameSite=Lax; Secure
34
+ X-Request-Id:
35
+ - 5ead5fa1-86fb-4b8f-ae8b-755d0b08b40c
36
+ Etag:
37
+ - W/"a9d3a797dc03972084547d21d1a4ebcd"
38
+ Cache-Control:
39
+ - max-age=0, private, must-revalidate
40
+ Strict-Transport-Security:
41
+ - max-age=31536000; includeSubDomains; preload
42
+ X-Frame-Options:
43
+ - DENY
44
+ X-Content-Type-Options:
45
+ - nosniff
46
+ X-Xss-Protection:
47
+ - 1; mode=block
48
+ X-Download-Options:
49
+ - noopen
50
+ X-Permitted-Cross-Domain-Policies:
51
+ - none
52
+ Referrer-Policy:
53
+ - strict-origin-when-cross-origin
54
+ Expect-Ct:
55
+ - enforce, max-age=86400
56
+ Content-Security-Policy:
57
+ - 'default-src ''none''; base-uri ''self''; block-all-mixed-content; child-src
58
+ www.youtube-nocookie.com; connect-src ''self'' www.google-analytics.com errors.hackerone.net;
59
+ font-src ''self''; form-action ''self''; frame-ancestors ''none''; img-src
60
+ ''self'' data: cover-photos.hackerone-user-content.com hackathon-photos.hackerone-user-content.com
61
+ profile-photos.hackerone-user-content.com hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
62
+ media-src ''self'' hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
63
+ script-src ''self'' www.google-analytics.com; style-src ''self'' ''unsafe-inline'';
64
+ report-uri https://errors.hackerone.net/api/30/csp-report/?sentry_key=61c1e2f50d21487c97a071737701f598'
65
+ Cf-Cache-Status:
66
+ - DYNAMIC
67
+ Server:
68
+ - cloudflare
69
+ Cf-Ray:
70
+ - 5790fbbbb977e4d8-ATL
71
+ body:
72
+ encoding: ASCII-8BIT
73
+ string: !binary |-
74
+ {"data":[{"id":"815099","type":"report","attributes":{"title":"Jal","state":"triaged","created_at":"2020-03-09T14:45:32.741Z","vulnerability_information":"Kal\n\n## Impact\n\nLal","triaged_at":"2020-03-24T14:11:37.712Z","closed_at":null,"last_reporter_activity_at":"2020-03-24T14:11:37.712Z","first_program_activity_at":"2020-03-09T14:45:32.796Z","last_program_activity_at":"2020-03-24T14:11:37.712Z","bounty_awarded_at":null,"swag_awarded_at":null,"disclosed_at":null,"reporter_agreed_on_going_public_at":null,"last_public_activity_at":"2020-03-24T14:11:37.712Z","last_activity_at":"2020-03-24T14:11:37.712Z","source":null},"relationships":{"reporter":{"data":{"id":"291079","type":"user","attributes":{"username":"rzhade3","name":"Rahul Zhade","disabled":false,"created_at":"2018-06-12T17:43:40.852Z","profile_picture":{"62x62":"https://profile-photos.hackerone-user-content.com/variants/000/291/079/b79c3c343130bd631131f690e2f04bc0d1fde8bf_original.png/3afcb5c896247e7ee8ada31b1c1eb8657e22241f911093acfe4ec7e97a3a959a","82x82":"https://profile-photos.hackerone-user-content.com/variants/000/291/079/b79c3c343130bd631131f690e2f04bc0d1fde8bf_original.png/eb31823a4cc9f6b6bb4db930ffdf512533928a68a4255fb50a83180281a60da5","110x110":"https://profile-photos.hackerone-user-content.com/variants/000/291/079/b79c3c343130bd631131f690e2f04bc0d1fde8bf_original.png/692237eb9691fbde92a17174cdb809a788ace02bc77c72803f17d32b41e4f213","260x260":"https://profile-photos.hackerone-user-content.com/variants/000/291/079/b79c3c343130bd631131f690e2f04bc0d1fde8bf_original.png/cf1e4b5d44005cb61fab358dd6968415f20545de5f055ba4ed33ca4387948cdc"},"bio":"Application Security @GitHub","website":"https://zhade.dev","location":"","hackerone_triager":false}}},"assignee":{"data":{"id":"85049","type":"user","attributes":{"username":"brentjo-gh","name":"Brent Johnson","disabled":false,"created_at":"2016-06-14T20:01:30.891Z","profile_picture":{"62x62":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","82x82":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","110x110":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png","260x260":"/assets/avatars/default-71a302d706457f3d3a31eb30fa3e73e6cf0b1d677b8fa218eaeaffd67ae97918.png"},"signal":null,"impact":null,"reputation":null,"bio":"","website":null,"location":"","hackerone_triager":false}}},"program":{"data":{"id":"11767","type":"program","attributes":{"handle":"github-test","policy":"# GitHub Test Bug Bounty\r\n\r\nSoftware security researchers are increasingly engaging with Internet companies to hunt down vulnerabilities. Our bounty program gives a tip of the hat to these researchers and provides rewards of  $30,000 or more for critical vulnerabilities.\r\n\r\n\r\nYou can find more information in our [rules](https://bounty.github.com/#rules), [scope](https://bounty.github.com/#scope), [targets](https://bounty.github.com/#targets), and [FAQ](https://bounty.github.com/#faqs) sections. You can also check the current rankings on the [leaderboard](https://bounty.github.com/#leaderboard).\r\n\r\nHappy hacking!\r\n\r\n\r\n## Rules\r\n\r\n### Before you start\r\n\r\n* Check the list of bugs that have been [classified as ineligible](https://bounty.github.com/ineligible.html). Submissions which are ineligible will likely be closed as `Not Applicable`.\r\n* Check the [GitHub Changelog](https://github.blog/changelog/) for recently launched features.\r\n* Never attempt non-technical attacks such as social engineering, phishing, or physical attacks against our employees, users, or infrastructure.\r\n* When in doubt, contact us at `bounty@github.com`.\r\n* By participating in GitHub's Bug Bounty program (the \"Program\"), you acknowledge that you have read and agree to GitHub's [Terms of Service](https://help.github.com/articles/github-terms-of-service) as well as the following:\r\n\r\n  * you're not participating from a country against which the United States has issued export sanctions or other trade restrictions, including Cuba, Iran, North Korea, Sudan, and Syria.\r\n\r\n  * your participation in the Program will not violate any law applicable to you, or disrupt or compromise any data that is not your own.\r\n\r\n  * you are solely responsible for any applicable taxes, withholding or otherwise, arising from or relating to your participation in the Program, including from any bounty payments.\r\n\r\n  * GitHub reserves the right to terminate or discontinue the Program at its discretion.\r\n\r\n  * Only test for vulnerabilities on sites you know to be operated by GitHub and are [in-scope](https://bounty.github.com#scope). Some sites hosted on subdomains of `GitHub.com` are operated by third parties and should not be tested.\r\n\r\n\r\n### Legal safe harbor\r\n\r\nYour research is covered by the [GitHub Bug Bounty Program Legal Safe Harbor](https://help.github.com/articles/github-bug-bounty-program-legal-safe-harbor/) policy. In summary:\r\n* We consider security research and vulnerability disclosure activities conducted consistent with this policy as “authorized” conduct under the Computer Fraud and Abuse Act, the DMCA, and other applicable computer use laws such as Cal. Penal Code 502(c). We waive any potential DMCA claim against you for circumventing the technological measures we have used to protect the applications in this bug bounty program's scope.\r\n* We want you to responsibly disclose through our bug bounty program, and don't want researchers put in fear of legal consequences because of their good faith attempts to comply with our bug bounty policy. We cannot bind any third party, so do not assume this protection extends to any third party. If in doubt, ask us before engaging in any specific action you think might go outside the bounds of our policy.\r\n* Because both identifying and non-identifying information can put a researcher at risk, we limit what we share with third parties. We may provide non-identifying substantive information from your report to an affected third party, but only after notifying you and receiving a commitment that the third party will not pursue legal action against you. We will only share identifying information (name, email address, phone number, etc.) with a third party if you give your written permission.\r\n* If your security research as part of the bug bounty program violates certain restrictions in our site policies, the safe harbor terms permit a limited exemption.\r\n\r\n\r\n### Performing your research\r\n\r\n* Do not impact other users with your testing, this includes testing vulnerabilities in repositories or organizations you do not own. If you are attempting to find an authorization bypass, you must use accounts you own.\r\n* The following are **never** allowed and are ineligible for reward. We may suspend your GitHub account and ban your IP address for:\r\n\r\n  * Performing distributed denial of service (DDoS) or other volumetric attacks\r\n  * Spamming content\r\n  * Large-scale vulnerability scanners, scrapers, or automated tools which produce excessive amounts of traffic.\r\n    * Note: We _do_ allow the use of automated tools so long as they do not produce excessive amounts of traffic. For example, running one `nmap` scan against one host is allowed, but sending 65,000 requests in two minutes using Burp Suite Intruder is excessive.\r\n* Researching denial-of-service attacks is allowed and eligible for rewards only if you follow these rules:\r\n\r\n  * Research **must** be performed in organizations or repositories you own\r\n  * Stop **immediately** if you believe you have affected the availability of our services. Don't worry about demonstrating the full impact of your vulnerability, GitHub's security team will be able to determine the impact.\r\n  * There are no limits for researching denial of service vulnerabilities against your own instance of [GitHub Enterprise Server](https://bounty.github.com/targets/github-enterprise-server.html)\r\n\r\n\r\n### Handling personally identifiable information (PII)\r\n\r\n* Personally identifying information (PII) includes:\r\n  * legal and/or full names\r\n  * names or usernames combined with other identifiers like phone numbers or email addresses\r\n  * health or financial information (including insurance information, social security numbers, etc.)\r\n  * information about political or religious affiliations\r\n  * information about race, ethnicity, sexual orientation, gender, or other identifying information that could be used for discriminatory purposes\r\n* Do not intentionally access others' PII. If you suspect a service provides access to PII, limit queries to your own personal information.\r\n* Report the vulnerability *immediately* and do not attempt to access any other data. The GitHub Security team will assess the scope and impact of the PII exposure.\r\n* Limit the amount of data returned from services. For SQL injection, for example, limit the number of rows returned\r\n* You must delete all your local, stored, or cached copies of data containing PII as soon as possible. We may ask you to sign a certificate of deletion and confidentiality agreement regarding the exact information you accessed. This agreement will not affect your bounty reward.\r\n* We may ask you for the usernames and IP addresses used during your testing to assess the impact of the vulnerability\r\n\r\n\r\n### Reporting your vulnerability\r\n\r\n* Submissions must include written instructions for reproducing the vulnerability. Submissions without clear reproduction steps or which only include reproduction steps in video form may be ineligible for a reward.\r\n* When reporting vulnerabilities you must keep all information on HackerOne. Do not post information to video-sharing or pastebin sites. Videos and images can be uploaded directly via HackerOne.\r\n* For vulnerabilities involving personally identifiable information, please explain the kind of PII you believe is exposed and limit the amount of PII data included in your submissions. For textual information and screenshots, please only include redacted data in your submission.\r\n* Do not publicly disclose your submission until GitHub has evaluated the impact.\r\n\r\n\r\n### Receiving your award\r\n\r\n* All reward amounts are determined by our [severity guidelines](https://bounty.github.com/#severity-guidelines).\r\n* When duplicates occur, we only award the first report that was received (provided that it can be fully reproduced).\r\n* You are free to publish write-ups about your vulnerability and GitHub will not limit what you write. We may pay out your reward before the vulnerability is patched so we may ask that you delay publishing to keep other GitHub users safe.\r\n* Medium, high, and critical severity issues will be written up on the GitHub Bug Bounty site and included in our leaderboard. We don't currently post write-ups for low severity vulnerabilities.\r\n* You may prefer the reward go toward helping others. If you choose so, GitHub will donate your reward to an established 501(c)(3) charitable organization of your choice. GitHub will also match your donation - subject to our discretion. Any rewards that go unclaimed after 12 months will be donated to a charity of GitHub's choosing.\r\n\r\n\r\n## Scope\r\n\r\nGitHub runs a number of services but only submissions under the following domains are eligible for rewards. Any GitHub-owned domains not listed below are *not* in-scope, *not* eligible for rewards and *not* covered by our [legal safe harbor](https://bounty.github.com#legal_safe_harbor).\r\n\r\n\r\n### github.com\r\n\r\nOur main domain hosting user-facing GitHub services.. All subdomains under `github.com` are in-scope *except*:\r\n* `blog.github.com`\r\n* `community.github.com`\r\n* `email.enterprise.github.com`\r\n* `email.finance.github.com`\r\n* `email.staging.finance.github.com`\r\n* `email.support.github.com`\r\n* `email.verify.github.com`\r\n* `google7650dcf6146f04d8.github.com`\r\n* `k1._domainkey.github.com`\r\n* `k1._domainkey.mcmail.github.com`\r\n* `mcmail.github.com`\r\n* `resources.github.com`\r\n* `*.resources.github.com`\r\n* `sgmail.github.com`\r\n* `*.sgmail.github.com`\r\n* `shop.github.com`\r\n* `smtp.github.com`\r\n* `*.smtp.github.com`\r\n* `support.github.com`\r\n\r\n### githubassets.com\r\n\r\nOur domain for hosting static assets.. All subdomains under `githubassets.com` are in-scope\r\n\r\n### githubusercontent.com\r\n\r\nOur domain for hosting and rendering users' data.. All subdomains under `githubusercontent.com` are in-scope\r\n\r\n### githubapp.com\r\n\r\nOur domain for hosting employee-facing services.. All subdomains under `githubapp.com` are in-scope *except*:\r\n* `atom-io.githubapp.com`\r\n* `atom-io-staging.githubapp.com`\r\n* `email.enterprise-staging.githubapp.com`\r\n* `email.haystack.githubapp.com`\r\n* `reply.githubapp.com`\r\n\r\n### github.net\r\n\r\nOur domain for hosting GitHub's internal production services. Many of these services are not accessible from outside our internal network.. All subdomains under `github.net` are in-scope\r\n\r\n### semmle.com\r\n\r\nOur main domain for Semmle and LGTM services. All subdomains under `semmle.com` are in-scope *except*:\r\n* `dev.semmle.com`\r\n* `git.semmle.com`\r\n* `jira.semmle.com`\r\n* `wiki.semmle.com`\r\n\r\n### semmle.net\r\n\r\nOur domain for non-production Semmle services. All subdomains under `semmle.net` are in-scope\r\n\r\n### downloads.lgtm.com\r\n\r\nOur domain for serving LGTM downloads.. All subdomains under `downloads.lgtm.com` are in-scope\r\n\r\n### lgtm-com.pentesting.semmle.net\r\n\r\nAn instance of [LGTM](https://bounty.github.com/targets/lgtm.html) especially for Bug Bounty research.. All subdomains under `lgtm-com.pentesting.semmle.net` are in-scope\r\n\r\n### backend-dot-lgtm-penetration-testing.appspot.com\r\n\r\nAn instance of [LGTM](https://bounty.github.com/targets/lgtm.html)'s backend used for triggering automated tasks.. All subdomains under `backend-dot-lgtm-penetration-testing.appspot.com` are in-scope\r\n\r\n## Severity Guidelines\r\n\r\nAll bounty submissions are rated by GitHub using a purposefully simple scale. Each vulnerability is unique but the following is a rough guideline we use internally for rating and rewarding submissions:\r\n\r\n\r\n### Critical: $20,000 - $30,000\r\n\r\nCritical severity issues present a direct and immediate risk to a broad array of our users or to GitHub itself. They often affect relatively low-level/foundational components in one of our application stacks or infrastructure. For example:\r\n* arbitrary code/command execution on a GitHub server in our production network.\r\n* arbitrary SQL queries on the GitHub production database.\r\n* bypassing the GitHub login process, either password or 2FA.\r\n* access to sensitive production user data or access to internal production systems.\r\n* accessing another user's data in the GitHub Actions service.\r\n\r\nThe upper bound for critical vulnerabilities, $30,000, is only a guideline and GitHub may reward higher amounts for exceptional reports.\r\n\r\n\r\n### High: $10,000 - $20,000\r\n\r\nHigh severity issues allow an attacker to read or modify highly sensitive data that they are not authorized to access. They are generally more narrow in scope than critical issues, though they may still grant an attacker extensive access. For example:\r\n* injecting attacker controlled content into GitHub.com (XSS) which bypasses CSP.\r\n* bypassing authorization logic to grant a repository collaborator more access than intended.\r\n* discovering sensitive user or GitHub data in a publicly exposed resource, such as an S3 bucket.\r\n* gaining access to a non-critical resource that only GitHub employees should be able to reach.\r\n* using the GitHub Actions repo-scoped GitHub token to access high-risk private content outside of that repository.\r\n* code execution in a desktop app that requires no user interaction.\r\n\r\n\r\n### Medium: $4,000 - $10,000\r\n\r\nMedium severity issues allow an attacker to read or modify limited amounts of data that they are not authorized to access. They generally grant access to less sensitive information than high severity issues. For example:\r\n* disclosing the title of issues in private repositories which should be be inaccessible.\r\n* injecting attacker controlled content into GitHub.com (XSS) but not bypassing CSP or executing sensitive actions with another user's session.\r\n* bypassing CSRF validation for low risk actions, such as starring a repository or unsubscribing from a mailing list.\r\n* escaping the LGTM worker sandbox to access other user's data or private networked resources\r\n\r\n\r\n### Low: $617 - $2,000\r\n\r\nLow severity issues allow an attacker to access extremely limited amounts of data. They may violate an expectation for how something is intended to work, but it allows nearly no escalation of privilege or ability to trigger unintended behavior by an attacker. For example:\r\n* signing up arbitrary users for access to an \"early access feature\" without their consent.\r\n* creating an issue comment that bypasses our image proxying filter by providing a malformed URL.\r\n* bypassing community-and-safety features such as locked conversations.\r\n* bypassing billing & plan restrictions to gain access to paid features.\r\n* triggering verbose or debug error pages without proof of exploitability or obtaining sensitive information.\r\n* triggering application exceptions that could affect many GitHub users.\r\n* triggering XSS or CSRF vulnerabilities in LGTM\r\n","created_at":"2016-04-15T17:10:31.261Z","updated_at":"2020-03-09T20:24:52.418Z"}}},"weakness":{"data":{"id":"9","type":"weakness","attributes":{"name":"Buffer Over-read","description":"The software reads from a buffer using buffer access mechanisms such as indexes or pointers that reference memory locations after the targeted buffer.","external_id":"cwe-126","created_at":"2017-01-05T01:51:19.000Z"}}},"structured_scope":{"data":{"id":"15455","type":"structured-scope","attributes":{"asset_type":"URL","asset_identifier":"render.github.com","eligible_for_bounty":true,"eligible_for_submission":true,"instruction":"","max_severity":"critical","created_at":"2018-10-10T00:40:51.479Z","updated_at":"2018-10-10T00:40:51.479Z","reference":"","confidentiality_requirement":"medium","integrity_requirement":"medium","availability_requirement":"low"}}},"bounties":{"data":[]},"custom_field_values":{"data":[]}}}],"links":{}}
75
+ http_version: null
76
+ recorded_at: Tue, 24 Mar 2020 14:11:47 GMT
77
+ recorded_with: VCR 5.1.0
@@ -0,0 +1,78 @@
1
+ ---
2
+ http_interactions:
3
+ - request:
4
+ method: post
5
+ uri: https://api.hackerone.com/v1/reports/200/severities
6
+ body:
7
+ encoding: UTF-8
8
+ string: '{"data":{"type":"severity","attributes":{"rating":"high"}}}'
9
+ headers:
10
+ Authorization:
11
+ - Basic NOPE
12
+ User-Agent:
13
+ - Faraday v1.0.0
14
+ Content-Type:
15
+ - application/json
16
+ Accept-Encoding:
17
+ - gzip;q=1.0,deflate;q=0.6,identity;q=0.3
18
+ Accept:
19
+ - "*/*"
20
+ response:
21
+ status:
22
+ code: 200
23
+ message: OK
24
+ headers:
25
+ Date:
26
+ - Mon, 23 Mar 2020 22:11:50 GMT
27
+ Content-Type:
28
+ - application/json; charset=utf-8
29
+ Transfer-Encoding:
30
+ - chunked
31
+ Connection:
32
+ - keep-alive
33
+ Set-Cookie:
34
+ - __cfduid=defc457f4849bd5da92f0d0a9e21f70cf1585001510; expires=Wed, 22-Apr-20
35
+ 22:11:50 GMT; path=/; Domain=api.hackerone.com; HttpOnly; SameSite=Lax; Secure
36
+ X-Request-Id:
37
+ - bc58a27f-3140-4457-b7b0-12a3c86f4f03
38
+ Etag:
39
+ - W/"30c2790e73edc770a9ed3fea69f0e8ea"
40
+ Cache-Control:
41
+ - max-age=0, private, must-revalidate
42
+ Strict-Transport-Security:
43
+ - max-age=31536000; includeSubDomains; preload
44
+ X-Frame-Options:
45
+ - DENY
46
+ X-Content-Type-Options:
47
+ - nosniff
48
+ X-Xss-Protection:
49
+ - 1; mode=block
50
+ X-Download-Options:
51
+ - noopen
52
+ X-Permitted-Cross-Domain-Policies:
53
+ - none
54
+ Referrer-Policy:
55
+ - strict-origin-when-cross-origin
56
+ Expect-Ct:
57
+ - enforce, max-age=86400
58
+ Content-Security-Policy:
59
+ - 'default-src ''none''; base-uri ''self''; block-all-mixed-content; child-src
60
+ www.youtube-nocookie.com; connect-src ''self'' www.google-analytics.com errors.hackerone.net;
61
+ font-src ''self''; form-action ''self''; frame-ancestors ''none''; img-src
62
+ ''self'' data: cover-photos.hackerone-user-content.com hackathon-photos.hackerone-user-content.com
63
+ profile-photos.hackerone-user-content.com hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
64
+ media-src ''self'' hackerone-us-west-2-production-attachments.s3.us-west-2.amazonaws.com;
65
+ script-src ''self'' www.google-analytics.com; style-src ''self'' ''unsafe-inline'';
66
+ report-uri https://errors.hackerone.net/api/30/csp-report/?sentry_key=61c1e2f50d21487c97a071737701f598'
67
+ Cf-Cache-Status:
68
+ - DYNAMIC
69
+ Server:
70
+ - cloudflare
71
+ Cf-Ray:
72
+ - 578b7d8e9faa3856-ATL
73
+ body:
74
+ encoding: ASCII-8BIT
75
+ string: '{"data":{"id":"668494","type":"severity","attributes":{"rating":"high","author_type":"Team","user_id":983615,"created_at":"2020-03-23T22:11:50.360Z"}}}'
76
+ http_version: null
77
+ recorded_at: Mon, 23 Mar 2020 22:11:50 GMT
78
+ recorded_with: VCR 5.1.0
@@ -14,8 +14,11 @@ require_relative "client/group"
14
14
  require_relative "client/structured_scope"
15
15
  require_relative "client/swag"
16
16
  require_relative "client/address"
17
+ require_relative "client/attachment"
17
18
  require_relative "client/bounty"
18
19
  require_relative "client/incremental/activities"
20
+ require_relative "client/billing_balance"
21
+ require "active_support/core_ext/hash"
19
22
 
20
23
  module HackerOne
21
24
  module Client
@@ -28,6 +31,17 @@ module HackerOne
28
31
 
29
32
  LENIENT_MODE_ENV_VARIABLE = "HACKERONE_CLIENT_LENIENT_MODE"
30
33
 
34
+ REPORT_STATES = %w(
35
+ new
36
+ triaged
37
+ needs-more-info
38
+ resolved
39
+ not-applicable
40
+ informative
41
+ duplicate
42
+ spam
43
+ )
44
+
31
45
  class << self
32
46
  ATTRS = [:low_range, :medium_range, :high_range, :critical_range].freeze
33
47
  attr_accessor :program
@@ -66,17 +80,20 @@ module HackerOne
66
80
  end
67
81
  end
68
82
 
69
- ## Returns all open reports, optionally with a time bound
83
+ ## Returns all reports in a given state, optionally with a time bound
70
84
  #
71
85
  # program: the HackerOne program to search on (configure globally with Hackerone::Client.program=)
72
86
  # since (optional): a time bound, don't include reports earlier than +since+. Must be a DateTime object.
87
+ # state (optional): state that a report is in, by default new
73
88
  #
74
89
  # returns all open reports or an empty array
75
- def reports(since: 3.days.ago)
90
+ def reports(since: 3.days.ago, state: :new)
76
91
  raise ArgumentError, "Program cannot be nil" unless program
92
+ raise ArgumentError, "State is invalid" unless REPORT_STATES.include?(state.to_s)
93
+
77
94
  response = self.class.hackerone_api_connection.get do |req|
78
95
  options = {
79
- "filter[state][]" => "new",
96
+ "filter[state][]" => state,
80
97
  "filter[program][]" => program,
81
98
  "filter[created_at__gt]" => since.iso8601
82
99
  }
@@ -90,6 +107,35 @@ module HackerOne
90
107
  end
91
108
  end
92
109
 
110
+ ## Public: create a new report
111
+ #
112
+ # title: The title of the report
113
+ # summary: Summary of the report
114
+ # impact: Impact of the report
115
+ # severity_rating: severity of report, must be one of https://api.hackerone.com/reference/#severity-ratings
116
+ # source: where the report came from, i.e. API, Bugcrowd, etc.
117
+ #
118
+ # returns an HackerOne::Client::Report object or raises an error if
119
+ # error during creation
120
+ def create_report(title:, summary:, impact:, severity_rating:, source:)
121
+ raise ArgumentError, "Program cannot be nil" unless program
122
+
123
+ data = {
124
+ "data": {
125
+ "type": "report",
126
+ "attributes": {
127
+ "team_handle": program,
128
+ "title": title,
129
+ "vulnerability_information": summary,
130
+ "impact": impact,
131
+ "severity_rating": severity_rating,
132
+ "source": source
133
+ }
134
+ }
135
+ }
136
+ Report.new(post("reports", data))
137
+ end
138
+
93
139
  ## Public: retrieve a report
94
140
  #
95
141
  # id: the ID of a specific report
@@ -15,6 +15,12 @@ module HackerOne
15
15
  attributes.internal
16
16
  end
17
17
 
18
+ def attachments
19
+ @attachments ||= activity.relationships.fetch(:attachments, {})
20
+ .fetch(:data, [])
21
+ .map { |attachment| HackerOne::Client::Attachment.new(attachment) }
22
+ end
23
+
18
24
  private
19
25
 
20
26
  def relationships
@@ -85,6 +91,9 @@ module HackerOne
85
91
  delegate :message, :bounty_amount, :bonus_amount, to: :attributes
86
92
  end
87
93
 
94
+ class ReportLocked < Activity
95
+ end
96
+
88
97
  ACTIVITY_TYPE_CLASS_MAPPING = {
89
98
  "activity-bounty-awarded" => BountyAwarded,
90
99
  "activity-swag-awarded" => SwagAwarded,
@@ -93,7 +102,8 @@ module HackerOne
93
102
  "activity-bug-triaged" => BugTriaged,
94
103
  "activity-reference-id-added" => ReferenceIdAdded,
95
104
  "activity-comment" => CommentAdded,
96
- "activity-bounty-suggested" => BountySuggested
105
+ "activity-bounty-suggested" => BountySuggested,
106
+ "activity-comments-closed" => ReportLocked
97
107
  }.freeze
98
108
 
99
109
  def self.build(activity_data)
@@ -0,0 +1,24 @@
1
+ # frozen_string_literal: true
2
+
3
+ module HackerOne
4
+ module Client
5
+ class Attachment
6
+ delegate :expiring_url, :file_name, :content_type, :created_at, \
7
+ :file_size, to: :attributes
8
+
9
+ def initialize(attachment)
10
+ @attachment = attachment
11
+ end
12
+
13
+ def id
14
+ @attachment[:id]
15
+ end
16
+
17
+ private
18
+
19
+ def attributes
20
+ OpenStruct.new(@attachment[:attributes])
21
+ end
22
+ end
23
+ end
24
+ end
@@ -0,0 +1,18 @@
1
+ # frozen_string_literal: true
2
+
3
+ module HackerOne
4
+ module Client
5
+ class BillingBalance
6
+ delegate :balance, to: :attributes
7
+
8
+ def initialize(billing_balance)
9
+ @billing_balance = OpenStruct.new billing_balance
10
+ end
11
+
12
+ private
13
+ def attributes
14
+ OpenStruct.new(@billing_balance[:attributes])
15
+ end
16
+ end
17
+ end
18
+ end
@@ -76,6 +76,13 @@ module HackerOne
76
76
  response_body.map { |r| Swag.new(r, self) }
77
77
  end
78
78
 
79
+ def balance
80
+ response_body = make_get_request(
81
+ "programs/#{id}/billing/balance"
82
+ )
83
+ BillingBalance.new(response_body).balance
84
+ end
85
+
79
86
  private
80
87
 
81
88
  def members
@@ -26,6 +26,22 @@ module HackerOne
26
26
  duplicate
27
27
  ).map(&:to_sym).freeze
28
28
 
29
+ RESOLVED_STATES = %w(
30
+ resolved
31
+ not-applicable
32
+ informative
33
+ duplicate
34
+ spam
35
+ ).map(&:to_sym).freeze
36
+
37
+ SEVERITY_RATINGS = %w(
38
+ none
39
+ low
40
+ medium
41
+ high
42
+ critical
43
+ ).freeze
44
+
29
45
  class << self
30
46
  def add_on_state_change_hook(proc)
31
47
  on_state_change_hooks << proc
@@ -64,6 +80,10 @@ module HackerOne
64
80
  attributes[:issue_tracker_reference_id]
65
81
  end
66
82
 
83
+ def severity
84
+ attributes[:severity]
85
+ end
86
+
67
87
  def state
68
88
  attributes[:state]
69
89
  end
@@ -123,6 +143,12 @@ module HackerOne
123
143
  classification_label.split("-").first
124
144
  end
125
145
 
146
+ def attachments
147
+ @attachments ||= relationships.fetch(:attachments, {})
148
+ .fetch(:data, [])
149
+ .map { |attachment| HackerOne::Client::Attachment.new(attachment) }
150
+ end
151
+
126
152
  def activities
127
153
  if ships = relationships.fetch(:activities, {}).fetch(:data, [])
128
154
  ships.map do |activity_data|
@@ -161,6 +187,23 @@ module HackerOne
161
187
  Swag.new(response_body, program)
162
188
  end
163
189
 
190
+ def update_severity(rating:)
191
+ raise ArgumentError, "Invalid severity rating" unless SEVERITY_RATINGS.include?(rating.to_s)
192
+
193
+ request_body = {
194
+ type: "severity",
195
+ attributes: {
196
+ rating: rating
197
+ }
198
+ }
199
+ response_body = make_post_request(
200
+ "reports/#{id}/severities",
201
+ request_body: request_body
202
+ )
203
+ @report[:attributes][:severity] = { rating: rating }
204
+ Activities.build(response_body)
205
+ end
206
+
164
207
  def suggest_bounty(message:, amount:, bonus_amount: nil)
165
208
  request_body = {
166
209
  message: message,
@@ -263,6 +306,19 @@ module HackerOne
263
306
  HackerOne::Client::Activities.build(response_json)
264
307
  end
265
308
 
309
+ def lock!
310
+ unless RESOLVED_STATES.include? self.state.to_sym
311
+ raise ArgumentError, "Report must be closed before locking"
312
+ end
313
+
314
+ body = {
315
+ type: "activity-comments-closed"
316
+ }
317
+
318
+ response_json = make_put_request("reports/#{id}/close_comments", request_body: body)
319
+ HackerOne::Client::Activities.build(response_json)
320
+ end
321
+
266
322
  def assign_to_user(name)
267
323
  member = program.find_member(name)
268
324
  _assign_to(member.user.id, :user)
@@ -2,6 +2,6 @@
2
2
 
3
3
  module Hackerone
4
4
  module Client
5
- VERSION = "0.16.0"
5
+ VERSION = "0.20.1"
6
6
  end
7
7
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: hackerone-client
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.16.0
4
+ version: 0.20.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Neil Matatall
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2020-03-24 00:00:00.000000000 Z
11
+ date: 2021-02-17 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -142,12 +142,17 @@ files:
142
142
  - fixtures/vcr_cassettes/award_a_bounty.yml
143
143
  - fixtures/vcr_cassettes/award_swag.yml
144
144
  - fixtures/vcr_cassettes/common_responses.yml
145
+ - fixtures/vcr_cassettes/create_report.yml
146
+ - fixtures/vcr_cassettes/create_report_invalid.yml
145
147
  - fixtures/vcr_cassettes/dup.yml
146
148
  - fixtures/vcr_cassettes/empty_report_list.yml
149
+ - fixtures/vcr_cassettes/get_balance.yml
150
+ - fixtures/vcr_cassettes/lock_report.yml
147
151
  - fixtures/vcr_cassettes/missing_report.yml
148
152
  - fixtures/vcr_cassettes/programs.yml
149
153
  - fixtures/vcr_cassettes/report.yml
150
154
  - fixtures/vcr_cassettes/report_list.yml
155
+ - fixtures/vcr_cassettes/report_list_triaged.yml
151
156
  - fixtures/vcr_cassettes/reporters.yml
152
157
  - fixtures/vcr_cassettes/server_error.yml
153
158
  - fixtures/vcr_cassettes/server_error_when_assigning_report_to_user.yml
@@ -159,11 +164,14 @@ files:
159
164
  - fixtures/vcr_cassettes/traverse_through_all_activities.yml
160
165
  - fixtures/vcr_cassettes/triage_and_hook_assign_report_to_user.yml
161
166
  - fixtures/vcr_cassettes/update_policy.yml
167
+ - fixtures/vcr_cassettes/update_severity.yml
162
168
  - fixtures/vcr_cassettes/user_find_fransrosen.yml
163
169
  - hackerone-client.gemspec
164
170
  - lib/hackerone/client.rb
165
171
  - lib/hackerone/client/activity.rb
166
172
  - lib/hackerone/client/address.rb
173
+ - lib/hackerone/client/attachment.rb
174
+ - lib/hackerone/client/billing_balance.rb
167
175
  - lib/hackerone/client/bounty.rb
168
176
  - lib/hackerone/client/group.rb
169
177
  - lib/hackerone/client/incremental/activities.rb