firejwt 0.2.0 → 0.4.0

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: 22a3cbe836d5c04927447040ffdc8580f0a8863798dc1089e3e4fa6940989b0f
4
- data.tar.gz: 886dbe43fee7a2132259c1997018e711a08e54e53366a461efc77516c6893bfc
3
+ metadata.gz: e5cccf39fd926dfa2cbe9744c9a5a12715c3fa03a2cbaf6bfbd5ae9ef332d0e0
4
+ data.tar.gz: 01c1468c405e86f39e733fdf676ee212bb11191e2416445c2edabc00d2933a00
5
5
  SHA512:
6
- metadata.gz: de05062161e6489c4c074b786a4125a2c412d3b4641b23e91c18f3e6f734993e81ea98eea4a0775259f10183c9872597e84e2a3d944c405bd6ea38d3edd82862
7
- data.tar.gz: c62208610c25313796a7a663dcad304c7568293a9096bce5c26b9d0de493fb90eedc159cc8047864f9eb7ca028caa4361c508b276ff2733bb7662e13b96e9a25
6
+ metadata.gz: 4e9326c3669c09f7b0f7bc82b33e52a36430ad59a5a6d534cb1a0e9763d0ce7393520e1f6f9ab87b52d2941a631fa1d4055898ab2bf28e7e7584f148dbdf1dff
7
+ data.tar.gz: ce68d73e6a08116fb2015f12670959b8b35c9ce70e3ea66e6d33353a7f34134f83cc2fa3965c1ca61989fb7dc47cf8d9784eeb2c54d2a50b4ccc176de97c49d8
@@ -0,0 +1,51 @@
1
+ name: Test
2
+ on:
3
+ push:
4
+ branches:
5
+ - main
6
+ pull_request:
7
+ branches:
8
+ - main
9
+ jobs:
10
+ golint:
11
+ runs-on: ubuntu-latest
12
+ steps:
13
+ - name: Checkout
14
+ uses: actions/checkout@v2
15
+ - name: Run lint
16
+ uses: golangci/golangci-lint-action@v2
17
+ with:
18
+ version: latest
19
+ go:
20
+ runs-on: ubuntu-latest
21
+ strategy:
22
+ matrix:
23
+ go-version: [1.16.x, 1.17.x]
24
+ steps:
25
+ - name: Checkout
26
+ uses: actions/checkout@v2
27
+ - name: Cache dependencies
28
+ uses: actions/cache@v2
29
+ with:
30
+ path: ~/go/pkg/mod
31
+ key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
32
+ restore-keys: |
33
+ ${{ runner.os }}-go-
34
+ - name: Setup Go
35
+ uses: actions/setup-go@v2
36
+ with:
37
+ go-version: ${{ matrix.go-version }}
38
+ - name: Run tests
39
+ run: make test
40
+ ruby:
41
+ runs-on: ubuntu-latest
42
+ strategy:
43
+ matrix:
44
+ ruby-version: ["2.5", "2.6", "2.7", "3.0"]
45
+ steps:
46
+ - uses: actions/checkout@v2
47
+ - uses: ruby/setup-ruby@v1
48
+ with:
49
+ ruby-version: ${{ matrix.ruby-version }}
50
+ bundler-cache: true
51
+ - run: bundle exec rake
data/.rubocop.yml CHANGED
@@ -1,5 +1,12 @@
1
- inherit_from:
2
- - https://gitlab.com/bsm/misc/raw/master/rubocop/default.yml
1
+ inherit_gem:
2
+ rubocop-bsm:
3
+ - default.yml
4
+ inherit_mode:
5
+ merge:
6
+ - Exclude
3
7
 
4
8
  AllCops:
5
9
  TargetRubyVersion: "2.5"
10
+
11
+ RSpec/FilePath:
12
+ Enabled: false
data/Gemfile.lock CHANGED
@@ -1,55 +1,68 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- firejwt (0.2.0)
4
+ firejwt (0.4.0)
5
5
  jwt
6
6
 
7
7
  GEM
8
8
  remote: https://rubygems.org/
9
9
  specs:
10
- addressable (2.7.0)
10
+ addressable (2.8.0)
11
11
  public_suffix (>= 2.0.2, < 5.0)
12
- ast (2.4.1)
13
- crack (0.4.4)
12
+ ast (2.4.2)
13
+ crack (0.4.5)
14
+ rexml
14
15
  diff-lcs (1.4.4)
15
16
  hashdiff (1.0.1)
16
- jwt (2.2.2)
17
- parallel (1.19.2)
18
- parser (2.7.1.5)
17
+ jwt (2.3.0)
18
+ parallel (1.21.0)
19
+ parser (3.0.3.1)
19
20
  ast (~> 2.4.1)
20
21
  public_suffix (4.0.6)
21
22
  rainbow (3.0.0)
