Commit Graph

1106 Commits (ad5cbd9a0e7c255342d48d63271721e98a8a5f92)

Author SHA1 Message Date
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 5 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
max furman 3415a1fef8 move SplitSANs to cli 6 years ago
max furman 6937bfea7b claims.SANS -> claims.SANs 6 years ago
max furman 93f39c64a0 backwards compat only when SANS empty 6 years ago
max furman fe8c8614b2 SANS backwards compat when token missing sujbect SAN 6 years ago
max furman e6e8443f3c allow multiple identical SANs in cert 6 years ago
max furman f0683c2e0a Enable signing certificates with custom SANs
* validate against SANs in token. must be 1:1 equivalent.
6 years ago
Derrick Lyndon Pallas 7a5c4a1112 authority/provisioners: fix overflow on 32-bit systems
In Go, len returns signed ints, not unsigned ints; consequently, this code
comparison overflows on 32-bit systems, like ARM.
6 years ago
max furman 2c72ada610 remove dead code 6 years ago
max furman 6dc89f46d8 make Duration public 6 years ago
max furman 0615f7eb11 don't wrap time.Duration 6 years ago
max furman 4b742042ee make Duration wrapper publicly accessible 6 years ago
Mariano Cano e8ac3f4888 Add comment to differentiate GetRootCertificates and GetRoots. 6 years ago
Mariano Cano 6e620073f5 Rename method Empties to HasEmpties 6 years ago
max furman cfbb2a6f41 method documentation grammar fix 6 years ago
Mariano Cano 518b597535 Remove mTLS client requirement in /roots and /federation 6 years ago
Mariano Cano 1763ede99d Add tests for new methods. 6 years ago
Mariano Cano d296cf95a9 Add mTLS request to get all the root CAs, not the federated ones. 6 years ago
Mariano Cano 98cc243a37 Add support for multiple roots. 6 years ago
Mariano Cano 722bcb7e7a Add initial support for federated root certificates. 6 years ago
Mariano Cano 7e95fc0e45 Strip ports on audience check.
Services might have proxies behind them so we cannot rely on them.
Fixes #17
6 years ago
Mariano Cano 9b87e08faf Do not require the port in the audience check.
Fixes #17
6 years ago
Mariano Cano 7da1d1adc2 Fix typo. 6 years ago
Mariano Cano d6cad2a7f3 Add provisioner option to disable renewal.
Fixes smallstep/ca-component#108
6 years ago
max furman c74fcd57a7 ca-component -> certificates
* fix redundant error check
* add README
6 years ago
Mariano Cano 428661f472 Use name instead of issuer in error message. 6 years ago
max furman 0d9dd2d14b provisioner issuer -> name 6 years ago
Mariano Cano ea0307239a Fix dead code and add missing error check. 6 years ago
Mariano Cano d574545d94 Format code with `gofmt -s` 6 years ago
max furman 7fa06643b2 change step provisioner OID and ASN1 representation 6 years ago
max furman b457b15292 fix: omit empty claims in AuthConfig 6 years ago
max furman ca6087145f fix unit test 6 years ago
max furman a4a461466b withProvisionerOID and unit test 6 years ago
max furman 283dc42904 add unit tests for MatchOne (token audience) and Authority.New 6 years ago
Mariano Cano 0ccf775f2e Add support for cursors in the api. 6 years ago
Mariano Cano 1de8eb4bfa Fix provisioner package move. 6 years ago
Mariano Cano 1db177b80d Add backend support for provisioners with cursors.
Fixes #83
6 years ago
max furman d2872564b4 accidentally removed DisableIssuedAtCheck during merge 6 years ago
max furman ee7db4006a change sign + authorize authority api | add provisioners
* authorize returns []interface{}
 - operators in this list can conform to any interface the user decides
 - our implementation has a combination of certificate claim validators
 and certificate template modifiers.
* provisioners can set and enforce tls cert options
6 years ago
Mariano Cano 1c1ac1b3fb Add disableIssuedAt check functionality
Fixes #86
6 years ago
Mariano Cano 69da47a727 Set audience using the sign url. 6 years ago
max furman 0b5f6487e1 change provisioners api
* /provisioners -> /provisioners/jwk-set-by-issuer
* /provisioners now returns a list of Provisioners
6 years ago
max furman f1dc00c810 add Provisioner config validation 6 years ago
max furman 0e904989d2 add unit tests for authority.Provisioners api 6 years ago
max furman d773770a44 add authority.New unit tests 6 years ago
max furman c284a2c0ab first commit 6 years ago