Mariano Cano
04f5053a7a
Add template support for x5c.
4 years ago
Mariano Cano
eb8886d828
Add CR subject as iid default subject.
...
Add a minimal subject with just a common name to iid provisioners
in case we want to use it.
4 years ago
Mariano Cano
e60ea419cc
Add template support for gcp provisioner.
4 years ago
Mariano Cano
32646c49bf
Add templates support to Azure provisioner.
4 years ago
Mariano Cano
a44f0ca866
Add token payload.
4 years ago
Mariano Cano
00fd41a3d0
Add template support to K8sSA provisioners.
4 years ago
Mariano Cano
13b704aeed
Add template support for AWS provisioner.
4 years ago
Mariano Cano
49b9aa6e3f
Fix log string.
4 years ago
Mariano Cano
4795e371bd
Add back the support for ca.json DN template.
4 years ago
Mariano Cano
e6fed5e0aa
Minor fixes and comments.
4 years ago
Mariano Cano
81cd288104
Enable templates in acme provisioners.
4 years ago
Mariano Cano
ca2fb42d68
Move options to the provisioner.
4 years ago
Mariano Cano
206bc6757a
Add initial support for templates in the OIDC provisioner.
4 years ago
Mariano Cano
95c3a41bf0
Rename UserData to TemplateData and fix unmarshaling.
4 years ago
Mariano Cano
9f3acc254b
Set the token payload in the JWK provisioner.
4 years ago
Mariano Cano
ef0ed0ff95
Integrate simple templates in the JWK provisioner.
4 years ago
Mariano Cano
9032018cf2
Convert x509util.WithOptions to new modifiers.
4 years ago
Carl Tashian
912e298043
Whitelist -> Allowlist per https://tools.ietf.org/id/draft-knodel-terminology-01.html
4 years ago
max furman
accf1be7e9
wip
4 years ago
max furman
71d87b4e61
wip
4 years ago
max furman
d25e7f64c2
wip
4 years ago
max furman
3636ba3228
wip
4 years ago
max furman
1951669e13
wip
4 years ago
max furman
7d5cf34ce5
Update profileLimitDuration validator ...
...
- respect notBefore of the provisioner
- modify/fix the reported errors
4 years ago
Mariano Cano
4ac51dd508
Merge pull request #274 from smallstep/oidc-raw-locals
...
Allow dots and other symbols in principals for OIDC
4 years ago
Mariano Cano
3246a3e81f
Add missing test case.
4 years ago
max furman
6e69f99310
Always set nbf and naf for new ACME orders ...
...
- Use the default value from the ACME provisioner if values are not
defined in the request.
4 years ago
Mariano Cano
0b5fd156e8
Add a third principal on OIDC tokens with the raw local part of the email.
...
For the email first.last@example.com it will create the principals
["firstlast", "first.last", "first.last@example.com"]
Fixes #253 , #254
4 years ago
Josh Hogle
e9b500daf2
Updated error message
4 years ago
Josh Hogle
044d00045a
Fixed missing initialization of IMDS versions
4 years ago
Josh Hogle
18ac5c07e2
Added support for specifying IMDS version preference
4 years ago
Josh Hogle
8c6a46887b
Added token URL fixes to tests
4 years ago
Josh Hogle
dd27901b12
Moved token URL and TTL to config values
4 years ago
Josh Hogle
bbbe4738c7
Added status code checking
4 years ago
Josh Hogle
af0f21d744
added support for IMDSv2 API
4 years ago
Oleksandr Kovalchuk
4cd01b6868
Implement tests for forceCNOption modifier
...
Implement unit tests which checks forceCNOption modifier (implemented
in 322200b7db
) is not broken and works
correctly.
Ref: https://github.com/smallstep/certificates/issues/259
4 years ago
Oleksandr Kovalchuk
893a53793a
Modify existing tests to accept forceCNOption modifier
...
Modify existing tests to pass with changes introduced in commit
322200b7db
. This is safe to do as
tests assert exact length of modifiers, which has changed.
4 years ago
Oleksandr Kovalchuk
322200b7db
Implement modifier to set CommonName
...
Implement modifier which sets CommonName to the certificate if
CommonName is empty and forceCN is set in the config. Replace previous
implementation introduced in 0218018cee
with new modifier.
Closes https://github.com/smallstep/certificates/issues/259
Ref: https://github.com/smallstep/certificates/pull/260#issuecomment-628961322
4 years ago
Oleksandr Kovalchuk
503c9f6101
Add config option to force CN
...
Add configuration option `forceCN` to ACME provisioner. When this option
is set to `true`, provisioner should generate Subject.CommonName for
certificate if it was not present in the request. Default value of
`false` should keep the existing behavior (do not modify CSR and
certificate).
Ref: https://github.com/smallstep/certificates/issues/259
4 years ago
Mariano Cano
4e9bff0986
Add support for OIDC multitoken tenants for azure.
5 years ago
Mariano Cano
a2dfa6faa8
Fix unit tests.
5 years ago
Mariano Cano
13507efb35
Remove the requirement for CSR to have a common name.
...
Fixes #226
5 years ago
Mariano Cano
bfe1f4952d
Rename interface to CertificateEnforcer and add tests.
5 years ago
Mariano Cano
64f26c0f40
Enforce a duration for identity certificates.
5 years ago
Mariano Cano
fa416336a8
Add context to tests.
5 years ago
Mariano Cano
c49a9d5e33
Add context parameter to all SSH methods.
5 years ago
Mariano Cano
f868e07a76
Allow to use custom principals on cloud provisioners.
...
Fixes #203
5 years ago
Mariano Cano
59fc8cdd2d
Fix typo in comments.
5 years ago
max furman
397a181d10
Add backdate validation to sshCertValidityValidator.
5 years ago
max furman
1cb8bb3ae1
Simplify statuscoder error generators.
5 years ago
max furman
dccbdf3a90
Introduce generalized statusCoder errors and loads of ssh unit tests.
...
* StatusCoder api errors that have friendly user messages.
* Unit tests for SSH sign/renew/rekey/revoke across all provisioners.
5 years ago
Mariano Cano
895d3054a3
Remove the use of custom x509 package.
...
Upgrade cli dependency.
5 years ago
Mariano Cano
144acb9ee3
Remove debug statement.
5 years ago
Mariano Cano
06411d1715
Add tests of profileLimitDuration with backdate.
5 years ago
Mariano Cano
8297e5c717
Add tests for backdate and sshDefaultDuration
5 years ago
Mariano Cano
93b65bee7c
Add unit test for profileDefaultDuration.
5 years ago
Mariano Cano
84ff172093
Add support for backdate to SSH certificates.
5 years ago
Mariano Cano
5565d61bf3
Add fault tolerance against clock skew accross system on TLS certificates.
5 years ago
Mariano Cano
08eac1b00d
Make sure to define the KeyID from the token if available.
5 years ago
max furman
9caadbb341
Fix authority calling wrong revoke method
5 years ago
max furman
414a94b210
Instrument getIdentity func for OIDC ssh provisioner
5 years ago
max furman
3d970b45c8
remove printfs
5 years ago
max furman
f74cd04a6a
Add WithGetIdentityFunc option and attr to authority
...
* Add Identity type to provisioner
5 years ago
Mariano Cano
a86dc78b5d
Add missing comment.
5 years ago
Mariano Cano
7db7b1ee4c
Fix some provisioner tests
5 years ago
Mariano Cano
d4627d1282
Make provisioner tests compile, they are still failing.
5 years ago
Mariano Cano
cf592fa0e1
Remove global check for number of k8sSA provisioners.
...
This was causing a bug in the reload of the ca.
5 years ago
max furman
5788ac3f4f
sshpop token should not allow renew/rekey of user ssh certs
5 years ago
max furman
54e3cf7322
Add multiuse capability to k8ssa provisioners
5 years ago
max furman
29853ae016
sshpop provisioner + ssh renew | revoke | rekey first pass
5 years ago
max furman
c04f1e1bd4
sshpop first pass
5 years ago
max furman
8f07ff6a39
Add kubernetes service account provisioner
5 years ago
max furman
d368791606
Add x5c provisioner capabilities
5 years ago
Mariano Cano
59526d3225
Merge pull request #105 from smallstep/okta-support
...
Address support on OIDC provisioners
5 years ago
Mariano Cano
39b41b5e83
Merge pull request #107 from smallstep/ssh-valid-after
...
Truncate to seconds ValidAfter
5 years ago
Mariano Cano
d59a5b222f
Truncate to seconds to avoid rounding up times.
...
It can cause that certs are not valid yet, if they are used right away.
5 years ago
max furman
fe7973c060
wip
5 years ago
Mariano Cano
adc1d54b0d
Define valid after as 1m before now.
...
It avoids errors with immediate use of cert.
5 years ago
Mariano Cano
72f1a61f06
Increase coverage.
5 years ago
Mariano Cano
b7045f27a9
Increase coverage.
5 years ago
Mariano Cano
a16b2125bc
Fix tests.
5 years ago
Mariano Cano
6c4abfabbb
Make /.well-known/openid-configuration optional
5 years ago
Mariano Cano
3527ee6940
Add support for listenAddress parameter if OIDC provisioners.
...
Fixes smallstep/cli#150
5 years ago
max furman
44e864030d
Remove debug logging
5 years ago
max furman
e3826dd1c3
Add ACME CA capabilities
5 years ago
max furman
d204469280
Add a few more validity checks to default ssh cert validator
5 years ago
Mariano Cano
396b4222aa
Implement validator for ssh keys.
...
Fixes #100
5 years ago
max furman
61d52a8510
Small fixes associated with PR review
...
* additions and grammar edits to documentation
* clarification of error msgs
5 years ago
Mariano Cano
10e7b81b9f
Merge branch 'master' into ssh-ca
5 years ago
max furman
ac234771c7
Remove unknown provisioner WARNning and leave TODO
5 years ago
max furman
ca8daf5f12
Update comment and warn
5 years ago
Mariano Cano
9200f11ed8
Skip unsupported provisioners.
5 years ago
max furman
2b41faa9cf
Enforce >= 2048 bit rsa keys at the provisioner layer
...
* Fixes #94
* In the future this should be configurable by provisioner
5 years ago
max furman
635c59ed24
Accept emails SANs
5 years ago
Mariano Cano
34e1e3380a
Fix lint errors.
5 years ago
Mariano Cano
57a529cc1a
Allow to enable the SSH CA per provisioner
5 years ago
Mariano Cano
e71072d389
Add experimental support for provisioning users.
5 years ago
Mariano Cano
dc657565a7
Add SSH test for GCP.
5 years ago
Mariano Cano
7983aa8661
Add azure ssh tests.
5 years ago
Mariano Cano
2cac85a8c8
Add aws tests.
5 years ago
Mariano Cano
f8a71899fd
Add missing file.
5 years ago
Mariano Cano
d231bfb764
Update jwk and oidc tests.
5 years ago
Mariano Cano
a8f4ad1b8e
Set default SSH options if no user options are given.
5 years ago
Mariano Cano
c17375a10a
Create convenient method to mock the timeduration.
5 years ago
Mariano Cano
4c1a11c1bc
Add Unix method to TimeDuration.
5 years ago
Mariano Cano
b0240772da
Add tests for SSH certs with JWK provisioners.
5 years ago
Mariano Cano
780eeb5487
Remove debug print.
5 years ago
Mariano Cano
ad91842d06
Add test for SanitizeSSHUserPrincipal
5 years ago
Mariano Cano
f8cacc11b1
Fix tests.
5 years ago
Mariano Cano
b827a59e96
Add SSH host certificate support for GCP provisioner.
5 years ago
Mariano Cano
221d323b68
Fix containsAllMembers
5 years ago
Mariano Cano
18a285e847
Change azure ssh key id.
5 years ago
Mariano Cano
aef52e4334
Add support for SSH host certificates in azure.
5 years ago
Mariano Cano
7d670b20ea
Add support of ssh host certinficates in AWS provisioner.
5 years ago
Mariano Cano
7583f1c739
Do not require all principals, allow subgroups.
5 years ago
Mariano Cano
41b97372e6
Rename function to SanitizeSSHUserPrincipal
5 years ago
Mariano Cano
53f62f871c
Set not extensions to host certificates.
5 years ago
Mariano Cano
48c98dea2a
Make SanitizeSSHPrincipal a public function.
5 years ago
Mariano Cano
f01286bb48
Add support for SSH certificates to OIDC.
...
Update the interface for all the provisioners.
5 years ago
Mariano Cano
082ebda85b
Merge branch 'master' of github.com:smallstep/certificates into ssh-ca
5 years ago
Mariano Cano
d7221e15ac
Always marshal timeduration as a string
5 years ago
Mariano Cano
3ff410c695
fix ssh validity modifier
5 years ago
Mariano Cano
1c8f610ca9
Add initial implementation of an SSH CA using the JWK provisioner.
...
Fixes smallstep/ca-component#187
5 years ago
Mariano Cano
f5beed3b96
Merge pull request #83 from matteo-s/oidc-groups
...
Add option for checking group membership declared in JWT token
5 years ago
Mariano Cano
3e69194cc4
Fix lint error
5 years ago
Mariano Cano
900ab9cc12
Allow custom common names in cloud identity provisioners.
5 years ago
Mariano Cano
5f4217ca4c
Simplify abs, it performs even better.
5 years ago
Matteo Saloni
1919cfdff3
Add option for checking group membership declared in JWT token
5 years ago
Mariano Cano
e66272d6f0
Fix panic when max-age is set to zero.
...
Fixes #81
5 years ago
Mariano Cano
8f8c862c04
Fix spelling errors.
5 years ago
Mariano Cano
b88a2f1373
Fix provisioner id in LoadByCertificate
5 years ago
Mariano Cano
37dff5124b
Fix audience tests.
...
Fixes smallstep/step#156
5 years ago
Mariano Cano
2491593cdd
Add ca-url based audience for AWS tokens
...
Fixes smallstep/step#156
5 years ago
Mariano Cano
4fa9e9333d
Add NewDuration constructor.
5 years ago
Mariano Cano
37f2096dff
Add Stringer interface to provisioner.Type.
...
Add missing file.
5 years ago
Mariano Cano
6e4a09651a
Add comments with links to cloud docs.
5 years ago
Mariano Cano
536ec36b9e
Add support for instance age check in AWS.
...
Fixes smallstep/step#164
5 years ago
Mariano Cano
c431538ff2
Add support for instance age check in GCP.
...
Fixes smallstep/step#164
5 years ago
Mariano Cano
4cef086c00
Allow to use emails as service accounts on GCP
...
Fixes smallstep/step#163
5 years ago
Mariano Cano
0a756ce9d0
Use on GCP audiences with the format https://<ca-url>#<provisioner-type>/<provisioner-name>
...
Fixes smallstep/step#156
5 years ago
Mariano Cano
a54bf925eb
Add filtering by GCP Project ID.
...
Fixes smallstep/step#155
5 years ago
Mariano Cano
54d0186d1f
Change condition to fail if the length is not the expected.
5 years ago
Mariano Cano
cf07c8f4c0
Fix typos.
5 years ago
Mariano Cano
423d505d04
Replace subscriptions with resource groups.
5 years ago
Mariano Cano
32d2d6b75a
Remove debug code.
5 years ago
Mariano Cano
e0aaa1a577
Use tenant id in azures's provisioner x509 extension.
5 years ago
Mariano Cano
89eeada2a2
Add support for loading azure tokens by tenant id.
5 years ago
Mariano Cano
803d81d332
Improve azure unit tests.
5 years ago
Mariano Cano
4c5fec06bf
Require TenantID in azure, add some tests.
5 years ago
Mariano Cano
12937c6b75
Remove pkcs7 related variables and structs.
5 years ago
Mariano Cano
6412b1a79b
Add first version of Asure support.
...
Fixes #69
5 years ago
Mariano Cano
70196b2331
Add skeleton for the Azure provisioner.
...
Related to #69
5 years ago
Mariano Cano
81bfd2c1cb
Add tests for AWS provisioner
...
Fixes #68
6 years ago
Mariano Cano
f755fddc35
Fix lint errors.
6 years ago
Mariano Cano
b6a5ebcfc9
Move code to switch default.
6 years ago
Mariano Cano
a7f06c765d
Fix load of gcp and aws provisioner by certificate.
6 years ago
Mariano Cano
da93e40f90
Add constant for Azure type.
6 years ago
Mariano Cano
37e84aa535
Add DisableCustomSANs and DisableTrustOnFirstUse to GCP provisioner.
...
Fixes #67
6 years ago
Mariano Cano
75ef5a2275
Add AWS provisioner.
...
Fixes #68
6 years ago
Mariano Cano
5defd8289d
Add missing config in tests.
6 years ago
Mariano Cano
2c68915b70
Fix comment.
6 years ago
Mariano Cano
fb6321fb2c
Use gcpConfig type to keep configuration urls.
...
Fixes #67
6 years ago
Mariano Cano
7e53b28320
Disable revoke for GCP.
6 years ago
Mariano Cano
7727fa5665
Update GCP tests.
6 years ago
Mariano Cano
1ea4b0ad64
Add unit test for GCP provider
6 years ago
Mariano Cano
b4729cd670
Use JWKSet to get the GCP keys.
6 years ago
Mariano Cano
f794dbeb93
Add support for GCP identity tokens.
6 years ago
max furman
ab4d569f36
Add /revoke API with interface db backend
6 years ago
Mariano Cano
7b9e08bcfa
Fix comment.
6 years ago
Mariano Cano
6d92ba75b9
Don't use pointer in TimeDuration.MarshalJSON
6 years ago
Mariano Cano
698058baa9
Add tests for TimeDuration.
6 years ago
Mariano Cano
00fed1c538
Add initial version of time duration support in sign requests.
6 years ago
Mariano Cano
76618558ae
Improve unit tests.
6 years ago
Mariano Cano
7378ed27ac
Refactor claims so they can be totally omitted if only the parent is set.
6 years ago
Mariano Cano
5d5f03f963
Set omitempty to admins and domains.
6 years ago
Mariano Cano
60880d1f0a
Add domains and check emails properly.
6 years ago
Mariano Cano
5edbce017f
Set docs for client secret as mandatory, but it can be blank.
6 years ago
Mariano Cano
2c0c0112c6
Add an optional client secret field.
6 years ago
Mariano Cano
945a1371f1
Fix tests.
6 years ago
Mariano Cano
0b4cde1ad3
Move type to the first position of the struct.
6 years ago
Mariano Cano
23e6de57a2
Address comments in code review.
6 years ago
Mariano Cano
7fd737cbb1
Fix lint warnings.
6 years ago
Mariano Cano
1a9e8bad74
Truncate to seconds instead of rounding.
6 years ago
Mariano Cano
ef4d809ee6
Move matchesAudience and stripPort tests to provisioner package.
6 years ago
Mariano Cano
636d92b19b
Add missing files.
6 years ago
Mariano Cano
a8d03c39bb
Move Duration to a new file and move tests to provisioner package.
6 years ago
Mariano Cano
c24d868d9d
Add tests for sign options.
6 years ago
Mariano Cano
5dfcbcf5dc
Add noop tests.
6 years ago
Mariano Cano
4ceb88fbae
Add tests for OIDC and complete some JWK tests.
6 years ago
Mariano Cano
dce3100cfb
Add missing time in validation.
6 years ago
Mariano Cano
fb279c89fb
Restore deleted methods.
6 years ago
Mariano Cano
955405d6aa
Add some comments added to master.
6 years ago
Mariano Cano
af9688c419
Fix some testing errors.
6 years ago
Mariano Cano
f17d2d9694
Remove debug statements.
6 years ago
Mariano Cano
67c79fd014
Add tests for default provisioner.
6 years ago
Mariano Cano
cf2dba3efb
Add tests for keyStore.
6 years ago
Mariano Cano
2a5430fee1
Complete tests for collection.
6 years ago
Mariano Cano
54d86ca1c1
testing work in progress.
6 years ago
Mariano Cano
9f7f871f25
Add noop provisioner and use it if a provisioner cannot been found from a cert.
6 years ago
Mariano Cano
47817ab212
Fix interface type.
6 years ago
Mariano Cano
cc8764c343
Initialize the list for backward compatibility.
6 years ago
Mariano Cano
a97ea87caa
Move options to provisioner so we can set the duration of the cert.
6 years ago
Mariano Cano
507fd01062
Remove provisioner intermediate type.
6 years ago
Mariano Cano
1671ab2590
Fix some tests.
6 years ago
Mariano Cano
d92a7f2948
Rename provisioner to jwk.
6 years ago
Mariano Cano
a1782733fe
Rename files.
6 years ago
Mariano Cano
2d00cd0933
Validate audiences in the default provisioner.
6 years ago
Mariano Cano
9d4034fbf6
Remove unused code.
6 years ago
Mariano Cano
6d395f3818
Add missing validy validator to oidc.
6 years ago
Mariano Cano
54ed49f072
Rename package.
6 years ago
Mariano Cano
34833d4fd5
Add validators from the authority package.
6 years ago
Mariano Cano
0dee841a4f
Complete first version of provisioner implementations.
6 years ago
Mariano Cano
7eb6eb1d3e
Complete provisioner.Claims with methods from authority.
6 years ago
Mariano Cano
fb77397fc7
Add new options to locate or list provisioners.
6 years ago
Mariano Cano
62dab7b6b8
Rename interface method.
6 years ago
Mariano Cano
5a8f78d9d0
Add support to collection to load the encrypted keys.
6 years ago
Mariano Cano
dd0376657c
Move collection to a new file.
6 years ago
Mariano Cano
4b2b6ffe32
Create the provisioner type used to englobe all different provisioners.
6 years ago
Mariano Cano
bed3132028
Move provisioner to authority/provisioner package.
6 years ago
Mariano Cano
fc0b2ca5a6
Revert "Move provisioners to authority/provisioner package."
...
This reverts commit f88d622a67
.
6 years ago
Mariano Cano
f88d622a67
Move provisioners to authority/provisioner package.
6 years ago
Mariano Cano
a2a45f635b
Add initial implementation of an OIDC provisioner.
6 years ago