22
- rake (13.0.1)
23
- regexp_parser (1.8.1)
24
- rexml (3.2.4)
25
- rspec (3.9.0)
26
- rspec-core (~> 3.9.0)
27
- rspec-expectations (~> 3.9.0)
28
- rspec-mocks (~> 3.9.0)
29
- rspec-core (3.9.3)
30
- rspec-support (~> 3.9.3)
31
- rspec-expectations (3.9.2)
23
+ rake (13.0.6)
24
+ regexp_parser (2.1.1)
25
+ rexml (3.2.5)
26
+ rspec (3.10.0)
27
+ rspec-core (~> 3.10.0)
28
+ rspec-expectations (~> 3.10.0)
29
+ rspec-mocks (~> 3.10.0)
30
+ rspec-core (3.10.1)
31
+ rspec-support (~> 3.10.0)
32
+ rspec-expectations (3.10.1)
32
33
  diff-lcs (>= 1.2.0, < 2.0)
33
- rspec-support (~> 3.9.0)
34
- rspec-mocks (3.9.1)
34
+ rspec-support (~> 3.10.0)
35
+ rspec-mocks (3.10.2)
35
36
  diff-lcs (>= 1.2.0, < 2.0)
36
- rspec-support (~> 3.9.0)
37
- rspec-support (3.9.3)
38
- rubocop (0.92.0)
37
+ rspec-support (~> 3.10.0)
38
+ rspec-support (3.10.3)
39
+ rubocop (1.23.0)
39
40
  parallel (~> 1.10)
40
- parser (>= 2.7.1.5)
41
+ parser (>= 3.0.0.0)
41
42
  rainbow (>= 2.2.2, < 4.0)
42
- regexp_parser (>= 1.7)
43
+ regexp_parser (>= 1.8, < 3.0)
43
44
  rexml
44
- rubocop-ast (>= 0.5.0)
45
+ rubocop-ast (>= 1.12.0, < 2.0)
45
46
  ruby-progressbar (~> 1.7)
46
- unicode-display_width (>= 1.4.0, < 2.0)
47
- rubocop-ast (0.7.1)
48
- parser (>= 2.7.1.5)
49
- ruby-progressbar (1.10.1)
50
- unicode-display_width (1.7.0)
51
- webmock (3.9.1)
52
- addressable (>= 2.3.6)
47
+ unicode-display_width (>= 1.4.0, < 3.0)
48
+ rubocop-ast (1.13.0)
49
+ parser (>= 3.0.1.1)
50
+ rubocop-bsm (0.6.0)
51
+ rubocop (~> 1.0)
52
+ rubocop-performance
53
+ rubocop-rake
54
+ rubocop-rspec
55
+ rubocop-performance (1.12.0)
56
+ rubocop (>= 1.7.0, < 2.0)
57
+ rubocop-ast (>= 0.4.0)
58
+ rubocop-rake (0.6.0)
59
+ rubocop (~> 1.0)
60
+ rubocop-rspec (2.6.0)
61
+ rubocop (~> 1.19)
62
+ ruby-progressbar (1.11.0)
63
+ unicode-display_width (2.1.0)
64
+ webmock (3.14.0)
65
+ addressable (>= 2.8.0)
53
66
  crack (>= 0.3.2)
54
67
  hashdiff (>= 0.4.0, < 2.0.0)
55
68
 
@@ -60,8 +73,8 @@ DEPENDENCIES
60
73
  firejwt!
61
74
  rake
62
75
  rspec
63
- rubocop
76
+ rubocop-bsm
64
77
  webmock
65
78
 
66
79
  BUNDLED WITH
67
- 2.1.4
80
+ 2.2.32
data/LICENSE CHANGED
@@ -1,13 +1,201 @@
1
- Copyright 2020 Black Square Media Ltd
1
+ Apache License
2
+ Version 2.0, January 2004
3
+ http://www.apache.org/licenses/
2
4
 
3
- Licensed under the Apache License, Version 2.0 (the "License");
4
- you may not use this file except in compliance with the License.
5
- You may obtain a copy of the License at
5
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
6
6
 
7
- http://www.apache.org/licenses/LICENSE-2.0
7
+ 1. Definitions.
8
8
 
