oauth2 2.0.20 → 2.0.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: a50435455bab3e2cbebb651d7b88494ee04268367f1f8ab3dbacb479f1637b65
4
- data.tar.gz: f9b36d98b44a56fbfc6e73b59c44829aa6f28eb24c16141c5052e23019145dcc
3
+ metadata.gz: 052c478b34f1b8c1d2da2469c20ca121bf4bbc5013b4996463a6d66472803574
4
+ data.tar.gz: 649fe4671d37facfb4afe1a095332853b1a19bad4af38cfb5139bfecd4990ed2
5
5
  SHA512:
6
- metadata.gz: 119ecedc64f4a158dcc0507b2da837ef2d44e6129803da0ebd383409a12670b43c892e596d2183a6e1095535ef0ed0e04769d4556f3111e392b12307a0c45e3c
7
- data.tar.gz: 43bd592fbe5945d846b9791297ea307fe505a64e79b029b24302fe69fa246b57e7d279e1e87c1bf2c1cdc9e787a5d26e8fdbef15978dcfbb2efe277267d1628f
6
+ metadata.gz: cc899a7ec288fa4a8226a8e56305b91b89be8e3644609c517bf3c5c80df2119b2970edb96850903a953761565cf36fbe9d91e1255cac0dcc74a6d0ad6b79789c
7
+ data.tar.gz: 87005576b091dc223e5ce1af711a9f449581627be4a9c56ac6b270abd4aa1bec94fd006c99b95c0146890af26f216d657ad877b4df6c8b023fcb12ec318519b8
checksums.yaml.gz.sig CHANGED
Binary file
data/CHANGELOG.md CHANGED
@@ -30,6 +30,66 @@ Please file a bug if you notice a violation of semantic versioning.
30
30
 
31
31
  ### Security
32
32
 
33
+ ## [2.0.21] - 2026-06-06
34
+
35
+ - TAG: [v2.0.21][2.0.21t]
36
+ - COVERAGE: 100.00% -- 525/525 lines in 15 files
37
+ - BRANCH COVERAGE: 100.00% -- 174/174 branches in 15 files
38
+ - 88.35% documented
39
+
40
+ ### Added
41
+
42
+ - [gh!730][gh!730] - Alternatives section to README by @jonathangrinstead
43
+ - Updates to alternatives section - by @pboling
44
+
45
+ [gh!730]: https://github.com/ruby-oauth/oauth2/pull/730
46
+
47
+ - Added conditional `appraisal2-rubocop` Appraisal root loading on modern Ruby
48
+ so generated Appraisal gemfiles are normalized during generation - by @pboling
49
+
50
+ ### Changed
51
+
52
+ - Raised generated `version_gem` dependency floor to `version_gem` >= 1.1.10 - by @pboling
53
+ - Raised the runtime dependency floor for `auth-sanitizer` to `>= 0.2.1` - by @pboling
54
+ - Refreshed generated package metadata, support documentation, CI workflows,
55
+ and development dependency floors from the current kettle-jem template - by @pboling
56
+ - Documented the current per-version Ruby, JRuby, and TruffleRuby CI matrix in
57
+ generated README badges and compatibility tables - by @pboling
58
+ - Removed the post-install message from the gemspec to keep installs quieter - by @pboling
59
+ - Refreshed generated README support badges so Ruby 2.3 is listed as
60
+ supported but untested - by @pboling
61
+ - Refreshed generated project metadata from the current kettle-jem template - by @pboling
62
+ - Raised development tooling floors to `kettle-dev` >= 2.1.0 and
63
+ `appraisal2` >= 3.1.1 for Appraisal2's split generate/install/update
64
+ command semantics.
65
+ - Refreshed generated Appraisal and CI templates to appraisal2-rubocop 0.2.0 - by @pboling
66
+
67
+ ### Removed
68
+
69
+ - Dropped the obsolete Ruby 2.3 Caboose workflow and its Hashie appraisal
70
+ gemfiles; development tooling now requires Ruby 2.4 or newer, and Ruby 2.4
71
+ coverage is already handled by the standard Ruby 2.4 workflow - by @pboling
72
+
73
+ ### Fixed
74
+
75
+ - Updated CI workflow maintenance: QLTY uploads now use OIDC and harden-runner
76
+ is pinned to v2.19.4 - by @pboling
77
+ - Replaced stale platform CI `rake magic` commands with portable spec commands - by @pboling
78
+ - Pinned `multi_xml` below 0.9 for TruffleRuby compatibility - by @pboling
79
+ - Marked EOL TruffleRuby 22.3, 23.0, and 23.1 CI as experimental because they can crash inside the interpreter during Bundler setup - by @pboling
80
+ - Improved gemspec version loading for older Rubies and isolated load-path
81
+ contexts - by @pboling
82
+ - Constrained `json` in TruffleRuby and Ruby 3.2 appraisal bundles so generated
83
+ CI dependency resolution remains compatible with those Ruby targets - by @pboling
84
+ - Pinned generated GitHub Actions `actions/checkout` steps to the peeled
85
+ v6.0.3 commit SHA so OSSF Scorecard workflow verification accepts them - by @pboling
86
+ - Marked generated EOL TruffleRuby 22.3, 23.0, and 23.1 matrix entries
87
+ experimental so native extension build failures do not fail the whole
88
+ workflow - by @pboling
89
+ - Pinned `json` only for EOL TruffleRuby appraisal bundles, matching the
90
+ default `json` gem shipped with each TruffleRuby release instead of
91
+ constraining MRI Ruby appraisal bundles - by @pboling
92
+
33
93
  ## [2.0.20] - 2026-05-20
