Skip to content

Commit

Permalink
feat(credentials): Refactor credential purposes (#2260)
Browse files Browse the repository at this point in the history
* feat(credentials): Refactor credential purposes

 * Application credentials have been refactored to Brokered credentials
 * Egress credentials have been refactored to Injected Application
credentials

Co-authored-by: Jeff Mitchell <[email protected]>
  • Loading branch information
louisruch and jefferai authored Jul 19, 2022
1 parent 271cc8f commit a17e973
Show file tree
Hide file tree
Showing 49 changed files with 1,502 additions and 1,037 deletions.
36 changes: 19 additions & 17 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ Canonical reference for changes, improvements, and bugfixes for Boundary.

### Deprecations/Changes

* Targets: Rename Application credentials to Brokered credentials
([PR](https://github.com/hashicorp/boundary/pull/2260)).
* Host plugins: Plugin-type host catalogs/sets/hosts now use typed prefixes for
any newly-created resources. Existing resources will not be affected.
([PR](https://github.com/hashicorp/boundary/pull/2256))
Expand All @@ -18,7 +20,7 @@ Canonical reference for changes, improvements, and bugfixes for Boundary.
### New and Improved

* `azure` host plugin: Support multiple MSI identities
([PR](https://github.com/hashicorp/go-kms-wrapping/pull/97)
([PR](https://github.com/hashicorp/go-kms-wrapping/pull/97))

### Bug Fixes

Expand All @@ -29,7 +31,7 @@ Canonical reference for changes, improvements, and bugfixes for Boundary.
could result in sessions never moving from `canceling` state to terminated.
([PR](https://github.com/hashicorp/boundary/pull/2229))
* The plugin execution_dir configuration parameter is now respected by kms plugins too
[PR](https://github.com/hashicorp/boundary/pull/2239).
([PR](https://github.com/hashicorp/boundary/pull/2239)).

### Deprecations/Changes

Expand Down Expand Up @@ -57,31 +59,31 @@ Canonical reference for changes, improvements, and bugfixes for Boundary.
credentials of type `username_password`. These credentials can act as
credential sources for targets, similar to credential libraries from the
`vault` credential store, and thus can be brokered to users at session
authorization time. [PR](https://github.com/hashicorp/boundary/pull/2174)
authorization time. ([PR](https://github.com/hashicorp/boundary/pull/2174))
* `boundary connect` Credential Brokering Integration: we have extended integration
into the `boundary connect` helpers. A new `sshpass` style has been added to the
`ssh` helper, when used, if the credential contains a username/password and `sshpass`
is installed, the command will automatically pass the credentials to the `ssh` process.
Additionally, the default `ssh` helper will now use the `username` of the brokered credential.
[PR](https://github.com/hashicorp/boundary/pull/2191).
([PR](https://github.com/hashicorp/boundary/pull/2191)).
* controller: Improve response time for listing sessions.
This also creates a new periodic job that will delete terminated
sessions after 1 hour.
See Deprecations/Changes for some additional details.
[PR](https://github.com/hashicorp/boundary/pull/2160).
([PR](https://github.com/hashicorp/boundary/pull/2160)).
* event filtering: Change event filters to use lowercase and snake case for data
elements like the rest of Boundary filters do.
* ui: Use include_terminated flag for listing sessions.
[PR](https://github.com/hashicorp/boundary-ui/pull/1126).
([PR](https://github.com/hashicorp/boundary-ui/pull/1126)).
* ui: Add Quick Setup onboarding guide.
[PR](https://github.com/hashicorp/boundary-ui/pull/1140).
([PR](https://github.com/hashicorp/boundary-ui/pull/1140)).

### Bug Fixes

* The plugin execution_dir configuration parameter is now respected.
[PR](https://github.com/hashicorp/boundary/pull/2183).
([PR](https://github.com/hashicorp/boundary/pull/2183)).
* ui: Fix Users page not updating fields correctly.
[PR](https://github.com/hashicorp/boundary-ui/pull/1105).
([PR](https://github.com/hashicorp/boundary-ui/pull/1105)).

### Deprecations/Changes

Expand All @@ -97,7 +99,7 @@ Canonical reference for changes, improvements, and bugfixes for Boundary.
to no longer include sessions in a terminated state and introduces
a new query parameter/cli flag to include the terminated sessions.
This also removes the connection information from the list response.
[PR](https://github.com/hashicorp/boundary/pull/2160).
([PR](https://github.com/hashicorp/boundary/pull/2160)).
* Anonymous user permissions: In order to reduce the risk of accidental and
unintended granting of permissions to anonymous users, the permissions system
now only allows certain actions on certain resources to be assigned to the
Expand All @@ -124,10 +126,10 @@ Canonical reference for changes, improvements, and bugfixes for Boundary.
* metrics: Provide metrics for controllers and workers
* controller: Add health endpoint ([PR](https://github.com/hashicorp/boundary/pull/1882))
* controller: Improve response time for listing sessions and targets.
[PR](https://github.com/hashicorp/boundary/pull/2049)
([PR](https://github.com/hashicorp/boundary/pull/2049))
* ui: Add support for worker filters in targets
* ui: Add manual refresh button in sessions list
* Audit events are no longer a WIP ([PR](https://github.com/hashicorp/boundary/pull/2031).
* Audit events are no longer a WIP ([PR](https://github.com/hashicorp/boundary/pull/2031)).

### Bug Fixes

Expand All @@ -140,7 +142,7 @@ Canonical reference for changes, improvements, and bugfixes for Boundary.
[PR](https://github.com/hashicorp/boundary/pull/1976))
* controller: Fix for retrieving sessions that could result in incomplete
results when there is a large number (10k+) of sessions.
[PR](https://github.com/hashicorp/boundary/pull/2049)
([PR](https://github.com/hashicorp/boundary/pull/2049))
* session: update session state trigger to prevent transitions to invalid states
([Issue](https://github.com/hashicorp/boundary/issues/2040),
[PR](https://github.com/hashicorp/boundary/pull/2046))
Expand Down Expand Up @@ -334,7 +336,7 @@ isolate transactions and prevent resource contention that caused deadlocks.
validating even though it is correctly handled within the ACL code.
([PR](https://github.com/hashicorp/boundary/pull/1474))
* targets: Fix panic when using `boundary targets authorize-session`
([issue](https://github.com/hashicorp/boundary/issues/1488),
([Issue](https://github.com/hashicorp/boundary/issues/1488),
[PR](https://github.com/hashicorp/boundary/pull/1496))

## 0.5.1 (2021/08/16)
Expand Down Expand Up @@ -453,7 +455,7 @@ isolate transactions and prevent resource contention that caused deadlocks.

* config: Fix error when populating all `kms` purposes in separate blocks (as
well as the error message)
([issue](https://github.com/hashicorp/boundary/issues/1305),
([Issue](https://github.com/hashicorp/boundary/issues/1305),
[PR](https://github.com/hashicorp/boundary/pull/1384))
* server: Fix panic on worker startup failure when the server was not also
configured as a controller
Expand Down Expand Up @@ -504,7 +506,7 @@ Boundary) but it's worth repeating.

* scheduler: removes a Postgres check constraint, on the length of the controller name,
causing an error when the scheduler attempts to run jobs
([issue](https://github.com/hashicorp/boundary/issues/1309),
([Issue](https://github.com/hashicorp/boundary/issues/1309),
[PR](https://github.com/hashicorp/boundary/pull/1310)).
* Docker: update entrypoint script to handle more Boundary subcommands for
better UX
Expand Down Expand Up @@ -574,7 +576,7 @@ Boundary) but it's worth repeating.

* oidc: If provider returns an `aud` claim as a `string` or `[]string`,
Boundary will properly parse the claims JSON.
([issue](https://github.com/hashicorp/cap/issues/37),
([Issue](https://github.com/hashicorp/cap/issues/37),
[PR](https://github.com/hashicorp/boundary/pull/1231))
* sessions: Clean up connections that are dangling after a worker dies (is
restarted, powered off, etc.) This fixes some cases where a session never goes
Expand Down
24 changes: 18 additions & 6 deletions api/targets/option.gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,18 @@ func DefaultAttributes() Option {
}
}

func WithBrokeredCredentialSourceIds(inBrokeredCredentialSourceIds []string) Option {
return func(o *options) {
o.postMap["brokered_credential_source_ids"] = inBrokeredCredentialSourceIds
}
}

func DefaultBrokeredCredentialSourceIds() Option {
return func(o *options) {
o.postMap["brokered_credential_source_ids"] = nil
}
}

func WithTcpTargetDefaultPort(inDefaultPort uint32) Option {
return func(o *options) {
raw, ok := o.postMap["attributes"]
Expand Down Expand Up @@ -147,21 +159,21 @@ func DefaultDescription() Option {
}
}

func WithEgressCredentialSourceIds(inEgressCredentialSourceIds []string) Option {
func WithHostId(inHostId string) Option {
return func(o *options) {
o.postMap["egress_credential_source_ids"] = inEgressCredentialSourceIds
o.postMap["host_id"] = inHostId
}
}

func DefaultEgressCredentialSourceIds() Option {
func WithInjectedApplicationCredentialSourceIds(inInjectedApplicationCredentialSourceIds []string) Option {
return func(o *options) {
o.postMap["egress_credential_source_ids"] = nil
o.postMap["injected_application_credential_source_ids"] = inInjectedApplicationCredentialSourceIds
}
}

func WithHostId(inHostId string) Option {
func DefaultInjectedApplicationCredentialSourceIds() Option {
return func(o *options) {
o.postMap["host_id"] = inHostId
o.postMap["injected_application_credential_source_ids"] = nil
}
}

Expand Down
46 changes: 24 additions & 22 deletions api/targets/target.gen.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading

0 comments on commit a17e973

Please sign in to comment.