9
- Unless required by applicable law or agreed to in writing, software
10
- distributed under the License is distributed on an "AS IS" BASIS,
11
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
- See the License for the specific language governing permissions and
13
- limitations under the License.
9
+ "License" shall mean the terms and conditions for use, reproduction,
10
+ and distribution as defined by Sections 1 through 9 of this document.
11
+
12
+ "Licensor" shall mean the copyright owner or entity authorized by
13
+ the copyright owner that is granting the License.
14
+
15
+ "Legal Entity" shall mean the union of the acting entity and all
16
+ other entities that control, are controlled by, or are under common
17
+ control with that entity. For the purposes of this definition,
18
+ "control" means (i) the power, direct or indirect, to cause the
19
+ direction or management of such entity, whether by contract or
20
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
21
+ outstanding shares, or (iii) beneficial ownership of such entity.
22
+
23
+ "You" (or "Your") shall mean an individual or Legal Entity
24
+ exercising permissions granted by this License.
25
+
26
+ "Source" form shall mean the preferred form for making modifications,
27
+ including but not limited to software source code, documentation
28
+ source, and configuration files.
29
+
30
+ "Object" form shall mean any form resulting from mechanical
31
+ transformation or translation of a Source form, including but
32
+ not limited to compiled object code, generated documentation,
33
+ and conversions to other media types.
34
+
35
+ "Work" shall mean the work of authorship, whether in Source or
36
+ Object form, made available under the License, as indicated by a
37
+ copyright notice that is included in or attached to the work
38
+ (an example is provided in the Appendix below).
39
+
40
+ "Derivative Works" shall mean any work, whether in Source or Object
41
+ form, that is based on (or derived from) the Work and for which the
42
+ editorial revisions, annotations, elaborations, or other modifications
43
+ represent, as a whole, an original work of authorship. For the purposes
44
+ of this License, Derivative Works shall not include works that remain
45
+ separable from, or merely link (or bind by name) to the interfaces of,
46
+ the Work and Derivative Works thereof.
47
+
48
+ "Contribution" shall mean any work of authorship, including
49
+ the original version of the Work and any modifications or additions
50
+ to that Work or Derivative Works thereof, that is intentionally
51
+ submitted to Licensor for inclusion in the Work by the copyright owner
52
+ or by an individual or Legal Entity authorized to submit on behalf of
53
+ the copyright owner. For the purposes of this definition, "submitted"
54
+ means any form of electronic, verbal, or written communication sent
55
+ to the Licensor or its representatives, including but not limited to
56
+ communication on electronic mailing lists, source code control systems,
57
+ and issue tracking systems that are managed by, or on behalf of, the
58
+ Licensor for the purpose of discussing and improving the Work, but
59
+ excluding communication that is conspicuously marked or otherwise
60
+ designated in writing by the copyright owner as "Not a Contribution."
61
+
62
+ "Contributor" shall mean Licensor and any individual or Legal Entity
63
+ on behalf of whom a Contribution has been received by Licensor and
64
+ subsequently incorporated within the Work.
65
+
66
+ 2. Grant of Copyright License. Subject to the terms and conditions of
67
+ this License, each Contributor hereby grants to You a perpetual,
68
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
69
+ copyright license to reproduce, prepare Derivative Works of,
70
+ publicly display, publicly perform, sublicense, and distribute the
71
+ Work and such Derivative Works in Source or Object form.
72
+
73
+ 3. Grant of Patent License. Subject to the terms and conditions of
74
+ this License, each Contributor hereby grants to You a perpetual,
75
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
76
+ (except as stated in this section) patent license to make, have made,
77
+ use, offer to sell, sell, import, and otherwise transfer the Work,
78
+ where such license applies only to those patent claims licensable
79
+ by such Contributor that are necessarily infringed by their
80
+ Contribution(s) alone or by combination of their Contribution(s)
81
+ with the Work to which such Contribution(s) was submitted. If You
82
+ institute patent litigation against any entity (including a
83
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
84
+ or a Contribution incorporated within the Work constitutes direct
85
+ or contributory patent infringement, then any patent licenses
86
+ granted to You under this License for that Work shall terminate
87
+ as of the date such litigation is filed.
88
+
89
+ 4. Redistribution. You may reproduce and distribute copies of the
90
+ Work or Derivative Works thereof in any medium, with or without
91
+ modifications, and in Source or Object form, provided that You
92
+ meet the following conditions:
93
+
94
+ (a) You must give any other recipients of the Work or
95
+ Derivative Works a copy of this License; and
96
+
97
+ (b) You must cause any modified files to carry prominent notices
98
+ stating that You changed the files; and
99
+
100
+ (c) You must retain, in the Source form of any Derivative Works
101
+ that You distribute, all copyright, patent, trademark, and
102
+ attribution notices from the Source form of the Work,
103
+ excluding those notices that do not pertain to any part of
104
+ the Derivative Works; and
105
+
106
+ (d) If the Work includes a "NOTICE" text file as part of its
107
+ distribution, then any Derivative Works that You distribute must
108
+ include a readable copy of the attribution notices contained
109
+ within such NOTICE file, excluding those notices that do not
110
+ pertain to any part of the Derivative Works, in at least one
111
+ of the following places: within a NOTICE text file distributed
112
+ as part of the Derivative Works; within the Source form or
113
+ documentation, if provided along with the Derivative Works; or,
114
+ within a display generated by the Derivative Works, if and
115
+ wherever such third-party notices normally appear. The contents
116
+ of the NOTICE file are for informational purposes only and
117
+ do not modify the License. You may add Your own attribution
118
+ notices within Derivative Works that You distribute, alongside
119
+ or as an addendum to the NOTICE text from the Work, provided
120
+ that such additional attribution notices cannot be construed
121
+ as modifying the License.
122
+
123
+ You may add Your own copyright statement to Your modifications and
124
+ may provide additional or different license terms and conditions
125
+ for use, reproduction, or distribution of Your modifications, or
126
+ for any such Derivative Works as a whole, provided Your use,
127
+ reproduction, and distribution of the Work otherwise complies with
128
+ the conditions stated in this License.
129
+
130
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
131
+ any Contribution intentionally submitted for inclusion in the Work
132
+ by You to the Licensor shall be under the terms and conditions of
133
+ this License, without any additional terms or conditions.
134
+ Notwithstanding the above, nothing herein shall supersede or modify
135
+ the terms of any separate license agreement you may have executed
136
+ with Licensor regarding such Contributions.
137
+
138
+ 6. Trademarks. This License does not grant permission to use the trade
139
+ names, trademarks, service marks, or product names of the Licensor,
140
+ except as required for reasonable and customary use in describing the
141
+ origin of the Work and reproducing the content of the NOTICE file.
142
+
143
+ 7. Disclaimer of Warranty. Unless required by applicable law or
144
+ agreed to in writing, Licensor provides the Work (and each
145
+ Contributor provides its Contributions) on an "AS IS" BASIS,
146
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
147
+ implied, including, without limitation, any warranties or conditions
148
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
149
+ PARTICULAR PURPOSE. You are solely responsible for determining the
150
+ appropriateness of using or redistributing the Work and assume any
151
+ risks associated with Your exercise of permissions under this License.
152
+
153
+ 8. Limitation of Liability. In no event and under no legal theory,
154
+ whether in tort (including negligence), contract, or otherwise,
155
+ unless required by applicable law (such as deliberate and grossly
156
+ negligent acts) or agreed to in writing, shall any Contributor be
157
+ liable to You for damages, including any direct, indirect, special,
158
+ incidental, or consequential damages of any character arising as a
159
+ result of this License or out of the use or inability to use the
160
+ Work (including but not limited to damages for loss of goodwill,
161
+ work stoppage, computer failure or malfunction, or any and all
162
+ other commercial damages or losses), even if such Contributor
163
+ has been advised of the possibility of such damages.
164
+
165
+ 9. Accepting Warranty or Additional Liability. While redistributing
166
+ the Work or Derivative Works thereof, You may choose to offer,
167
+ and charge a fee for, acceptance of support, warranty, indemnity,
168
+ or other liability obligations and/or rights consistent with this
169
+ License. However, in accepting such obligations, You may act only
170
+ on Your own behalf and on Your sole responsibility, not on behalf
171
+ of any other Contributor, and only if You agree to indemnify,
172
+ defend, and hold each Contributor harmless for any liability
173
+ incurred by, or claims asserted against, such Contributor by reason
174
+ of your accepting any such warranty or additional liability.
175
+
176
+ END OF TERMS AND CONDITIONS
177
+
178
+ APPENDIX: How to apply the Apache License to your work.
179
+
180
+ To apply the Apache License to your work, attach the following
181
+ boilerplate notice, with the fields enclosed by brackets "[]"
182
+ replaced with your own identifying information. (Don't include
183
+ the brackets!) The text should be enclosed in the appropriate
184
+ comment syntax for the file format. We also recommend that a
185
+ file or class name and description of purpose be included on the
186
+ same "printed page" as the copyright notice for easier
187
+ identification within third-party archives.
188
+
189
+ Copyright 2021 Black Square Media Ltd
190
+
191
+ Licensed under the Apache License, Version 2.0 (the "License");
192
+ you may not use this file except in compliance with the License.
193
+ You may obtain a copy of the License at
194
+
195
+ http://www.apache.org/licenses/LICENSE-2.0
196
+
197
+ Unless required by applicable law or agreed to in writing, software
198
+ distributed under the License is distributed on an "AS IS" BASIS,
199
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
200
+ See the License for the specific language governing permissions and
201
+ limitations under the License.
data/Makefile CHANGED
@@ -1,7 +1,7 @@
1
- default: vet test
1
+ default: test
2
2
 
3
3
  test:
4
4
  go test ./...
5
5
 
6
- vet:
7
- go vet ./...
6
+ lint:
7
+ golangci-lint run
data/README.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # FireJWT
2
2
 
3
- [![Build Status](https://travis-ci.org/bsm/firejwt.png?branch=master)](https://travis-ci.org/bsm/firejwt)
3
+ [![Test](https://github.com/bsm/firejwt/actions/workflows/test.yml/badge.svg)](https://github.com/bsm/firejwt/actions/workflows/test.yml)
4
4
  [![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
5
5
 
6
6
  Decode and validate [Google Firebase](https://firebase.google.com/) JWT tokens with [Ruby](https://www.ruby-lang.org/) and [Go](https://golang.org/).
data/firejwt.gemspec CHANGED
@@ -1,6 +1,6 @@
1
1
  Gem::Specification.new do |s|
2
2
  s.name = 'firejwt'
3
- s.version = '0.2.0'
3
+ s.version = '0.4.0'
4
4
  s.authors = ['Black Square Media Ltd']
5
5
  s.email = ['info@blacksquaremedia.com']
6
6
  s.summary = %(Firebase JWT validation)
@@ -16,6 +16,9 @@ Gem::Specification.new do |s|
16
16
  s.add_dependency 'jwt'
17
17
  s.add_development_dependency 'rake'
18
18
  s.add_development_dependency 'rspec'
19
- s.add_development_dependency 'rubocop'
19
+ s.add_development_dependency 'rubocop-bsm'
20
20
  s.add_development_dependency 'webmock'
21
+ s.metadata = {
22
+ 'rubygems_mfa_required' => 'true',
23
+ }
21
24
  end
data/firejwt.go CHANGED
@@ -13,7 +13,7 @@ import (
13
13
  "sync/atomic"
14
14
  "time"
15
15
 
16
- "github.com/dgrijalva/jwt-go"
16
+ "github.com/golang-jwt/jwt/v4"
17
17
  )
18
18
 
19
19
  const defaultURL = "https://www.googleapis.com/robot/v1/metadata/x509/securetoken@system.gserviceaccount.com"
@@ -59,8 +59,15 @@ func (v *Validator) Stop() {
59
59
  }
60
60
 
61
61
  // Decode decodes the token
62
- func (v *Validator) Decode(tokenString string) (*jwt.Token, error) {
63
- return jwt.ParseWithClaims(tokenString, new(Claims), v.verify)
62
+ func (v *Validator) Decode(tokenString string) (*Claims, error) {
63
+ claims := new(Claims)
64
+ token, err := jwt.ParseWithClaims(tokenString, claims, v.verify)
65
+ if err != nil {
66
+ return nil, err
67
+ } else if !token.Valid {
68
+ return nil, errTokenInvalid
69
+ }
70
+ return claims, nil
64
71
  }
65
72
 
66
73
  // ExpTime returns the expiration time.
@@ -97,6 +104,7 @@ var (
97
104
  errIssuedFuture = errors.New("issued in the future")
98
105
  errNoSubject = errors.New("subject is missing")
99
106
  errAuthFuture = errors.New("auth-time in the future")
107
+ errTokenInvalid = errors.New("token is invalid")
100
108
  )
101
109
 
102
110
  func (v *Validator) verify(token *jwt.Token) (interface{}, error) {
data/firejwt_test.go CHANGED
@@ -17,18 +17,18 @@ import (
17
17
  "time"
18
18
 
19
19
  "github.com/bsm/firejwt"
20
- "github.com/dgrijalva/jwt-go"
21
- . "github.com/onsi/ginkgo"
22
- . "github.com/onsi/gomega"
20
+ . "github.com/bsm/ginkgo"
21
+ . "github.com/bsm/gomega"
22
+ "github.com/golang-jwt/jwt/v4"
23
23
  )
24
24
 
25
25
  var _ = Describe("Validator", func() {
26
26
  var subject *firejwt.Validator
27
27
  var server *httptest.Server
28
- var claims *firejwt.Claims
28
+ var seeds *firejwt.Claims
29
29
 
30
30
  generate := func() string {
31
- token := jwt.NewWithClaims(jwt.SigningMethodRS256, claims)
31
+ token := jwt.NewWithClaims(jwt.SigningMethodRS256, seeds)
32
32
  token.Header["kid"] = certKID
33
33
 
34
34
  data, err := token.SignedString(privKey)
@@ -39,11 +39,11 @@ var _ = Describe("Validator", func() {
39
39
  BeforeEach(func() {
40
40
  server = httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, _ *http.Request) {
41
41
  w.Header().Set("expires", "Mon, 20 Jan 2020 23:40:59 GMT")
42
- json.NewEncoder(w).Encode(map[string]string{
42
+ _ = json.NewEncoder(w).Encode(map[string]string{
43
43
  certKID: string(certPEM),
44
44
  })
45
45
  }))
46
- claims = mockClaims(time.Now().Unix())
46
+ seeds = mockClaims(time.Now().Unix())
47
47
 
48
48
  var err error
49
49
  subject, err = firejwt.Mocked(server.URL)
@@ -60,10 +60,9 @@ var _ = Describe("Validator", func() {
60
60
  })
61
61
 
62
62
  It("should decode tokens", func() {
63
- token, err := subject.Decode(generate())
63
+ claims, err := subject.Decode(generate())
64
64
  Expect(err).NotTo(HaveOccurred())
65
- Expect(token.Valid).To(BeTrue())
66
- Expect(token.Claims).To(Equal(claims))
65
+ Expect(claims).To(Equal(seeds))
67
66
  })
68
67
 
69
68
  It("should reject bad tokens", func() {
@@ -73,42 +72,42 @@ var _ = Describe("Validator", func() {
73
72
  })
74
73
 
75
74
  It("should verify exp", func() {
76
- claims.ExpiresAt = time.Now().Unix() - 1
75
+ seeds.ExpiresAt = time.Now().Unix() - 1
77
76
  _, err := subject.Decode(generate())
78
77
  Expect(err).To(MatchError(`token has expired`))
79
78
  Expect(err).To(BeAssignableToTypeOf(&jwt.ValidationError{}))
80
79
  })
81
80
 
82
81
  It("should verify iat", func() {
83
- claims.IssuedAt = time.Now().Unix() + 1
82
+ seeds.IssuedAt = time.Now().Unix() + 1
84
83
  _, err := subject.Decode(generate())
85
84
  Expect(err).To(MatchError(`issued in the future`))
86
85
  Expect(err).To(BeAssignableToTypeOf(&jwt.ValidationError{}))
87
86
  })
88
87
 
89
88
  It("should verify aud", func() {
90
- claims.Audience = "other"
89
+ seeds.Audience = "other"
91
90
  _, err := subject.Decode(generate())
92
91
  Expect(err).To(MatchError(`invalid audience claim "other"`))
93
92
  Expect(err).To(BeAssignableToTypeOf(&jwt.ValidationError{}))
94
93
  })
95
94
 
96
95
  It("should verify iss", func() {
97
- claims.Issuer = "other"
96
+ seeds.Issuer = "other"
98
97
  _, err := subject.Decode(generate())
99
98
  Expect(err).To(MatchError(`invalid issuer claim "other"`))
100
99
  Expect(err).To(BeAssignableToTypeOf(&jwt.ValidationError{}))
101
100
  })
102
101
 
103
102
  It("should verify sub", func() {
104
- claims.Subject = ""
103
+ seeds.Subject = ""
105
104
  _, err := subject.Decode(generate())
106
105
  Expect(err).To(MatchError(`subject is missing`))
107
106
  Expect(err).To(BeAssignableToTypeOf(&jwt.ValidationError{}))
108
107
  })
109
108
 
110
109
  It("should verify auth time", func() {
111
- claims.AuthAt = time.Now().Unix() + 1
110
+ seeds.AuthAt = time.Now().Unix() + 1
112
111
  _, err := subject.Decode(generate())
113
112
  Expect(err).To(MatchError(`auth-time in the future`))
114
113
  Expect(err).To(BeAssignableToTypeOf(&jwt.ValidationError{}))
@@ -117,8 +116,8 @@ var _ = Describe("Validator", func() {
117
116
 
118
117
  var _ = Describe("Claims", func() {
119
118
  It("should be JWT compatible", func() {
120
- claims := mockClaims(1515151515)
121
- Expect(json.Marshal(claims)).To(MatchJSON(`{
119
+ subject := mockClaims(1515151515)
120
+ Expect(json.Marshal(subject)).To(MatchJSON(`{
122
121
  "name": "Me",
123
122
  "picture": "https://test.host/me.jpg",
124
123
  "sub": "MDYwNDQwNjUtYWQ0ZC00ZDkwLThl",
data/go.mod CHANGED
@@ -1,15 +1,9 @@
1
1
  module github.com/bsm/firejwt
2
2
 
3
- go 1.13
3
+ go 1.16
4
4
 
5
5
  require (
6
- github.com/dgrijalva/jwt-go v3.2.0+incompatible
7
- github.com/golang/protobuf v1.3.2 // indirect
8
- github.com/kr/pretty v0.1.0 // indirect
9
- github.com/onsi/ginkgo v1.11.0
10
- github.com/onsi/gomega v1.8.1
11
- golang.org/x/net v0.0.0-20191007182048-72f939374954 // indirect
12
- golang.org/x/sys v0.0.0-20191008105621-543471e840be // indirect
13
- golang.org/x/text v0.3.2 // indirect
14
- gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 // indirect
6
+ github.com/bsm/ginkgo v1.16.1
7
+ github.com/bsm/gomega v1.11.0
8
+ github.com/golang-jwt/jwt/v4 v4.1.0
15
9
  )
data/go.sum CHANGED
@@ -1,43 +1,6 @@
1
- github.com/dgrijalva/jwt-go v3.2.0+incompatible h1:7qlOGliEKZXTDg6OTjfoBKDXWrumCAMpl/TFQ4/5kLM=
2
- github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ=
3
- github.com/fsnotify/fsnotify v1.4.7 h1:IXs+QLmnXW2CcXuY+8Mzv/fWEsPGWxqefPtCP5CnV9I=
4
- github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo=
5
- github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
6
- github.com/golang/protobuf v1.3.2 h1:6nsPYzhq5kReh6QImI3k5qWzO4PEbvbIW2cwSfR/6xs=
7
- github.com/golang/protobuf v1.3.2/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
8
- github.com/hpcloud/tail v1.0.0 h1:nfCOvKYfkgYP8hkirhJocXT2+zOD8yUNjXaWfTlyFKI=
9
- github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU=
10
- github.com/kr/pretty v0.1.0 h1:L/CwN0zerZDmRFUapSPitk6f+Q3+0za1rQkzVuMiMFI=
11
- github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo=
12
- github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
13
- github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE=
14
- github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
15
- github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
16
- github.com/onsi/ginkgo v1.11.0 h1:JAKSXpt1YjtLA7YpPiqO9ss6sNXEsPfSGdwN0UHqzrw=
17
- github.com/onsi/ginkgo v1.11.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
18
- github.com/onsi/gomega v1.8.1 h1:C5Dqfs/LeauYDX0jJXIe2SWmwCbGzx9yF8C8xy3Lh34=
19
- github.com/onsi/gomega v1.8.1/go.mod h1:Ho0h+IUsWyvy1OpqCwxlQ/21gkhVunqlU8fDGcoTdcA=
20
- golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
21
- golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
22
- golang.org/x/net v0.0.0-20191007182048-72f939374954 h1:JGZucVF/L/TotR719NbujzadOZ2AgnYlqphQGHDCKaU=
23
- golang.org/x/net v0.0.0-20191007182048-72f939374954/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
24
- golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
25
- golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
26
- golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
27
- golang.org/x/sys v0.0.0-20191008105621-543471e840be h1:QAcqgptGM8IQBC9K/RC4o+O9YmqEm0diQn9QmZw/0mU=
28
- golang.org/x/sys v0.0.0-20191008105621-543471e840be/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
29
- golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
30
- golang.org/x/text v0.3.2 h1:tW2bmiBqwgJj/UpqtC8EpXEZVYOwU0yG4iWbprSVAcs=
31
- golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
32
- golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
33
- golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7 h1:9zdDQZ7Thm29KFXgAX/+yaf3eVbP7djjWp/dXAppNCc=
34
- golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
35
- gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
36
- gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 h1:YR8cESwS4TdDjEe65xsg0ogRM/Nc3DYOhEAlW+xobZo=
37
- gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
38
- gopkg.in/fsnotify.v1 v1.4.7 h1:xOHLXZwVvI9hhs+cLKq5+I5onOuwQLhQwiu63xxlHs4=
39
- gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys=
40
- gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkepLTh2hOroT7a+7czfdQ=
41
- gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw=
42
- gopkg.in/yaml.v2 v2.2.4 h1:/eiJrUcujPVeJ3xlSWaiNi3uSVmDGBK1pDHUHAnao1I=
43
- gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
1
+ github.com/bsm/ginkgo v1.16.1 h1:jp1v1dbmbGZDWmnGXDTN+XK3U1fTTNja9xYa7VBI0l0=
2
+ github.com/bsm/ginkgo v1.16.1/go.mod h1:RabIZLzOCPghgHJKUqHZpqrQETA5AnF4aCSIYy5C1bk=
3
+ github.com/bsm/gomega v1.11.0 h1:wg9DVGPETNZLIbMsseneMV1a7uo/x+wsCyNXdEcifDI=
4
+ github.com/bsm/gomega v1.11.0/go.mod h1:JifAceMQ4crZIWYUKrlGcmbN3bqHogVTADMD2ATsbwk=
5
+ github.com/golang-jwt/jwt/v4 v4.1.0 h1:XUgk2Ex5veyVFVeLm0xhusUTQybEbexJXrvPNOKkSY0=
6
+ github.com/golang-jwt/jwt/v4 v4.1.0/go.mod h1:/xlHOz8bRuivTWchD4jCa+NbatV+wEUSzwAxVc6locg=
@@ -11,17 +11,18 @@ RSpec.describe FireJWT::Certificates do
11
11
  )
12
12
  end
13
13
 
14
- it 'should init' do
14
+ it 'inits' do
15
15
  expect(subject.expires_at).to be_within(10).of(Time.now + 3600)
16
16
  expect(subject).not_to be_expired
17
+ expect(http_request).to have_been_made
17
18
  end
18
19
 
19
- it 'should retrieve keys' do
20
+ it 'retrieves keys' do
20
21
  expect(subject.get('BAD')).to be_nil
21
22
  expect(subject.get(cert.kid)).to be_instance_of(OpenSSL::PKey::RSA)
22
23
  end
23
24
 
24
- it 'should check/update expiration status' do
25
+ it 'check/updates expiration status' do
25
26
  expect(subject).not_to be_expired
26
27
  subject.expire!
27
28
  expect(subject).to be_expired
@@ -1,6 +1,8 @@
1
1
  require 'spec_helper'
2
2
 
3
3
  RSpec.describe FireJWT::Validator do
4
+ subject { described_class.new(project_id) }
5
+
4
6
  let! :http_request do
5
7
  stub_request(:get, FireJWT::Certificates::URL.to_s).to_return(
6
8
  status: 200,
@@ -37,9 +39,7 @@ RSpec.describe FireJWT::Validator do
37
39
  let(:project_id) { 'mock-project' }
38
40
  let(:token) { JWT.encode payload, cert.pkey, 'RS256', kid: cert.kid }
39
41
 
40
- subject { described_class.new(project_id) }
41
-
42
- it 'should decode' do
42
+ it 'decodes' do
43
43
  decoded = subject.decode(token)
44
44
  expect(decoded).to be_instance_of(FireJWT::Token)
45
45
  expect(decoded).to eq(payload)
@@ -47,38 +47,39 @@ RSpec.describe FireJWT::Validator do
47
47
  'alg' => 'RS256',
48
48
  'kid' => cert.kid,
49
49
  )
50
+ expect(http_request).to have_been_made
50
51
  end
51
52
 
52
- it 'should reject bad tokens' do
53
+ it 'rejects bad tokens' do
53
54
  expect { subject.decode('BAD') }.to raise_error(JWT::DecodeError)
54
55
  end
55
56
 
56
- it 'should verify exp' do
57
+ it 'verifies exp' do
57
58
  payload['exp'] = Time.now.to_i - 1
58
59
  expect { subject.decode(token) }.to raise_error(JWT::ExpiredSignature)
59
60
  end
60
61
 
61
- it 'should verify iat' do
62
+ it 'verifies iat' do
62
63
  payload['iat'] = Time.now.to_i + 10
63
64
  expect { subject.decode(token) }.to raise_error(JWT::InvalidIatError)
64
65
  end
65
66
 
66
- it 'should verify aud' do
67
+ it 'verifies aud' do
67
68
  payload['aud'] = 'other'
68
69
  expect { subject.decode(token) }.to raise_error(JWT::InvalidAudError)
69
70
  end
70
71
 
71
- it 'should verify iss' do
72
+ it 'verifies iss' do
72
73
  payload['iss'] = 'other'
73
74
  expect { subject.decode(token) }.to raise_error(JWT::InvalidIssuerError)
74
75
  end
75
76
 
76
- it 'should verify sub' do
77
+ it 'verifies sub' do
77
78
  payload['sub'] = ''
78
79
  expect { subject.decode(token) }.to raise_error(JWT::InvalidSubError)
79
80
  end
80
81
 
81
- it 'should verify auth_time' do
82
+ it 'verifies auth_time' do
82
83
  payload['auth_time'] = Time.now.to_i + 10
83
84
  expect { subject.decode(token) }.to raise_error(FireJWT::InvalidAuthTimeError)
84
85
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: firejwt
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.0
4
+ version: 0.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Black Square Media Ltd
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-10-01 00:00:00.000000000 Z
11
+ date: 2021-12-01 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: jwt
@@ -53,7 +53,7 @@ dependencies:
53
53
  - !ruby/object:Gem::Version
54
54
  version: '0'
55
55
  - !ruby/object:Gem::Dependency
56
- name: rubocop
56
+ name: rubocop-bsm
57
57
  requirement: !ruby/object:Gem::Requirement
58
58
  requirements:
59
59
  - - ">="
@@ -87,9 +87,9 @@ executables: []
87
87
  extensions: []
88
88
  extra_rdoc_files: []
89
89
  files:
90
+ - ".github/workflows/test.yml"
90
91
  - ".gitignore"
91
92
  - ".rubocop.yml"
92
- - ".travis.yml"
93
93
  - Gemfile
94
94
  - Gemfile.lock
95
95
  - LICENSE
@@ -111,7 +111,8 @@ files:
111
111
  homepage: https://github.com/bsm/firejwt
112
112
  licenses:
113
113
  - Apache-2.0
114
- metadata: {}
114
+ metadata:
115
+ rubygems_mfa_required: 'true'
115
116
  post_install_message:
116
117
  rdoc_options: []
117
118
  require_paths:
@@ -127,7 +128,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
127
128
  - !ruby/object:Gem::Version
128
129
  version: '0'
129
130
  requirements: []
130
- rubygems_version: 3.1.2
131
+ rubygems_version: 3.2.15
131
132
  signing_key:
132
133
  specification_version: 4
133
134
  summary: Firebase JWT validation
data/.travis.yml DELETED
@@ -1,23 +0,0 @@
1
- matrix:
2
- include:
3
- - language: ruby
4
- rvm:
5
- - 2.7
6
- before_install:
7
- - gem install bundler
8
- - language: ruby
9
- rvm:
10
- - 2.6
11
- before_install:
12
- - gem install bundler
13
- - language: ruby
14
- rvm:
15
- - 2.5
16
- before_install:
17
- - gem install bundler
18
- - language: go
19
- go:
20
- - 1.15.x
21
- - language: go
22
- go:
23
- - 1.14.x