34
94
 
35
95
  - TAG: [v2.0.20][2.0.20t]
@@ -39,11 +99,11 @@ Please file a bug if you notice a violation of semantic versioning.
39
99
 
40
100
  ### Added
41
101
 
42
- - OAuth2::VERSION (Traditional Constant Location)
102
+ - OAuth2::VERSION (Traditional Constant Location) - by @pboling
43
103
 
44
104
  ### Changed
45
105
 
46
- - auth-sanitizer v0.1.3
106
+ - auth-sanitizer v0.1.3 - by @pboling
47
107
 
48
108
  ### Fixed
49
109
 
@@ -786,7 +846,9 @@ Please file a bug if you notice a violation of semantic versioning.
786
846
 
787
847
  [gemfiles/readme]: gemfiles/README.md
788
848
 
789
- [Unreleased]: https://github.com/ruby-oauth/oauth2/compare/v2.0.20...HEAD
849
+ [Unreleased]: https://github.com/ruby-oauth/oauth2/compare/v2.0.21...HEAD
850
+ [2.0.21]: https://github.com/ruby-oauth/oauth2/compare/v2.0.20...v2.0.21
851
+ [2.0.21t]: https://github.com/ruby-oauth/oauth2/releases/tag/v2.0.21
790
852
  [2.0.20]: https://github.com/ruby-oauth/oauth2/compare/v2.0.19...v2.0.20
791
853
  [2.0.20t]: https://github.com/ruby-oauth/oauth2/releases/tag/v2.0.20
792
854
  [2.0.19]: https://github.com/ruby-oauth/oauth2/compare/v2.0.18...v2.0.19
data/CITATION.cff CHANGED
@@ -1,19 +1,19 @@
1
1
  cff-version: 1.2.0
2
- title: oauth2
2
+ title: "oauth2"
3
3
  message: >-
4
4
  If you use this work and you want to cite it,
5
5
  then you can use the metadata from this file.
6
6
  type: software
7
7
  authors:
8
- - given-names: Peter Hurn
9
- family-names: Boling
10
- email: peter@railsbling.com
11
- affiliation: railsbling.com
8
+ - given-names: "Peter H."
9
+ family-names: "Boling"
10
+ email: "floss@galtzo.com"
11
+ affiliation: "galtzo.com"
12
12
  orcid: 'https://orcid.org/0009-0008-8519-441X'
13
13
  identifiers:
14
14
  - type: url
15
15
  value: 'https://github.com/ruby-oauth/oauth2'
16
- description: oauth2
16
+ description: "oauth2"
17
17
  repository-code: 'https://github.com/ruby-oauth/oauth2'
18
18
  abstract: >-
19
19
  oauth2
