Herman Slatman
f81d49d963
Add first working version of External Account Binding
3 years ago
Mariano Cano
dd9850ce4c
Add working implementation of the linkedca.
...
Replaces the authority adminDB with a new impmentation that users the
linkedca client to retrieve the data.
Note that this implementation still hardcodes the endpoint to localhost.
3 years ago
Mariano Cano
49c1427d15
Use authorityId instead of authorityID.
...
In json or javascript world authorityId, userId, ... are more common
than authorityID, ...
3 years ago
Herman Slatman
258efca0fa
Improve revocation authorization
3 years ago
Herman Slatman
8f7e700f09
Merge branch 'master' into hs/acme-revocation
3 years ago
max furman
1df21b9b6a
Addressing comments in PR review
...
- added a bit of validation to admin create and update
- using protojson where possible in admin api
- fixing a few instances of admin -> acme in errors
3 years ago
max furman
5679c9933d
Fixes from PR review
3 years ago
max furman
77fdfc9fa3
Merge branch 'master' into max/cert-mgr-crud
3 years ago
max furman
9fdef64709
Admin level API for provisioner mgmt v1
3 years ago
Herman Slatman
84e7d468f2
Improve handling of ACME revocation
3 years ago
Herman Slatman
7e82bd6ef3
Add setup for Authority tests
3 years ago
Herman Slatman
a64974c179
Fix small typo in divisible
3 years ago
Herman Slatman
d46a4eaca4
Change fmt to errors package for formatting errors
3 years ago
Herman Slatman
2beea1aa89
Add configuration option for specifying the minimum public key length
...
Instead of using the defaultPublicKeyValidator a new validator called
publicKeyMinimumLengthValidator has been implemented that uses a
configurable minimum length for public keys in CSRs.
It's also an option to alter the defaultPublicKeyValidator to also
take a parameter, but that would touch quite some lines of code. This
might be a viable option after merging SCEP support.
3 years ago
Herman Slatman
4168449935
Fix typo
3 years ago
Herman Slatman
fa100a5138
Mask challenge password after it has been read
3 years ago
Herman Slatman
13fe7a0121
Make serving SCEP endpoints optional
...
Only when a SCEP provisioner is enabled, the SCEP endpoints
will now be available.
The SCEP endpoints will be served on an "insecure" server,
without TLS, only when an additional "insecureAddress" and a
SCEP provisioner are configured for the CA.
3 years ago
Herman Slatman
97b88c4d58
Address (most) PR comments
3 years ago
Herman Slatman
be528da709
Make tests green
3 years ago
Herman Slatman
57a62964b1
Make tests not fail hard on ECDSA keys
...
All tests for the Authority failed because the test data
contains ECDSA keys. ECDSA keys are no crypto.Decrypter,
resulting in a failure when instantiating the Authority.
3 years ago
Herman Slatman
491c2b8d93
Improve initialization of SCEP authority
3 years ago
Herman Slatman
2d85d4c1c1
Add non-TLS server and improve crypto.Decrypter interface
...
A server without TLS was added to serve the SCEP endpoints. According
to the RFC, SCEP has to be served via HTTP. The `sscep` client, for
example, will stop any URL that does not start with `http://` from
being used, so serving SCEP seems to be the right way to do it.
This commit adds a second server for which no TLS configuration is
configured. A distinct field in the configuration, `insecureAddress`
was added to specify the address for the insecure server.
The SCEP endpoints will also still be served via HTTPS. Some clients
may be able to work with that.
This commit also improves how the crypto.Decrypter interface is
handled for the different types of KMSes supported by step. The
apiv1.Decrypter interface was added. Currently only SoftKMS
implements this interface, providing a crypto.Decrypter required
for SCEP operations.
3 years ago
Herman Slatman
e7cb80f880
Fix linter issues
3 years ago
Herman Slatman
4fe7179b95
Add support for configuring capabilities (cacaps)
3 years ago
Herman Slatman
3b86550dbf
Add support for challenge password
3 years ago
Herman Slatman
da65f46d0f
Add AuthorizeSign method to SCEP authority
3 years ago
Herman Slatman
2a249d20de
Refactor initialization of SCEP authority
3 years ago
Herman Slatman
339039768c
Refactor SCEP authority initialization and clean some code
3 years ago
Herman Slatman
48c86716a0
Add rudimentary (and incomplete) support for SCEP
3 years ago
max furman
94ba057f01
wip
3 years ago
max furman
01a4460812
wip
3 years ago
max furman
1726076ea2
wip
3 years ago
max furman
423942da44
wip
3 years ago
max furman
9bfb1c2e7b
wip
3 years ago
max furman
d8d5d7332b
wip
3 years ago
max furman
5929244fda
wip
3 years ago
max furman
9bf9bf142d
wip
3 years ago
Herman Slatman
375687cd1b
Add setup for Authority tests
3 years ago
max furman
638766c615
wip
3 years ago
max furman
4f3e5ef64d
wip
3 years ago
max furman
5d09d04d14
wip
3 years ago
max furman
4d48072746
wip admin CRUD
3 years ago
max furman
98a6e54530
wip
3 years ago
max furman
af3cf7dae9
first steps
3 years ago
max furman
2f60f20b0b
lots of codes
3 years ago
max furman
7b5d6968a5
first commit
3 years ago
Herman Slatman
a3ec890e71
Fix small typo in divisible
3 years ago
Herman Slatman
d0a9cbc797
Change fmt to errors package for formatting errors
3 years ago
Herman Slatman
ff1b46c95d
Add configuration option for specifying the minimum public key length
...
Instead of using the defaultPublicKeyValidator a new validator called
publicKeyMinimumLengthValidator has been implemented that uses a
configurable minimum length for public keys in CSRs.
It's also an option to alter the defaultPublicKeyValidator to also
take a parameter, but that would touch quite some lines of code. This
might be a viable option after merging SCEP support.
3 years ago
Herman Slatman
c04f556dc2
Merge branch 'master' into hs/scep
3 years ago
Cristian Le
d7eec869c2
Fix the previous tests
3 years ago
Cristian Le
c2d30f7260
gofmt everything
3 years ago
Cristian Le
f38a72a62b
Leftover from previous commit
3 years ago
Cristian Le
1d2445e1d8
Removed the variadic username
...
Could be useful later on, but for the current PR changes should be minimized
3 years ago
Cristian Le
9e00b82bdf
Revert `oidc_test.go`
...
Moving the `preferred_username` to a separate PR
3 years ago
Cristian Le
decf0fc8ce
Revert using preferred_username
...
It might present a security issue if the users can change this value for themselves. Needs further investigation
3 years ago
Cristian Le
21732f213b
Fix shadow issue in CI
3 years ago
Mariano Cano
08e5ec6ad1
Fix IsAdminGroup comment.
3 years ago
Mariano Cano
46c1dc80fb
Use map[string]struct{} instead of map[string]bool
3 years ago
Mariano Cano
aafac179a5
Add test for oidc with preferred usernames.
3 years ago
Cristian Le
f730c0bec4
Sanitize usernames
3 years ago
Cristian Le
48666792c7
Draft: adding usernames to GetIdentityFunc
3 years ago
Cristian Le
79eec83f3e
Rename and reformat to PreferredUsername
3 years ago
Cristian Le
09a21fef26
Implement #550
...
- Read `preferred_username` from token
- Add `preferred_username` to the default Usernames
- Check the `admin` array for admin groups that the user might belong to
3 years ago
max furman
8c709fe3c2
Init config on load | Add wrapper for cli
3 years ago
Mariano Cano
2cbaee9c1d
Allow to use an alternative interface to store renewed certs.
...
This can be useful to know if a certificate has been renewed and
link one certificate with the 'parent'.
3 years ago
Herman Slatman
68d5f6d0d2
Merge branch 'master' into hs/scep
3 years ago
Mariano Cano
e6833ecee3
Add extension of db.AuthDB to store the fullchain.
...
Add a temporary solution to allow an extension of an db.AuthDB
interface that logs the fullchain of certificates instead of just
the leaf.
3 years ago
Herman Slatman
2336936b5c
Fix typo
4 years ago
Herman Slatman
9787728fbd
Mask challenge password after it has been read
4 years ago
Herman Slatman
0487686f69
Merge branch 'master' into hs/scep
4 years ago
Max
b724af30ad
Merge pull request #496 from smallstep/max/acme
...
Convert to ACME DB interface
4 years ago
Mariano Cano
aea2a7c9f3
Update sshd_config.tpl to a Match all block.
...
Fixes #479
4 years ago
Herman Slatman
b815478981
Make serving SCEP endpoints optional
...
Only when a SCEP provisioner is enabled, the SCEP endpoints
will now be available.
The SCEP endpoints will be served on an "insecure" server,
without TLS, only when an additional "insecureAddress" and a
SCEP provisioner are configured for the CA.
4 years ago
Herman Slatman
c5e4ea08b3
Merge branch 'master' into hs/scep
4 years ago
max furman
2ae43ef2dc
[acme db interface] wip errors
4 years ago
Mariano Cano
0b8528ce6b
Allow mTLS revocation without provisioner.
4 years ago
Herman Slatman
583d60dc0d
Address (most) PR comments
4 years ago
Mariano Cano
bcf70206ac
Add support for revocation using an extra provisioner in the RA.
4 years ago
Mariano Cano
a6115e29c2
Add initial implementation of StepCAS.
...
StepCAS allows to configure step-ca as an RA using another step-ca
as the main CA.
4 years ago
Herman Slatman
a4844fee7b
Make tests green
4 years ago
Herman Slatman
99952080c7
Make tests not fail hard on ECDSA keys
...
All tests for the Authority failed because the test data
contains ECDSA keys. ECDSA keys are no crypto.Decrypter,
resulting in a failure when instantiating the Authority.
4 years ago
Herman Slatman
e1cab4966f
Improve initialization of SCEP authority
4 years ago
Herman Slatman
8c5b12e21d
Add non-TLS server and improve crypto.Decrypter interface
...
A server without TLS was added to serve the SCEP endpoints. According
to the RFC, SCEP has to be served via HTTP. The `sscep` client, for
example, will stop any URL that does not start with `http://` from
being used, so serving SCEP seems to be the right way to do it.
This commit adds a second server for which no TLS configuration is
configured. A distinct field in the configuration, `insecureAddress`
was added to specify the address for the insecure server.
The SCEP endpoints will also still be served via HTTPS. Some clients
may be able to work with that.
This commit also improves how the crypto.Decrypter interface is
handled for the different types of KMSes supported by step. The
apiv1.Decrypter interface was added. Currently only SoftKMS
implements this interface, providing a crypto.Decrypter required
for SCEP operations.
4 years ago
Herman Slatman
538fe8114d
Fix linter issues
4 years ago
Herman Slatman
2536a08dc2
Add support for configuring capabilities (cacaps)
4 years ago
Herman Slatman
e4d7ea8fa0
Add support for challenge password
4 years ago
Herman Slatman
311c9d767b
Add AuthorizeSign method to SCEP authority
4 years ago
Herman Slatman
7ad90d10b3
Refactor initialization of SCEP authority
4 years ago
Herman Slatman
9e43dc85d8
Merge branch 'master' into hs/scep-master
4 years ago
Herman Slatman
713b571d7a
Refactor SCEP authority initialization and clean some code
4 years ago
Herman Slatman
ffdd58ea3c
Add rudimentary (and incomplete) support for SCEP
4 years ago
Mariano Cano
fbd2208044
Close key manager for safe reloads when a cgo module is used.
4 years ago
max furman
16665c97f0
Allow empty SAN in CSR for validation ...
...
- The default template will always use the SANs from the token.
- If there are any SANs they must be validated against the token.
4 years ago
Miclain Keffeler
cf063d1f4a
Revert "Begins to fix issue 87"
...
This reverts commit e2ba4159c3
.
4 years ago
Miclain Keffeler
21dc406382
Begins to fix issue 87
4 years ago
Miclain Keffeler
7545b4a625
leverage intermediate_ca.crt for appending certs.
4 years ago
Mariano Cano
5017b7d21f
Recalculate token id instead of validating it.
4 years ago
Mariano Cano
86c947babc
Upgrade crypto and fix test.
4 years ago
Mariano Cano
0cf594a003
Validate payload ID.
...
Related to #435
4 years ago
Anton Lundin
3e6137110b
Add support for using ssh-agent as a KMS
...
This adds a new KMS, SSHAgentKMS, which is a KMS to provide signing keys
for issuing ssh certificates signed by a key managed by a ssh-agent. It
uses the golang.org/x/crypto package to get a native Go implementation
to talk to a ssh-agent.
This was primarly written to be able to use gpg-agent to provide the
keys stored in a YubiKeys openpgp interface, but can be used for other
setups like proxying a ssh-agent over network.
That way the signing key for ssh certificates can be kept in a
"sign-only" hsm.
This code was written for my employer Intinor AB, but for simplicity
sake gifted to me to contribute upstream.
Signed-off-by: Anton Lundin <glance@acc.umu.se>
4 years ago
Mariano Cano
39b23c057d
Add all AWS certificates used to verify base64 signatures.
4 years ago
Mariano Cano
ef92a3a6d7
Move cas options under authority.
4 years ago
Mariano Cano
7d1686dc53
Add option to specify the AWS IID certificates to use.
...
This changes adds a new option `iidRoots` that allows a user to
define one or more certificates that will be used for AWS IID
signature validation.
Fixes #393
4 years ago
Mariano Cano
647b9b4541
Merge pull request #367 from smallstep/cas
...
Support for CAS Interface and CloudCAS
4 years ago
Mariano Cano
3e0ab8fba7
Fix typo.
4 years ago
Mariano Cano
d64427487d
Add comment about the missing error check.
4 years ago
Mariano Cano
072adc906e
Print root fingerprint for CloudCAS.
4 years ago
Mariano Cano
38fa780775
Add interface to get root certificate from CAS.
...
This change makes easier the configuration of cloudCAS as it does
not require to configure the root or intermediate certificate
in the ca.json. CloudCAS will get the root certificate using
the configured certificateAuthority.
4 years ago
Mariano Cano
4c8bf87dc1
Use new admin template for K8ssa and admin-OIDC provisioners.
...
This change replaces the .Insecure.CR template to one that sets
all the SANs, but uses key usages and extended key usages for
regular TLS certificates.
4 years ago
Mariano Cano
d79b4e709e
Create a hash of a token if a token id is empty.
4 years ago
Mariano Cano
60515d92c5
Remove unnecessary properties.
4 years ago
Mariano Cano
1550a21f68
Fix unit tests.
4 years ago
Mariano Cano
e17ce39e3a
Add support for Revoke using CAS.
4 years ago
Mariano Cano
bd8dd9da41
Do not read issuer and signer twice.
4 years ago
Mariano Cano
aad8f9e582
Pass issuer and signer to softCAS options.
...
Remove commented code and initialize CAS properly.
Minor fixes in CloudCAS.
4 years ago
Mariano Cano
1b1f73dec6
Early attempt to develop a CAS interface.
4 years ago
Mariano Cano
276e307a1d
Add extra tests for CustomSSHTemplateOptions
4 years ago
max furman
da9f0b09af
Ignore `null` string for x509 and ssh templateData.
4 years ago
Mariano Cano
81c6e01269
Fix unit test.
4 years ago
max furman
ce9af5c20f
Standardize k8ssa check on issuer name
4 years ago
Mariano Cano
8ee246edda
Upgrade go.step.sm to v0.4.0
4 years ago
Mariano Cano
ce5e1b4934
Fix merge issue.
4 years ago
Mariano Cano
35bd3ec383
Merge pull request #329 from smallstep/ssh-cert-templates
...
SSH cert templates
4 years ago
Mariano Cano
cef0475e71
Make clear what's a template/unsigned certificate.
4 years ago
Mariano Cano
4d375a06f5
Make clearer what's an unsigned cert.
4 years ago
Mariano Cano
b7269b6579
Fix comment.
4 years ago
Mariano Cano
c94a1c51be
Merge branch 'master' into ssh-cert-templates
4 years ago
Mariano Cano
ba918100d0
Use go.step.sm/crypto/jose
...
Replace use of github.com/smallstep/cli/crypto with the new package
go.step.sm/crypto/jose.
4 years ago
max furman
46fc922afd
Remove unused code; fix usage wrong word; add gap time for unit test
4 years ago
max furman
81875074e3
tie -> the in comment
4 years ago
max furman
cb594ed2e0
go mod tidy and golang 1.15.0 cleanup ...
...
- cs.NegotiatedProtocolIsMutual has been deprecated but we still build
in travis with 1.14 so for now we'll ignore this linting error
- string(int) was resolving to string of a single rune rather than
string of digits -> use fmt.Sprint
4 years ago
Mariano Cano
b900a7a2fc
Fix error message in tests.
4 years ago
Mariano Cano
d30a95236d
Use always go.step.sm/crypto
4 years ago
Mariano Cano
aaaa7e9b4e
Merge branch 'master' into cert-templates
4 years ago
Mariano Cano
3577d696c7
Use new x509util in tls_test.go
4 years ago
Mariano Cano
0a59efd853
Use new x509util to generate the CA certificate.
4 years ago
Mariano Cano
4943ae58d8
Move TLSOption, TLSVersion, CipherSuites and ASN1DN to certificates.
4 years ago
Mariano Cano
e83e47a91e
Use sshutil and randutil from go.step.sm/crypto.
4 years ago
Mariano Cano
ce1eb0a01b
Use new x509util for renew/rekey.
4 years ago
Mariano Cano
f437b86a7b
Merge branch 'cert-templates' into ssh-cert-templates
4 years ago
Mariano Cano
c8d225a763
Use x509util from go.step.sm/crypto/x509util
4 years ago
Mariano Cano
37f84e9bb3
Add delay in test.
4 years ago
Mariano Cano
342cb713ee
Add test with custom templates.
4 years ago
Mariano Cano
8d89bbd62f
Remove unused code.
4 years ago
Mariano Cano
c4bbc81d9f
Fix authority tests.
4 years ago
Mariano Cano
413af88aad
Fix provisioning tests.
4 years ago
Mariano Cano
b66bdfabcd
Enforce an OIDC users to send all template variables.
4 years ago
Mariano Cano
9822305bb6
Use only the IID template on IID provisioners.
...
Use always sshutil.DefaultIIDCertificate and require at least one
principal on IID provisioners.
4 years ago
Mariano Cano
aa657cdb4b
Use SSHOptions inside provisioner options.
4 years ago
Mariano Cano
02379d494b
Add support for extensions and critical options on the identity
...
function.
4 years ago
Mariano Cano
8ff8d90f8c
On JWK and X5C validate the key id on the request.
4 years ago
Mariano Cano
a78f7e8913
Add template support on k8ssa provisioner.
4 years ago
Mariano Cano
6c36ceb158
Add initial template support for iid provisisioners.
4 years ago
Mariano Cano
8e7bf96769
Fix error prefix.
4 years ago
Mariano Cano
e0dce54338
Add missing argument.
4 years ago
Mariano Cano
c1fc45c872
Simplify SSH modifiers with options.
...
It also changes the behavior of the request options to modify only
the validity of the certificate.
4 years ago
Mariano Cano
ad28f0f59a
Move variable where it is used.
4 years ago
Mariano Cano
715eb4eacc
Add initial support for ssh templates on OIDC.
4 years ago
Mariano Cano
c2dc76550c
Add ssh certificate template to X5C provisioner.
4 years ago
Mariano Cano
380a0d6daf
Add ssh certificate templates to JWK provisioner.
4 years ago
Mariano Cano
f75a12e10a
Add omitempty tag option.
4 years ago
Mariano Cano
d7e590908e
Use sshutil for ssh renewing and rekeying.
4 years ago
Mariano Cano
b66d123572
Use sshutil for SSH certificate signing.
4 years ago
Mariano Cano
570ede45e7
Do not enforce number of principals or extensions.
4 years ago
Mariano Cano
631f1612a1
Add TemplateData to SignSSHOptions.
4 years ago
Mariano Cano
c6746425a3
Add methods to initialize ssh templates in provisioners.
4 years ago
Mariano Cano
3e80f41c19
Change provisioner options to have X509 as a field.
4 years ago
max furman
3f844c5e23
Update the way SubjectKeyId is calculated, and more ...
...
- swith lint to first in line for `make all`
- update tests to conform with new subjectkeyid
4 years ago
Mariano Cano
a7b65f1e1e
Add authority.Sign test with custom templates.
4 years ago
David Cowden
86efe7aff0
aws: use http.NoBody instead of nil
...
It's a little more descriptive.
4 years ago
David Cowden
2b121efc8f
aws: test constructor with empty IDMS string array
4 years ago
Mariano Cano
6c64fb3ed2
Rename provisioner options structs:
...
* provisioner.ProvisionerOptions => provisioner.Options
* provisioner.Options => provisioner.SignOptions
* provisioner.SSHOptions => provisioner.SingSSHOptions
4 years ago
David Cowden
dc39eef721
aws: test badIDMS functional path
...
The existing test only covers the constructor logic. Also test the live
code path that is executed when a bad IDMS version is supplied.
4 years ago
David Cowden
51f16ee2e0
aws: add tests covering metadata service versions
...
* Add constructor tests for the aws provisioner.
* Add a test to make sure the "v1" logic continues to work.
By and large, v2 is the way to go. However, there are some instances of
things that specifically request metadata service version 1 and so this
adds minimal coverage to make sure we don't accidentally break the path
should anyone need to depend on the former logic.
4 years ago
David Cowden
5efe5f3573
metadata-v2: pull in joshathysolate-master
...
Taking of this PR to get it across the goal line.
4 years ago
Mariano Cano
978ad7e2b6
Fix merged tests.
4 years ago
Mariano Cano
5ac3f8a160
Add provisioner options tests.
4 years ago
Mariano Cano
02c4f9817d
Set full token payload instead of only the known properties.
4 years ago
Mariano Cano
0c8376a7f6
Fix existing unit tests.
4 years ago
Mariano Cano
d64cb99a22
Fix authority package tests.
4 years ago
Mariano Cano
ccc705cdcd
Use alias x509legacy to cli x509util in tls.go.
4 years ago
Mariano Cano
8f0dd811af
Allow to send errors from template to cli.
4 years ago
Mariano Cano
a7fe0104c4
Remove ACME restrictions and add proper template support.
4 years ago
Mariano Cano
cf2989a848
Add token and subject to K8sSA provisioner to be used in custom
...
templates.
4 years ago
Mariano Cano
71be83b25e
Add iss#sub uri in OIDC certificates.
...
Admin will use the CR template if none is provided.
4 years ago
Mariano Cano
c58117b30d
Allow to use base64 when defining a template in the ca.json.
4 years ago
Mariano Cano
b2ca3176f5
Prepend insecure to user and CR variables names.
4 years ago
Mariano Cano
b11486f41f
Fix option method for template variable.
4 years ago
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
d1d9ae42d6
Use certificates x509util instead of cli for certificate signing.
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
fd05f3249b
A few last fixes and tests added for rekey/renew ...
...
- remove all `renewOrRekey`
- explicitly test difference between renew and rekey (diff pub keys)
- add back tests for renew
4 years ago
Max
ea9bc493b8
Merge pull request #307 from dharanikumar-s/master
...
Add support for rekeying Fixes #292
4 years ago
dharanikumar-s
57fb0c80cf
Removed calculating SubjectKeyIdentifier on Rekey
4 years ago
dharanikumar-s
dfda497929
Renamed RenewOrRekey to Rekey
4 years ago
dharanikumar-s
fe73154a20
Corrected misspelling
4 years ago
dharanikumar-s
0c21f0ae9e
Added error check after GenerateDefaultKeyPair
4 years ago
dharanikumar-s
2479371c06
Added error check while marshalling public key
4 years ago
dharanikumar-s
b368a53149
Modified TestAuthority_Renew to TestAuthority_RenewOrRekey
4 years ago
dharanikumar-s
c8c3581e2f
SubjectKeyIdentifier extention is calculated from public key passed to this function instead of copying from old certificate
4 years ago
dharanikumar-s
8f504483ce
Added RenewOrRekey function based on @maraino suggestion. RenewOrReky is called from Renew.
4 years ago
dharanikumar-s
3813f57b1a
Add support for rekeying Fixes #292
4 years ago
Max
debce1cec2
Merge pull request #299 from smallstep/max/refactor
...
Refactor
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
Mariano Cano
39650637d4
Merge pull request #297 from smallstep/no-bastion-bastion
...
Do not return bastion for the configured bastion host.
4 years ago
Mariano Cano
fcfc4e9b2b
Fix ssh federated template variables.
4 years ago
max furman
1951669e13
wip
4 years ago
Mariano Cano
b0fdd0b2be
Do not return bastion for the configured bastion host.
...
Fixes #296
4 years ago
Mariano Cano
ff32746312
Add test case for error executing template.
4 years ago
Mariano Cano
e3ae751b57
Use templates from authority instead of config.
4 years ago
Mariano Cano
237baa5169
Check for required variables in templates.
...
Fixes smallstep/cli#232
4 years ago
Mariano Cano
6c844a0618
Load default templates if no templates are configured.
4 years ago
Max
2ebfc73f77
Merge pull request #290 from smallstep/max/profileLimit
...
Update profileLimitDuration validator ...
4 years ago
max furman
7d5cf34ce5
Update profileLimitDuration validator ...
...
- respect notBefore of the provisioner
- modify/fix the reported errors
4 years ago
Mariano Cano
9832d1538b
Avoid nil pointer panic on step ssh config with no templates.
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
Mariano Cano
2bc69d3edd
Merge pull request #252 from smallstep/yubikey
...
Yubikey support
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
c02fe77998
Close the key manager before shutting down.
4 years ago
Mariano Cano
4e544344f9
Initialize the required config fields on embedded authorities.
...
This change is to make easier the use of embedded authorities. It
can be difficult for third parties to know what fields are required.
The new init methods will define the minimum usable configuration.
4 years ago
Mariano Cano
b5eab009b2
Rename method to NewEmbedded
4 years ago
Mariano Cano
824374bde0
Create a method to initialize the authority without a config file.
...
When the CA is embedded in a third party product like Caddy, the
config needed to use placeholders to be valid. This change adds
a new method `NewEmbeddedAuthority` that allows to create an
authority with the given options, the minimum options are a root
and intermediate certificate, and the intermediate key.
Fixes #218
4 years ago
Mariano Cano
4e9bff0986
Add support for OIDC multitoken tenants for azure.
5 years ago
Mariano Cano
8bc3b05232
Add new extra test case.
5 years ago
Mariano Cano
b0ff731d18
Add support for user provisioner certificates on OIDC provisioners.
...
OIDC provisioners create an SSH certificate with two principals. This
was avoiding the creationg of user provisioner certificates for those
provisioners.
Fixes smallstep/cli#268
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
02ed784a9b
Do not enable by default ForwardAgent.
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
Mariano Cano
5c8c741fab
Fix linting issues.
5 years ago
Mariano Cano
05cc1437b7
Remove unnecessary parse of certificate.
5 years ago
Mariano Cano
2d4f369db2
Add options to set root and federated certificates using x509.Certificate
5 years ago
Mariano Cano
43bd8113aa
Remove unnecessary comments.
5 years ago
Mariano Cano
4eaeede77d
Fix unit tests.
5 years ago
Mariano Cano
21bd339b86
Merge branch 'master' into kms
5 years ago
Mariano Cano
7846696fbb
Fix return sign options on ssh sign.
5 years ago
max furman
d482ae2fb5
Remove test that is no longer implemented by the method.
5 years ago
max furman
397a181d10
Add backdate validation to sshCertValidityValidator.
5 years ago
max furman
df60fe3f0d
Remove all references to old apiError.
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
74b5d7f984
Add backdate support on ssh rekey.
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
max furman
b9f6aacb0f
Move api errors to their own package and modify the typedef
5 years ago
Mariano Cano
f033422ffa
Allow no provisioners.
5 years ago
Mariano Cano
f4615d6258
Addapt test to api change.
5 years ago
max furman
3ac388612a
Use x5cInsecure token for /ssh/check-host endpoint
5 years ago
Mariano Cano
08eac1b00d
Make sure to define the KeyID from the token if available.
5 years ago
Mariano Cano
de3ba58455
Store renew certificate in the database.
5 years ago
Mariano Cano
caa2b8dbb7
Add leeway in identity not before.
5 years ago
max furman
9caadbb341
Fix authority calling wrong revoke method
5 years ago
Mariano Cano
f26103d150
Make test compilable.
5 years ago
Mariano Cano
557a45abfa
Update template tests.
5 years ago
max furman
656f35e522
Use an actual Hosts type when returning ssh hosts
5 years ago
Mariano Cano
03bb26fb91
Add missing version.go file.
5 years ago
Mariano Cano
c60641701b
Add version endpoint.
5 years ago
max furman
f92bb06b6c
change func def for getSSHHosts
...
* continue to return all hosts if injection method not specified
5 years ago
Mariano Cano
11c8639782
Add identity certificate in ssh response.
5 years ago
max furman
d940ab7c20
Add getSSHHosts injection func
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
8bf3bf701e
Add support for /ssh/bastion method.
5 years ago
Mariano Cano
a6edcd0a3d
Make test to compile, they still fail.
5 years ago
Mariano Cano
000885dea7
Move Option type to a new file.
5 years ago
Mariano Cano
a86dc78b5d
Add missing comment.
5 years ago
Mariano Cano
7db7b1ee4c
Fix some provisioner tests
5 years ago
Mariano Cano
29be322b1c
Make audiences compatible with the old version.
5 years ago
Mariano Cano
39ae5636fe
Complete AuthDB interface.
5 years ago
Mariano Cano
d4627d1282
Make provisioner tests compile, they are still failing.
5 years ago
Mariano Cano
a8a6d0ada3
Fix indentation.
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
5616386eed
Add SSH getHosts api
5 years ago
Mariano Cano
c7e4cc96a4
Change default user duration to 16h.
5 years ago
Mariano Cano
c729c5f925
Fix list of user ssh public keys.
5 years ago
Mariano Cano
ee22778264
Fix lint error.
5 years ago
Mariano Cano
8939caace4
Add tests for ssh authority methods.
5 years ago
Mariano Cano
4f06f3901e
Add some ssh related tests.
5 years ago
Mariano Cano
08850d5334
Add support for federated keys.
5 years ago
Mariano Cano
37f17213bb
Add initial support for check-host endpoint.
5 years ago
Mariano Cano
d08db4df23
Rename SSH methods.
5 years ago
Mariano Cano
b5bc249e1c
Add support for multiple ssh roots.
...
Fixes #125
5 years ago
Mariano Cano
91130b9c3f
Add support for user data in templates.
5 years ago
Mariano Cano
a35988ff08
Add initial support for ssh config.
...
Related to smallstep/cli#170
5 years ago
Mariano Cano
d4c47cf3e1
Fix tests.
5 years ago
Mariano Cano
961be1fbc7
Add endpoint to return the SSH public keys.
...
Related to smallstep/ca-component#195
5 years ago
Mariano Cano
a197158426
Add initial implementation of ssh config.
5 years ago
Mariano Cano
69a1b68283
Merge branch 'ssh' into kms
5 years ago
max furman
92c48949d7
Remove test that is no longer implemented by the method.
5 years ago
max furman
1e5763031b
Add backdate validation to sshCertValidityValidator.
5 years ago
max furman
99e5bf4782
Remove all references to old apiError.
5 years ago
max furman
b265877050
Simplify statuscoder error generators.
5 years ago
max furman
c387b21808
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
9021951f1a
Fix types.
5 years ago
Mariano Cano
9641ab33b8
Use crypto.Signer instead of ssh.Signer in SSH options.
5 years ago
Mariano Cano
e98d7832b9
Add options to read the roots and federated roots from a bundle.
5 years ago
Mariano Cano
44eccc6bd8
Merge branch 'ssh' into kms
5 years ago
Mariano Cano
085ae82163
Remove the use of custom x509 package.
...
Upgrade cli dependency.
5 years ago
Mariano Cano
c62526b39f
Add wip support for kms.
5 years ago
Mariano Cano
77af30bfa3
Remove debug statement.
5 years ago
Mariano Cano
f46dc03111
Add tests of profileLimitDuration with backdate.
5 years ago
Mariano Cano
165a91858e
Add tests for backdate and sshDefaultDuration
5 years ago
Mariano Cano
7e33aeb8d3
Add unit test for profileDefaultDuration.
5 years ago
Mariano Cano
f06db4099e
Add backdate support on ssh rekey.
5 years ago
Mariano Cano
935d0d4542
Add support for backdate to SSH certificates.
5 years ago
Mariano Cano
e67ccd9e3d
Add fault tolerance against clock skew accross system on TLS certificates.
5 years ago
max furman
f9ef5070f9
Move api errors to their own package and modify the typedef
5 years ago
Mariano Cano
6d6f496331
Allow no provisioners.
5 years ago
Mariano Cano
96b6989658
Addapt test to api change.
5 years ago
Max
1f42637ba1
Merge pull request #143 from smallstep/expired-cert
...
Expired cert
5 years ago
max furman
1e17ec7d33
Use x5cInsecure token for /ssh/check-host endpoint
5 years ago
Mariano Cano
e841a86b48
Make sure to define the KeyID from the token if available.
5 years ago
Mariano Cano
8eeb82d0ce
Store renew certificate in the database.
5 years ago
Mariano Cano
50152391a3
Add leeway in identity not before.
5 years ago
max furman
55237d635c
Fix authority calling wrong revoke method
5 years ago
Mariano Cano
92d1db1616
Make test compilable.
5 years ago
Mariano Cano
5d35586402
Update template tests.
5 years ago
max furman
c2a3bcfab5
resolving merge
5 years ago
max furman
927784237d
Use an actual Hosts type when returning ssh hosts
5 years ago
Mariano Cano
7a06a60f88
Add missing version.go file.
5 years ago
Mariano Cano
2f18a26d4f
Add version endpoint.
5 years ago
max furman
35912cc906
change func def for getSSHHosts
...
* continue to return all hosts if injection method not specified
5 years ago
Mariano Cano
3fda081e42
Add identity certificate in ssh response.
5 years ago
max furman
c407a9319b
Add getSSHHosts injection func
5 years ago
max furman
8b2105a8f9
Instrument getIdentity func for OIDC ssh provisioner
5 years ago
max furman
f25a2a43eb
remove printfs
5 years ago
max furman
6ca1df5081
Add WithGetIdentityFunc option and attr to authority
...
* Add Identity type to provisioner
5 years ago
Mariano Cano
86a0558587
Add support for /ssh/bastion method.
5 years ago
Mariano Cano
8585b29711
Make test to compile, they still fail.
5 years ago
Mariano Cano
43b663e0c3
Move Option type to a new file.
5 years ago
Mariano Cano
be93c9e1f4
Add missing comment.
5 years ago
Mariano Cano
fcccb06696
Fix some provisioner tests
5 years ago
Mariano Cano
2cb6bd880b
Make audiences compatible with the old version.
5 years ago
Mariano Cano
efc2180c4a
Complete AuthDB interface.
5 years ago
Mariano Cano
a4fd76f1a8
Make provisioner tests compile, they are still failing.
5 years ago
Mariano Cano
0c3b9ebf45
Fix indentation.
5 years ago
Mariano Cano
69a7058ff0
Remove global check for number of k8sSA provisioners.
...
This was causing a bug in the reload of the ca.
5 years ago
max furman
e679deddd7
sshpop token should not allow renew/rekey of user ssh certs
5 years ago
max furman
946094d2b7
Add multiuse capability to k8ssa provisioners
5 years ago
max furman
a9ea292bd4
sshpop provisioner + ssh renew | revoke | rekey first pass
5 years ago
max furman
b5f15531d8
sshpop first pass
5 years ago
max furman
64b69374fa
Add SSH getHosts api
5 years ago
Mariano Cano
cf2b9301c0
Change default user duration to 16h.
5 years ago
Mariano Cano
e5da24f269
Fix list of user ssh public keys.
5 years ago
Mariano Cano
91ccc3802c
Fix lint error.
5 years ago
Mariano Cano
c2e20c7877
Add tests for ssh authority methods.
5 years ago
Mariano Cano
40052a1824
Add some ssh related tests.
5 years ago
Mariano Cano
38d735be6e
Add support for federated keys.
5 years ago
Mariano Cano
3ee0dcec93
Add initial support for check-host endpoint.
5 years ago
Mariano Cano
a50d59338e
Rename SSH methods.
5 years ago
Mariano Cano
e84489775b
Add support for multiple ssh roots.
...
Fixes #125
5 years ago
Mariano Cano
caa2174efc
Add support for user data in templates.
5 years ago
Mariano Cano
7b8bb6deb4
Add initial support for ssh config.
...
Related to smallstep/cli#170
5 years ago
Mariano Cano
c6a5772356
Fix tests.
5 years ago
Mariano Cano
fe3149cf52
Add endpoint to return the SSH public keys.
...
Related to smallstep/ca-component#195
5 years ago
Mariano Cano
dc6ffb7670
Add initial implementation of ssh config.
5 years ago
max furman
8f07ff6a39
Add kubernetes service account provisioner
5 years ago
Max
0a96062b76
Merge pull request #128 from jkralik/returnCertChain
...
Change api of functions Authority.Sign, Authority.Renew
5 years ago
max furman
d368791606
Add x5c provisioner capabilities
5 years ago
Jozef Kralik
bc6074f596
Change api of functions Authority.Sign, Authority.Renew
...
Returns certificate chain instead of 2 members.
Implements #126
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
5dac2459c3
Merge pull request #96 from smallstep/max/2084
...
Enforce >= 2048 bit rsa keys in CSRs
5 years ago
max furman
d3e74a0d2e
switch from metalinter to golangci-lint
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
db4baa0487
Add tests for authority sign ssh methods.
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
390aecca0b
Check for error creating signers.
5 years ago
Mariano Cano
004ea12212
Allow to use custom SSH user/host key files.
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
7a64a84761
Pass the given context.
5 years ago
Mariano Cano
e1cd5ee8c3
Add context to the Authorize method.
...
Fix tests.
5 years ago
Mariano Cano
2127d09ef3
Rename context type to apiCtx.
...
It will conflict with the context package.
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
578beec25d
Merge pull request #65 from smallstep/cloud-identities
...
Cloud identities
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
dbd3131068
Fix comments.
5 years ago
Mariano Cano
9f39cb5f2a
Add test.
5 years ago
Mariano Cano
fb6a1afd89
Fix typo.
5 years ago
Mariano Cano
3a1a4c5ea9
Do not allow reload with database configuration changes.
...
Fixes #smallstep/ca-component#170
5 years ago
Mariano Cano
cf07c8f4c0
Fix typos.
5 years ago
Mariano Cano
54570095d4
Merge branch 'master' into cloud-identities
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
max furman
81db527f12
NoopDB -> SimpleDB
5 years ago
max furman
b73fe8c157
Add used OTT to DB during authToken step
6 years ago
Mariano Cano
70196b2331
Add skeleton for the Azure provisioner.
...
Related to #69
6 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
27c98806c0
Use GetTokenID.
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
9977eff153
bump cli dep and fix text error msg
6 years ago
max furman
ff20d9f5af
Fix composite literal uses unkeyed field
6 years ago
max furman
ab4d569f36
Add /revoke API with interface db backend
6 years ago
Mariano Cano
1812c0619a
Update go-jose to 2.3.0.
...
This is a dependency for smallstep/cli#105 , it will be solved once
square/go-jose#224 gets merged
6 years ago
Mariano Cano
04da00d716
Merge pull request #55 from smallstep/x509util-real-x509
...
Use standard x509 creating signed certificates
6 years ago
Mariano Cano
7b9e08bcfa
Fix comment.
6 years ago
Mariano Cano
64f2615864
Fix tests.
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
8c8547bf65
Remove unnecessary parse and improve tests.
6 years ago
Mariano Cano
b9530909a4
Fix tests.
6 years ago
Mariano Cano
a3e2b4a552
Move certificate check to the right place.
6 years ago
Mariano Cano
30a6889d1f
Use standard x509 instead of step one.
6 years ago
Mariano Cano
68ff077ea9
Improve tests.
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
8a05cdde52
Add audience in the error v2
6 years ago
Mariano Cano
f8fba4df6b
Add audience in error.
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
07cdc1021c
Use OIDC nonce as the reuse key.
6 years ago
Mariano Cano
7fd737cbb1
Fix lint warnings.
6 years ago
Mariano Cano
1f5ff5c899
Fix sign and renew tests.
6 years ago
Mariano Cano
2fb77b8a4d
Truncate to seconds the startTime to simplify tests.
6 years ago
Mariano Cano
1a9e8bad74
Truncate to seconds instead of rounding.
6 years ago
Mariano Cano
b77621675c
Fix and simplify authorize tests.
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
c0ef6f8dc5
Add missing modifier and change return codes.
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
33c1449360
Remove deprecated file.
6 years ago
Mariano Cano
57b705f6cf
Use provisioner sign options.
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
602a42813c
Re-enable replay protection for JWK provisioner.
6 years ago
Mariano Cano
ab1cca03d7
Use new provisioners in authorize methods.
6 years ago
Mariano Cano
54ed49f072
Rename package.
6 years ago
Mariano Cano
c776ca3bd6
Use provisioner.Collection to store and request the provisioners.
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
34ff388828
Use new types in config.
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
max furman
229e5908b7
Added test for different authority key id after renew
...
Also ran dep ensure.
6 years ago
Mariano Cano
d78febec7a
Fix extensions copy on renew
...
Fixes #36
6 years ago
max furman
7e43402575
bug fix: don't add common name to CSR validation claims in Sign
...
* added unit test for this case
6 years ago