data/CODE_OF_CONDUCT.md CHANGED
File without changes
data/CONTRIBUTING.md CHANGED
@@ -8,19 +8,27 @@ To submit a patch, please fork the project, create a patch with tests, and send
8
8
 
9
9
  Remember to [![Keep A Changelog][📗keep-changelog-img]][📗keep-changelog] if you make changes.
10
10
 
11
+ ## Developer Certificate of Origin
12
+
13
+ In order to protect users of this project, we require all contributors to comply with the
14
+ [Developer Certificate of Origin](https://developercertificate.org/).
15
+ This ensures that all contributions are properly licensed and attributed.
16
+
11
17
  ## Help out!
12
18
 
13
- Take a look at the `reek` list which is the file called `REEK` and find something to improve.
19
+ Take a look at the open issues and pull requests, or use the gem and find something to improve.
14
20
 
15
21
  Follow these instructions:
16
22
 
17
- 1. Fork the repository
18
- 2. Create a feature branch (`git checkout -b my-new-feature`)
19
- 3. Make some fixes.
20
- 4. Commit changes (`git commit -am 'Added some feature'`)
21
- 5. Push to the branch (`git push origin my-new-feature`)
22
- 6. Make sure to add tests for it. This is important, so it doesn't break in a future release.
23
- 7. Create new Pull Request.
23
+ 1. Join the Discord: [![Live Chat on Discord][✉️discord-invite-img]][✉️discord-invite]
24
+ 2. Fork the repository
25
+ 3. Create your feature branch (`git checkout -b my-new-feature`)
26
+ 4. Make some fixes.
27
+ 5. Commit your changes (`git commit -am 'Added some feature'`)
28
+ 6. Push to the branch (`git push origin my-new-feature`)
29
+ 7. Make sure to add tests for it. This is important, so it doesn't break in a future release.
30
+ 8. Create new Pull Request.
31
+ 9. Announce it in the channel for this org in the [Discord][✉️discord-invite]!
24
32
 
25
33
  ## Executables vs Rake tasks
26
34
 
@@ -42,6 +50,22 @@ There are many Rake tasks available as well. You can see them by running:
42
50
  bin/rake -T
43
51
  ```
44
52
 
53
+ ## Code quality checks
54
+
55
+ Run the Reek task when you want a smell check that fails on current findings:
56
+
57
+ ```shell
58
+ bin/rake reek
59
+ ```
60
+
61
+ Refresh the checked-in `REEK` backlog through the rake task, not by redirecting
62
+ the raw `reek` executable output. The rake task uses the project bundle and
63
+ avoids stale generated binstubs shadowing the Reek gem executable:
64
+
65
+ ```shell
66
+ bin/rake reek:update
67
+ ```
68
+
45
69
  ## Environment Variables for Local Development
46
70
 
47
71
  Below are the primary environment variables recognized by stone_checksums (and its integrated tools). Unless otherwise noted, set boolean values to the string "true" to enable.
@@ -52,7 +76,7 @@ General/runtime
52
76
  - CI: When set to true, adjusts default rake tasks toward CI behavior
53
77
 
54
78
  Coverage (kettle-soup-cover / SimpleCov)
55
- - K_SOUP_COV_DO: Enable coverage collection (default: true in .envrc)
79
+ - K_SOUP_COV_DO: Enable coverage collection (default: true in `mise.toml`)
56
80
  - K_SOUP_COV_FORMATTERS: Comma-separated list of formatters (html, xml, rcov, lcov, json, tty)
57
81
  - K_SOUP_COV_MIN_LINE: Minimum line coverage threshold (integer, e.g., 100)
58
82
  - K_SOUP_COV_MIN_BRANCH: Minimum branch coverage threshold (integer, e.g., 100)
@@ -78,35 +102,60 @@ Git hooks and commit message helpers (exe/kettle-commit-msg)
78
102
  - GIT_HOOK_FOOTER_SENTINEL: Required when footer append is enabled — a unique first-line sentinel to prevent duplicates
79
103
  - GIT_HOOK_FOOTER_APPEND_DEBUG: Extra debug output in the footer template (true/false)
80
104
 
81
- For a quick starting point, this repository’s `.envrc` shows sane defaults, and `.env.local` can override them locally.
105
+ Git diff driver setup
106
+ - Local setup writes repository `.gitattributes` entries and local Git `diff.smorg-*` command config so this checkout uses StructuredMerge semantic diffs.
107
+ - Global setup registers `diff.smorg-*` commands once in the user Git config; use it when you work across several StructuredMerge-enabled repositories.
108
+ - Include-file setup writes `.git/smorg/config` and includes it from local Git config, keeping command registrations out of the repository files.
109
+ - Git hosting forges generally ignore external diff drivers, so pull request views may still show raw textual diffs even when local `git diff` uses semantic drivers.
110
+
111
+ ```console
112
+ K_JEM_TEMPLATING=true bundle exec kettle-jem install
113
+ ```
114
+
115
+ Troubleshooting Git diffs
116
+ - Use `git diff --no-ext-diff` to compare against Git's built-in diff output.
117
+ - Use `git diff --no-textconv` when a textconv projection obscures the raw file bytes you need to inspect.
118
+ - If Git reports a missing `smorg-*` executable, rerun `bundle install` and the setup command above, then check `git config --local --get-regexp '^diff\.smorg-'`.
119
+ - To remove managed local entries, run `K_JEM_TEMPLATING=true bundle exec kettle-jem install --undo`; remove global command registrations with `git config --global --unset-all diff.smorg-ruby.command`.
120
+
121
+ For a quick starting point, this repository’s `mise.toml` defines the shared defaults, and `.env.local` can override them locally. Copy `.env.local.example` to `.env.local`, use `KEY=value` lines, and either activate `mise` in your shell or run commands through `mise exec -C /path/to/project -- ...`.
82
122
 
83
123
  ## Appraisals
84
124
 
85
125
  From time to time the [appraisal2][🚎appraisal2] gemfiles in `gemfiles/` will need to be updated.
126
+ Generated appraisal and CI workflow floors are controlled by `ruby.test_minimum`
127
+ in `.structuredmerge/kettle-jem.yml`; this project was templated with `ruby.test_minimum: 2.4`.
128
+ That value describes the lowest Ruby version expected to run the test/development
129
+ toolchain, and it may be higher than the gemspec runtime floor.
130
+
86
131
  They are created and updated with the commands:
87
132
 
88
133
  ```console
89
134
  bin/rake appraisal:update
90
135
  ```
91
136
 
92
- When adding an appraisal to CI, check the [runner tool cache][🏃‍♂️runner-tool-cache] to see which runner to use.
137
+ If you need to reset all gemfiles/*.gemfile.lock files:
138
+
139
+ ```console
140
+ bin/rake appraisal:reset
141
+ ```
93
142
 
94
- ## The Reek List
143
+ When adding an appraisal to CI, check the [runner tool cache][🏃‍♂️runner-tool-cache] to see which runner to use.
95
144
 
96
- Take a look at the `reek` list which is the file called `REEK` and find something to improve.
145
+ ## Run Tests
97
146
 
98
- To refresh the `reek` list:
147
+ Run tests via `kettle-test` (provided by `kettle-test`). It runs RSpec, writes the full log to
148
+ `tmp/kettle-test/rspec-TIMESTAMP.log`, and prints a compact highlight block with timing, seed,
149
+ pass/fail count, failing example list, and SimpleCov coverage percentages.
99
150
 
100
151
  ```console
101
- bundle exec reek > REEK
152
+ bundle exec kettle-test
102
153
  ```
103
154
 
104
- ## Run Tests
105
-
106
- To run all tests
155
+ For targeted runs, disable the hard coverage threshold to avoid false failures:
107
156
 
108
157
  ```console
109
- bundle exec rake test
158
+ K_SOUP_COV_MIN_HARD=false bundle exec kettle-test spec/path/to/spec.rb
110
159
  ```
111
160
 
112
161
  ### Spec organization (required)
@@ -177,33 +226,34 @@ NOTE: To build without signing the gem set `SKIP_GEM_SIGNING` to any value in th
177
226
  1. Run `bin/setup && bin/rake` as a "test, coverage, & linting" sanity check
178
227
  2. Update the version number in `version.rb`, and ensure `CHANGELOG.md` reflects changes
179
228
  3. Run `bin/setup && bin/rake` again as a secondary check, and to update `Gemfile.lock`
180
- 4. Run `git commit -am "🔖 Prepare release v<VERSION>"` to commit the changes
181
- 5. Run `git push` to trigger the final CI pipeline before release, and merge PRs
229
+ 4. Run `bin/rake yard` to regenerate the docs site using the canonical docs task
230
+ 5. Run `git commit -am "🔖 Prepare release v<VERSION>"` to commit the changes
231
+ 6. Run `git push` to trigger the final CI pipeline before release, and merge PRs
182
232
  - NOTE: Remember to [check the build][🧪build].
183
- 6. Run `export GIT_TRUNK_BRANCH_NAME="$(git remote show origin | grep 'HEAD branch' | cut -d ' ' -f5)" && echo $GIT_TRUNK_BRANCH_NAME`
184
- 7. Run `git checkout $GIT_TRUNK_BRANCH_NAME`
185
- 8. Run `git pull origin $GIT_TRUNK_BRANCH_NAME` to ensure latest trunk code
186
- 9. Optional for older Bundler (< 2.7.0): Set `SOURCE_DATE_EPOCH` so `rake build` and `rake release` use the same timestamp and generate the same checksums
233
+ 7. Run `export GIT_TRUNK_BRANCH_NAME="$(git remote show origin | grep 'HEAD branch' | cut -d ' ' -f5)" && echo $GIT_TRUNK_BRANCH_NAME`
234
+ 8. Run `git checkout $GIT_TRUNK_BRANCH_NAME`
235
+ 9. Run `git pull origin $GIT_TRUNK_BRANCH_NAME` to ensure latest trunk code
236
+ 10. Optional for older Bundler (< 2.7.0): Set `SOURCE_DATE_EPOCH` so `rake build` and `rake release` use the same timestamp and generate the same checksums
187
237
  - If your Bundler is >= 2.7.0, you can skip this; builds are reproducible by default.
188
238
  - Run `export SOURCE_DATE_EPOCH=$EPOCHSECONDS && echo $SOURCE_DATE_EPOCH`
189
239
  - If the echo above has no output, then it didn't work.
190
240
  - Note: `zsh/datetime` module is needed, if running `zsh`.
191
241
  - In older versions of `bash` you can use `date +%s` instead, i.e. `export SOURCE_DATE_EPOCH=$(date +%s) && echo $SOURCE_DATE_EPOCH`
192
- 10. Run `bundle exec rake build`
193
- 11. Run `bin/gem_checksums` (more context [1][🔒️rubygems-checksums-pr], [2][🔒️rubygems-guides-pr])
242
+ 11. Run `bundle exec rake build`
243
+ 12. Run `bin/gem_checksums` (more context [1][🔒️rubygems-checksums-pr], [2][🔒️rubygems-guides-pr])
194
244
  to create SHA-256 and SHA-512 checksums. This functionality is provided by the `stone_checksums`
195
245
  [gem][💎stone_checksums].
196
246
  - The script automatically commits but does not push the checksums
197
- 12. Sanity check the SHA256, comparing with the output from the `bin/gem_checksums` command:
247
+ 13. Sanity check the SHA256, comparing with the output from the `bin/gem_checksums` command:
198
248
  - `sha256sum pkg/<gem name>-<version>.gem`
199
- 13. Run `bundle exec rake release` which will create a git tag for the version,
249
+ 14. Run `bundle exec rake release` which will create a git tag for the version,
200
250
  push git commits and tags, and push the `.gem` file to the gem host configured in the gemspec.
201
251
 
202
- [📜src-gl]: https://gitlab.com/ruby-oauth/oauth2/
252
+ [📜src-gl]: https://gitlab.com/ruby-oauth/oauth2
203
253
  [📜src-cb]: https://codeberg.org/ruby-oauth/oauth2
204
254
  [📜src-gh]: https://github.com/ruby-oauth/oauth2
205
255
  [🧪build]: https://github.com/ruby-oauth/oauth2/actions
206
- [🤝conduct]: https://gitlab.com/ruby-oauth/oauth2/-/blob/main/CODE_OF_CONDUCT.md
256
+ [🤝conduct]: https://github.com/ruby-oauth/oauth2/blob/main/CODE_OF_CONDUCT.md
207
257
  [🖐contrib-rocks]: https://contrib.rocks
208
258
  [🖐contributors]: https://github.com/ruby-oauth/oauth2/graphs/contributors
209
259
  [🚎contributors-gl]: https://gitlab.com/ruby-oauth/oauth2/-/graphs/main
@@ -219,3 +269,4 @@ NOTE: To build without signing the gem set `SKIP_GEM_SIGNING` to any value in th
219
269
  [📌major-versions-not-sacred]: https://tom.preston-werner.com/2022/05/23/major-version-numbers-are-not-sacred.html
220
270
  [🚎appraisal2]: https://github.com/appraisal-rb/appraisal2
221
271
  [🏃‍♂️runner-tool-cache]: https://github.com/ruby/ruby-builder/releases/tag/toolcache
272
+ [✉️discord-invite]: https://discord.gg/3qme4XHNKN
data/FUNDING.md CHANGED
@@ -19,7 +19,7 @@ Many paths lead to being a sponsor or a backer of this project. Are you on such
19
19
  [🖇polar-img]: https://img.shields.io/badge/polar-donate-a51611.svg?style=flat
20
20
  [🖇polar]: https://polar.sh/pboling
21
21
  [🖇kofi-img]: https://img.shields.io/badge/ko--fi-%E2%9C%93-a51611.svg?style=flat
22
- [🖇kofi]: https://ko-fi.com/O5O86SNP4
22
+ [🖇kofi]: https://ko-fi.com/pboling
23
23
  [🖇patreon-img]: https://img.shields.io/badge/patreon-donate-a51611.svg?style=flat
24
24
  [🖇patreon]: https://patreon.com/galtzo
25
25
  [🖇buyme-small-img]: https://img.shields.io/badge/buy_me_a_coffee-%E2%9C%93-a51611.svg?style=flat
data/LICENSE.md ADDED
@@ -0,0 +1,110 @@
1
+ # License
2
+
3
+ This project is made available under the following license.
4
+ Choose the option that best fits your use case:
5
+
6
+ - [MIT](MIT.md)
7
+
8
+ ## Copyright Notice
9
+
10
+ - Copyright (c) 2010-2014, 2016-2017 Erik Michaels-Ober
11
+ - Copyright (c) 2010 Jeremy Kemper
12
+ - Copyright (c) 2010-2011 Michael Bleigh
13
+ - Copyright (c) 2010-2011 Paul Walker
14
+ - Copyright (c) 2010 rick
15
+ - Copyright (c) 2010 Tim Habermaas
16
+ - Copyright (c) 2010 Wynn Netherland
17
+ - Copyright (c) 2011 Alexander Lang
18
+ - Copyright (c) 2011 Alexander Lang
19
+ - Copyright (c) 2011 Greg Spurrier
20
+ - Copyright (c) 2011 Jay Adkisson
21
+ - Copyright (c) 2011 Luke Saunders
22
+ - Copyright (c) 2011 Paul Walker
23
+ - Copyright (c) 2011 Simon Gate
24
+ - Copyright (c) 2012 Bas Vodde
25
+ - Copyright (c) 2012 Damian Janowski
26
+ - Copyright (c) 2012 Daniël van de Burgt
27
+ - Copyright (c) 2012 Dorren Chen
28
+ - Copyright (c) 2012 Igor Sales
29
+ - Copyright (c) 2012 Leigh Caplan
30
+ - Copyright (c) 2012 Michael Andrews
31
+ - Copyright (c) 2012 Omer Rauchwerger
32
+ - Copyright (c) 2012 Saverio Trioni
33
+ - Copyright (c) 2012 Trent Ogren
34
+ - Copyright (c) 2012 Vsevolod Romashov
35
+ - Copyright (c) 2013 Antonio Tapiador del Dujo
36
+ - Copyright (c) 2013 Eduardo Gurgel
37
+ - Copyright (c) 2013 Geostellar Developer
38
+ - Copyright (c) 2013-2014, 2018 Niels Ganser
39
+ - Copyright (c) 2013 Rainux Luo
40
+ - Copyright (c) 2013 Taylor Hedberg
41
+ - Copyright (c) 2013 Tim Clem
42
+ - Copyright (c) 2014 Dave Stevens
43
+ - Copyright (c) 2014 Ellis Berner
44
+ - Copyright (c) 2014 Frank Macreery
45
+ - Copyright (c) 2014 Michael Bleigh
46
+ - Copyright (c) 2014 Olivier Lacan
47
+ - Copyright (c) 2014 Peter Souter
48
+ - Copyright (c) 2014 Ryan Williams
49
+ - Copyright (c) 2015 Andrew Cantino and Jeff Moore
50
+ - Copyright (c) 2015 Thomas Walpole
51
+ - Copyright (c) 2016 Bo Jeanes
52
+ - Copyright (c) 2016 Cody Cutrer
53
+ - Copyright (c) 2016 Edward Rudd
54
+ - Copyright (c) 2016 Lawrence Oluyede
55
+ - Copyright (c) 2016 Linus Pettersson
56
+ - Copyright (c) 2016 Motoshi Nishihira
57
+ - Copyright (c) 2017 Adrian Setyadi
58
+ - Copyright (c) 2017-2018 Benjamin Quorning
59
+ - Copyright (c) 2017 Christoph Petschnig
60
+ - Copyright (c) 2017, 2022 Nathaniel Bibler
61
+ - Copyright (c) 2017 Oleg
62
+ - Copyright (c) 2017 Samuel Cochran
63
+ - Copyright (c) 2017 tetsuya
64
+ - Copyright (c) 2017 Yury Velikanau
65
+ - Copyright (c) 2018 Alex Kowalczuk
66
+ - Copyright (c) 2018 asm__
67
+ - Copyright (c) 2018 David Christensen
68
+ - Copyright (c) 2018 fossabot
69
+ - Copyright (c) 2018 Jeff Moore
70
+ - Copyright (c) 2018 Jeff Moore
71
+ - Copyright (c) 2018 Jonathan del Strother
72
+ - Copyright (c) 2018 Joseph Page
73
+ - Copyright (c) 2018 Joseph Page
74
+ - Copyright (c) 2018 Lomey
75
+ - Copyright (c) 2018 Markus Bengts
76
+ - Copyright (c) 2018 Mathias Klippinge
77
+ - Copyright (c) 2018 nikz
78
+ - Copyright (c) 2018-2019, 2021-2022, 2024-2026 Peter H. Boling
79
+ - Copyright (c) 2019 Daniel Fockler
80
+ - Copyright (c) 2019 Elliot Crosby-McCullough
81
+ - Copyright (c) 2019 João Paulo
82
+ - Copyright (c) 2019 Orien Madgwick
83
+ - Copyright (c) 2019 Ryan T. Hosford
84
+ - Copyright (c) 2019 Tom Corley
85
+ - Copyright (c) 2020 anvox
86
+ - Copyright (c) 2020 Jesse Cotton
87
+ - Copyright (c) 2020 Olle Jonsson
88
+ - Copyright (c) 2020 Stephen Reid
89
+ - Copyright (c) 2021 Anders Carling
90
+ - Copyright (c) 2021 dobon
91
+ - Copyright (c) 2021 Jan Zaydowicz
92
+ - Copyright (c) 2021 Nicholas Palaniuk
93
+ - Copyright (c) 2021-2022 Stan Hu
94
+ - Copyright (c) 2022 Benjamin Quorning
95
+ - Copyright (c) 2022 Bouke van der Bijl
96
+ - Copyright (c) 2022 nov
97
+ - Copyright (c) 2022 Rick Selby
98
+ - Copyright (c) 2022 Ryo Takahashi
99
+ - Copyright (c) 2023 Jessie Young
100
+ - Copyright (c) 2023 Карим Гимадеев
101
+ - Copyright (c) 2024 Aboling0
102
+ - Copyright (c) 2024 Elise Wood
103
+ - Copyright (c) 2024 Manuel van Rijn
104
+ - Copyright (c) 2025-2026 Annibelle Boling
105
+ - Copyright (c) 2025 Mark James
106
+ - Copyright (c) 2025 Mridang Agarwalla
107
+ - Copyright (c) 2025 Sasa Rosic
108
+ - Copyright (c) 2026 Jonathan Grinstead
109
+ - Copyright (c) 2026 kain
110
+ - Copyright (c) 2026 StepSecurity Bot