Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

VAULT-1564 report in-flight requests #13024

Merged
merged 36 commits into from
Dec 8, 2021
Merged

VAULT-1564 report in-flight requests #13024

merged 36 commits into from
Dec 8, 2021

Conversation

hghaf099
Copy link
Contributor

@hghaf099 hghaf099 commented Nov 3, 2021

Adding a trace capability to the request handling or HTTP layer that shows, for each requests received but not yet answered:

  • time duration since the request was received
  • the request RemoteAddress
  • the operation and path in the request, but not payload

This would provide a point-in-time snapshot of what user requests Vault is handling, highlighting any deadlocks or abnormally long response times.

The API reporting on this information should be called as part of the debug command. It also support unauthenticated requests if a new profiling config option is set.

Adding a new metric for the total number of in-flight requests.
Adding documentation for the metric and the new endpoint.

Here is a sample result:
{ "7ecdd692-d934-e668-365d-b4a6664e1548": { "start_time": "2021-11-03T14:54:45.774893-07:00", "client_remote_address": "127.0.0.2:53771", "request_path": "/v1/secret/data/68", "duration": "230750 microseconds" } }

@vercel vercel bot temporarily deployed to Preview – vault November 3, 2021 00:38 Inactive
@vercel vercel bot temporarily deployed to Preview – vault-storybook November 3, 2021 00:38 Inactive
@vercel vercel bot temporarily deployed to Preview – vault November 3, 2021 00:55 Inactive
@vercel vercel bot temporarily deployed to Preview – vault-storybook November 3, 2021 00:55 Inactive
@vercel vercel bot temporarily deployed to Preview – vault November 3, 2021 00:57 Inactive
@vercel vercel bot temporarily deployed to Preview – vault-storybook November 3, 2021 00:57 Inactive
@vercel vercel bot temporarily deployed to Preview – vault November 3, 2021 20:38 Inactive
@vercel vercel bot temporarily deployed to Preview – vault-storybook November 3, 2021 20:38 Inactive
http/handler_test.go Outdated Show resolved Hide resolved
@hghaf099 hghaf099 requested a review from ncabatoff November 3, 2021 22:38
command/debug.go Outdated Show resolved Hide resolved
command/debug.go Outdated Show resolved Hide resolved
http/handler.go Outdated Show resolved Hide resolved
http/handler.go Outdated Show resolved Hide resolved
http/sys_in_flight_reqeusts_test.go Outdated Show resolved Hide resolved
http/sys_in_flight_requests.go Outdated Show resolved Hide resolved
vault/core.go Outdated Show resolved Hide resolved
vault/logical_system.go Show resolved Hide resolved
vault/core_metrics.go Outdated Show resolved Hide resolved
vault/logical_system.go Outdated Show resolved Hide resolved
@vercel vercel bot temporarily deployed to Preview – vault November 5, 2021 00:21 Inactive
@vercel vercel bot temporarily deployed to Preview – vault-storybook November 5, 2021 00:21 Inactive
@hghaf099 hghaf099 marked this pull request as ready for review November 5, 2021 00:21
@hghaf099 hghaf099 requested a review from taoism4504 as a code owner November 5, 2021 00:21
@hghaf099 hghaf099 requested a review from ncabatoff November 5, 2021 01:01
command/debug.go Outdated
@@ -865,10 +884,12 @@ func (c *DebugCommand) collectServerStatus(ctx context.Context) {
healthInfo, err := c.cachedClient.Sys().Health()
if err != nil {
c.captureError("server-status.health", err)
return
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Although it's true that an error on the health endpoint will probably mean one on the seal-status endpoint too, I'd rather we didn't assume that. Can you revert this change please?

command/debug.go Outdated
}
sealInfo, err := c.cachedClient.Sys().SealStatus()
if err != nil {
c.captureError("server-status.seal", err)
return
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here too.

command/debug.go Outdated
defer resp.Body.Close()
err = jsonutil.DecodeJSONFromReader(resp.Body, &data)
if err != nil {
c.captureError("inFlightReq-status", err)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It looks like the first arg to captureError is the target, which we're now calling requests right?

command/debug.go Outdated
return
}

if data != nil && len(data) > 0 {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think we need this conditional do we?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yeah, there should always be at least one entry which is the /v1/sys/in-flight-req related info

http/handler.go Outdated
ClientRemoteAddr: r.RemoteAddr,
ReqPath: r.URL.Path,
})
if err != nil {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What error are we handling here?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ah, thanks for catching this!

@vercel vercel bot temporarily deployed to Preview – vault-storybook December 7, 2021 17:00 Inactive
@vercel vercel bot temporarily deployed to Preview – vault December 7, 2021 17:00 Inactive
@hghaf099 hghaf099 requested a review from ncabatoff December 7, 2021 18:13
vault/core.go Outdated
currentInFlightReqMap := make(map[string]InFlightReqData)
c.inFlightReqData.InFlightReqMap.Range(func(key, value interface{}) bool {
// there is only one writer to this map, so skip checking for errors
v, _ := value.(InFlightReqData)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Minor nit, but: by using the two-argument form, you're deliberately ignoring errors. Either we don't believe errors are possible, in which case you can use the single-argument form which panics on error, or we do, in which case we should handle the error.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think at some point, you mentioned that there is only one writer for this and there is no need to check if the assertion worked or not. The comment I have on line 3006 talks about that. But, happy to add the error check for this.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm ok with there being no error check, I'm just saying if we're not going to check for errors because we think they can't happen, why not use the single-argument form? If we're right that errors can't happen, then they're equivalent. If we're wrong, we'll learn of it because of panics.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sounds good! I think it is highly unlikely that a panic happens. I am going to use the single-arguments form.

@vercel vercel bot temporarily deployed to Preview – vault-storybook December 7, 2021 21:55 Inactive
@vercel vercel bot temporarily deployed to Preview – vault December 7, 2021 21:55 Inactive
@vercel vercel bot temporarily deployed to Preview – vault-storybook December 7, 2021 23:34 Inactive
@hghaf099 hghaf099 merged commit 13b8306 into main Dec 8, 2021
@hghaf099 hghaf099 deleted the report-in-flight-req branch December 8, 2021 22:34
Monkeychip added a commit that referenced this pull request Dec 15, 2021
* Rename master key to root key (#13324)

* See what it looks like to replace "master key" with "root key".  There are two places that would require more challenging code changes: the storage path `core/master`, and its contents (the JSON-serialized EncodedKeyringtructure.)

* Restore accidentally deleted line

* Add changelog

* Update root->recovery

* Fix test

Co-authored-by: Nick Cabatoff <[email protected]>

* Fix typo (#13355)

* Add kms_library configuration stanza (#13352)

- Add the kms_library configuration stanza to Vault's command/server
 - Provide validation of keys and general configuration.
 - Add initial kms_library configuration documentation
 - Attempt at startup to verify we can read the configured HSM Library
 - Hook in KmsLibrary config into the Validate to detect typo/unused keys

* modifed note (#13351)

* Incorporate Ember Flight Icons (#12976)

* adds ember-flight-icons dependecy

* adds inline-json-import babel plugin

* adds flight icon styling

* updates Icon component to support flight icons

* updates Icon component usages to new api and updates name values to flight icon set when available

* fixes tests

* updates icon story with flight mappings and fixes issue with flight icons not rendering in storybook

* adds changelog

* fixes typo in sign action glyph name in transit-key model

* adds comments to icon-map

* updates Icon component to use only supported flight icon sizes

* adds icon transform codemod

* updates icon transform formatting to handle edge case

* runs icon transform on templates

* updates Icon usage in toolbar-filter md and story

* updates tests

* docs: winsvc update recommendations (#13280)

* docs: update custom database sample code (#13211)

* clarify more sink options (#12586)

* Update @hashicorp/react-hashi-stack-menu (#13354)

* Docs to clarify k8s auth options with short-lived tokens (#13275)

* Rework 1.21 content into one heading and add note at top
* Add notes about extended k8s token duration
* Add example of ClusterRoleBinding for using client JWTs

* Adds support for SHA-3 to transit (#13367)

* Adding support for SHA3 in the transit backend.

* Adds SHA-3 tests for transit sign/verify path. Adds SHA-3 tests for logical system tools path hash functionality. Updates documentation to include SHA-3 algorithms in system tools path hashing.

* Adds changelog entry.

Co-authored-by: robison jacka <[email protected]>

* agent/cache: differentiate open log messages (#13362)

Changes the error output for the second open of the persistent cache
file, to differentiate it from the c.UI.Error message for the initial
open of the cache file, just to make it easier to tell where a problem
occurred.

* Warn user supplying nonce values in FIPS mode for transit encryption requests (#13366)

* Warn user supplying nonce values in FIPS mode for transit encryption requests

 - Send back a warning within the response if an end-user supplies nonce
   values that we use within the various transit encrypt apis.
 - We do not send a warning if an end-user supplies a nonce value but we
   don't use it.
 - Affected api methods are encrypt, rewrap and datakey
 - The warning is only sent when we are operating in FIPS mode.

* [VAULT-3252] Add entity-alias behavior change to docs (#13370)

* Add entity-alias behavior change to docs

* Add upgrade note about entity-alias mapping change

* Rename 1.7-9 upgrade pages, shuffle upgrade note position

* Update website/content/partials/entity-alias-mapping.mdx

Co-authored-by: Meggie <[email protected]>

* Add incorrect policy issue to the docs

* Add example about entity-alias restriction

Co-authored-by: Meggie <[email protected]>

* VAULT-1564 report in-flight requests (#13024)

* VAULT-1564 report in-flight requests

* adding a changelog

* Changing some variable names and fixing comments

* minor style change

* adding unauthenticated support for in-flight-req

* adding documentation for the listener.profiling stanza

* adding an atomic counter for the inflight requests
addressing comments

* addressing comments

* logging completed requests

* fixing a test

* providing log_requests_info as a config option to determine at which level requests should be logged

* removing a member and a method from the StatusHeaderResponseWriter struct

* adding api docks

* revert changes in NewHTTPResponseWriter

* Fix logging invalid log_requests_info value

* Addressing comments

* Fixing a test

* use an tomic value for logRequestsInfo, and moving the CreateClientID function to Core

* fixing go.sum

* minor refactoring

* protecting InFlightRequests from data race

* another try on fixing a data race

* another try to fix a data race

* addressing comments

* fixing couple of tests

* changing log_requests_info to log_requests_level

* minor style change

* fixing a test

* removing the lock in InFlightRequests

* use single-argument form for interface assertion

* adding doc for the new configuration paramter

* adding the new doc to the nav data file

* minor fix

* auth/jwt: Update plugin to v0.11.3 (#13365)

* auth/jwt: Update plugin to v0.11.3

* add changelog

* changelog++

* Update alert banner (#13375)

* Updating website for 1.9.1 (#13378)

* Use os.Hostname instead of a dependency that doesn't work on OpenBSD. (#13389)

* Remove another use gopsutil/host. (#13390)

* CLI changes for new mount tune config parameter allowed_managed_keys (#13255)

* CLI changes for new mount tune config parameter allowed_managed_keys

* Correct allowed_managed_keys description in auth and secrets

* Documentation update for secrets and removed changes for auth

* Add changelog and remove documentation changes for auth

* removed changelog

* Correct the field description

* auth/jwt: update changelog for pkce improvement (#13392)

* Fix test validating convergent encryption behaviour across key types (#13371)

- The test was attempting to test the convergent encryption behaviour
  with several key types but the common function never used the passed
  in key type. So we ran the test with the default aes256-gcm96 only.

* Fix managed namespace test (#13394)

* Fix managed namespace test

* Remove log

* Some changelog tidying for 1.10 preview (#13385)

* Some changelog tidying for 1.10 preview

* PR accounted for by different CL entry

* changelog++

Working on a new workflow for generating the preview so I thought I'd leave a note that it's still coming.

* UI/fix client count partial (#13396)

* Initial fix

* Add fallback zero values

* Add changelog

* Fix client count current test

* Support clearing an identity alias' custom_metadata (#13395)

* Support clearing an identity alias' custom_metadata

Previously, an update to an entity alias supported updating the
custom_metadata as long as the update was not empty, which makes it
impossible to clear the metadata values completely.

Fixes:
- empty custom_metadata parameters are honoured on entity alias update
- update related tests
- drop dependency on mapstructure
- reformat with gofumpt

* Docs: fix invalid link in the kubernetes auth api doc. (#13399)

* Clean up whitespace

* auth/azure: add note about debug env (#13405)

* auth/azure: add note about debug env

* Update azure.mdx

* Update azure.mdx

* Add universal default key_bits value for PKI endpoints (#13080)

* Allow universal default for key_bits

This allows the key_bits field to take a universal default value, 0,
which, depending on key_type, gets adjusted appropriately into a
specific default value (rsa->2048, ec->256, ignored under ed25519).

Signed-off-by: Alexander Scheel <[email protected]>

* Handle universal default key size in certutil

Also move RSA < 2048 error message into certutil directly, instead of in
ca_util/path_roles.

Signed-off-by: Alexander Scheel <[email protected]>

* Add missing RSA key sizes to pki/backend_test.go

Signed-off-by: Alexander Scheel <[email protected]>

* Switch to returning updated values

When determining the default, don't pass in pointer types, but instead
return the newly updated value.

Signed-off-by: Alexander Scheel <[email protected]>

* Add changelog entry

Signed-off-by: Alexander Scheel <[email protected]>

* Re-add fix for ed25519 from #13254

Ed25519 internally specifies a hash length; by changing the default from
256 to 0, we fail validation in ValidateSignatureLength(...) unless we
specify the key algorithm.

Signed-off-by: Alexander Scheel <[email protected]>

* Fix logging statement using formatting args (#13407)

* Add docs about path param restrictions (#13413)

* Add docs about path param restrictions

* Update website/content/api-docs/auth/userpass.mdx

Co-authored-by: Loann Le <[email protected]>

* Update with review suggestion

Co-authored-by: Loann Le <[email protected]>

* Update raftautosnapshots.mdx (#13412)

* Main go version bump (#13408)

* Go 1.17.2 -> 1.17.5
* Switching to cimg

* Bump yarn cache key version so that it uses the new disk layout we've adopted for using cimg/go. (#13420)

* Add vault-api module (#13048)

* crt main fix for ecr tag (#13425)

* Add no-op method setupManagedKeyRegistry(). (#13433)

* github auth: use org id to verify creds (#13332)

* github auth: use org id to verify creds

* add check for required org param; add test case

* update UTs

* add nil check for org

* add changelog

* fix typo in ut

* set org ID if it is unset; add more ut coverage

* add optional organization_id

* move client instantiation

* refactor parse URL; add UT for setting org ID

* fix comment in UT

* add nil check

* don't update org name on change; return warning

* refactor verifyCredentials

* error when unable to fetch org ID on config write; add warnings

* fix bug in log message

* update UT and small refactor

* update comments and log msg

* use getter for org ID

Co-authored-by: Jim Kalafut <[email protected]>
Co-authored-by: Nick Cabatoff <[email protected]>
Co-authored-by: Harsimran Singh Maan <[email protected]>
Co-authored-by: Steven Clark <[email protected]>
Co-authored-by: Loann Le <[email protected]>
Co-authored-by: Jordan Reimer <[email protected]>
Co-authored-by: mickael-hc <[email protected]>
Co-authored-by: Calvin Leung Huang <[email protected]>
Co-authored-by: Mike Green <[email protected]>
Co-authored-by: Noel Quiles <[email protected]>
Co-authored-by: Tom Proctor <[email protected]>
Co-authored-by: Matt Schultz <[email protected]>
Co-authored-by: robison jacka <[email protected]>
Co-authored-by: Theron Voran <[email protected]>
Co-authored-by: Pratyoy Mukhopadhyay <[email protected]>
Co-authored-by: Meggie <[email protected]>
Co-authored-by: hghaf099 <[email protected]>
Co-authored-by: John-Michael Faircloth <[email protected]>
Co-authored-by: Brandon Romano <[email protected]>
Co-authored-by: divyapola5 <[email protected]>
Co-authored-by: Chelsea Shaw <[email protected]>
Co-authored-by: Ben Ash <[email protected]>
Co-authored-by: Jason O'Donnell <[email protected]>
Co-authored-by: Alexander Scheel <[email protected]>
Co-authored-by: Mark Lewis <[email protected]>
Co-authored-by: Sai Hemanth Bheemreddy <[email protected]>
Co-authored-by: Kyle Penfound <[email protected]>
Co-authored-by: Victor Rodriguez <[email protected]>
hellobontempo added a commit that referenced this pull request Jan 6, 2022
* UI/total client usage (#13359)

* blah

* setup

* clean up

* rename history to dashboard

* clean up

* Styling fixes (#13369)

* styling

* clean up

* UI/ horizontal bar chart component (#13361)

* horizontal bar chart component

* adds horizontal chart to dashboard file

* add export class

* yarn install d3 array

* yarn install d3 array

* adds data subtext to chart

* update naming to plural charts"

* updates css grid to 6 columns"

* UI/tooltip (#13397)

* working state

* stuff

* adds month tick marks and sort of y-axis, but y scale still messed up

* moves y scale so zero shows again

* fixes translating constants

* format numbers y axis

* actually fixes viewbox

* styling for x and y axis plus gridlines

* clean up

* separates grid types based on content

Co-authored-by: Claire Bontempo <[email protected]>

* Styling and legend component (#13430)

* styling

* cleanup

* UI/ Double horizontal bar charts (#13398)

* add descriptions and styling to side by side charts

* add border below horizontal charts

* starts legend styling

* center legend

* add to do

* add hover actions/event listeners

* UI/merge main (#13436)

* Rename master key to root key (#13324)

* See what it looks like to replace "master key" with "root key".  There are two places that would require more challenging code changes: the storage path `core/master`, and its contents (the JSON-serialized EncodedKeyringtructure.)

* Restore accidentally deleted line

* Add changelog

* Update root->recovery

* Fix test

Co-authored-by: Nick Cabatoff <[email protected]>

* Fix typo (#13355)

* Add kms_library configuration stanza (#13352)

- Add the kms_library configuration stanza to Vault's command/server
 - Provide validation of keys and general configuration.
 - Add initial kms_library configuration documentation
 - Attempt at startup to verify we can read the configured HSM Library
 - Hook in KmsLibrary config into the Validate to detect typo/unused keys

* modifed note (#13351)

* Incorporate Ember Flight Icons (#12976)

* adds ember-flight-icons dependecy

* adds inline-json-import babel plugin

* adds flight icon styling

* updates Icon component to support flight icons

* updates Icon component usages to new api and updates name values to flight icon set when available

* fixes tests

* updates icon story with flight mappings and fixes issue with flight icons not rendering in storybook

* adds changelog

* fixes typo in sign action glyph name in transit-key model

* adds comments to icon-map

* updates Icon component to use only supported flight icon sizes

* adds icon transform codemod

* updates icon transform formatting to handle edge case

* runs icon transform on templates

* updates Icon usage in toolbar-filter md and story

* updates tests

* docs: winsvc update recommendations (#13280)

* docs: update custom database sample code (#13211)

* clarify more sink options (#12586)

* Update @hashicorp/react-hashi-stack-menu (#13354)

* Docs to clarify k8s auth options with short-lived tokens (#13275)

* Rework 1.21 content into one heading and add note at top
* Add notes about extended k8s token duration
* Add example of ClusterRoleBinding for using client JWTs

* Adds support for SHA-3 to transit (#13367)

* Adding support for SHA3 in the transit backend.

* Adds SHA-3 tests for transit sign/verify path. Adds SHA-3 tests for logical system tools path hash functionality. Updates documentation to include SHA-3 algorithms in system tools path hashing.

* Adds changelog entry.

Co-authored-by: robison jacka <[email protected]>

* agent/cache: differentiate open log messages (#13362)

Changes the error output for the second open of the persistent cache
file, to differentiate it from the c.UI.Error message for the initial
open of the cache file, just to make it easier to tell where a problem
occurred.

* Warn user supplying nonce values in FIPS mode for transit encryption requests (#13366)

* Warn user supplying nonce values in FIPS mode for transit encryption requests

 - Send back a warning within the response if an end-user supplies nonce
   values that we use within the various transit encrypt apis.
 - We do not send a warning if an end-user supplies a nonce value but we
   don't use it.
 - Affected api methods are encrypt, rewrap and datakey
 - The warning is only sent when we are operating in FIPS mode.

* [VAULT-3252] Add entity-alias behavior change to docs (#13370)

* Add entity-alias behavior change to docs

* Add upgrade note about entity-alias mapping change

* Rename 1.7-9 upgrade pages, shuffle upgrade note position

* Update website/content/partials/entity-alias-mapping.mdx

Co-authored-by: Meggie <[email protected]>

* Add incorrect policy issue to the docs

* Add example about entity-alias restriction

Co-authored-by: Meggie <[email protected]>

* VAULT-1564 report in-flight requests (#13024)

* VAULT-1564 report in-flight requests

* adding a changelog

* Changing some variable names and fixing comments

* minor style change

* adding unauthenticated support for in-flight-req

* adding documentation for the listener.profiling stanza

* adding an atomic counter for the inflight requests
addressing comments

* addressing comments

* logging completed requests

* fixing a test

* providing log_requests_info as a config option to determine at which level requests should be logged

* removing a member and a method from the StatusHeaderResponseWriter struct

* adding api docks

* revert changes in NewHTTPResponseWriter

* Fix logging invalid log_requests_info value

* Addressing comments

* Fixing a test

* use an tomic value for logRequestsInfo, and moving the CreateClientID function to Core

* fixing go.sum

* minor refactoring

* protecting InFlightRequests from data race

* another try on fixing a data race

* another try to fix a data race

* addressing comments

* fixing couple of tests

* changing log_requests_info to log_requests_level

* minor style change

* fixing a test

* removing the lock in InFlightRequests

* use single-argument form for interface assertion

* adding doc for the new configuration paramter

* adding the new doc to the nav data file

* minor fix

* auth/jwt: Update plugin to v0.11.3 (#13365)

* auth/jwt: Update plugin to v0.11.3

* add changelog

* changelog++

* Update alert banner (#13375)

* Updating website for 1.9.1 (#13378)

* Use os.Hostname instead of a dependency that doesn't work on OpenBSD. (#13389)

* Remove another use gopsutil/host. (#13390)

* CLI changes for new mount tune config parameter allowed_managed_keys (#13255)

* CLI changes for new mount tune config parameter allowed_managed_keys

* Correct allowed_managed_keys description in auth and secrets

* Documentation update for secrets and removed changes for auth

* Add changelog and remove documentation changes for auth

* removed changelog

* Correct the field description

* auth/jwt: update changelog for pkce improvement (#13392)

* Fix test validating convergent encryption behaviour across key types (#13371)

- The test was attempting to test the convergent encryption behaviour
  with several key types but the common function never used the passed
  in key type. So we ran the test with the default aes256-gcm96 only.

* Fix managed namespace test (#13394)

* Fix managed namespace test

* Remove log

* Some changelog tidying for 1.10 preview (#13385)

* Some changelog tidying for 1.10 preview

* PR accounted for by different CL entry

* changelog++

Working on a new workflow for generating the preview so I thought I'd leave a note that it's still coming.

* UI/fix client count partial (#13396)

* Initial fix

* Add fallback zero values

* Add changelog

* Fix client count current test

* Support clearing an identity alias' custom_metadata (#13395)

* Support clearing an identity alias' custom_metadata

Previously, an update to an entity alias supported updating the
custom_metadata as long as the update was not empty, which makes it
impossible to clear the metadata values completely.

Fixes:
- empty custom_metadata parameters are honoured on entity alias update
- update related tests
- drop dependency on mapstructure
- reformat with gofumpt

* Docs: fix invalid link in the kubernetes auth api doc. (#13399)

* Clean up whitespace

* auth/azure: add note about debug env (#13405)

* auth/azure: add note about debug env

* Update azure.mdx

* Update azure.mdx

* Add universal default key_bits value for PKI endpoints (#13080)

* Allow universal default for key_bits

This allows the key_bits field to take a universal default value, 0,
which, depending on key_type, gets adjusted appropriately into a
specific default value (rsa->2048, ec->256, ignored under ed25519).

Signed-off-by: Alexander Scheel <[email protected]>

* Handle universal default key size in certutil

Also move RSA < 2048 error message into certutil directly, instead of in
ca_util/path_roles.

Signed-off-by: Alexander Scheel <[email protected]>

* Add missing RSA key sizes to pki/backend_test.go

Signed-off-by: Alexander Scheel <[email protected]>

* Switch to returning updated values

When determining the default, don't pass in pointer types, but instead
return the newly updated value.

Signed-off-by: Alexander Scheel <[email protected]>

* Add changelog entry

Signed-off-by: Alexander Scheel <[email protected]>

* Re-add fix for ed25519 from #13254

Ed25519 internally specifies a hash length; by changing the default from
256 to 0, we fail validation in ValidateSignatureLength(...) unless we
specify the key algorithm.

Signed-off-by: Alexander Scheel <[email protected]>

* Fix logging statement using formatting args (#13407)

* Add docs about path param restrictions (#13413)

* Add docs about path param restrictions

* Update website/content/api-docs/auth/userpass.mdx

Co-authored-by: Loann Le <[email protected]>

* Update with review suggestion

Co-authored-by: Loann Le <[email protected]>

* Update raftautosnapshots.mdx (#13412)

* Main go version bump (#13408)

* Go 1.17.2 -> 1.17.5
* Switching to cimg

* Bump yarn cache key version so that it uses the new disk layout we've adopted for using cimg/go. (#13420)

* Add vault-api module (#13048)

* crt main fix for ecr tag (#13425)

* Add no-op method setupManagedKeyRegistry(). (#13433)

* github auth: use org id to verify creds (#13332)

* github auth: use org id to verify creds

* add check for required org param; add test case

* update UTs

* add nil check for org

* add changelog

* fix typo in ut

* set org ID if it is unset; add more ut coverage

* add optional organization_id

* move client instantiation

* refactor parse URL; add UT for setting org ID

* fix comment in UT

* add nil check

* don't update org name on change; return warning

* refactor verifyCredentials

* error when unable to fetch org ID on config write; add warnings

* fix bug in log message

* update UT and small refactor

* update comments and log msg

* use getter for org ID

Co-authored-by: Jim Kalafut <[email protected]>
Co-authored-by: Nick Cabatoff <[email protected]>
Co-authored-by: Harsimran Singh Maan <[email protected]>
Co-authored-by: Steven Clark <[email protected]>
Co-authored-by: Loann Le <[email protected]>
Co-authored-by: Jordan Reimer <[email protected]>
Co-authored-by: mickael-hc <[email protected]>
Co-authored-by: Calvin Leung Huang <[email protected]>
Co-authored-by: Mike Green <[email protected]>
Co-authored-by: Noel Quiles <[email protected]>
Co-authored-by: Tom Proctor <[email protected]>
Co-authored-by: Matt Schultz <[email protected]>
Co-authored-by: robison jacka <[email protected]>
Co-authored-by: Theron Voran <[email protected]>
Co-authored-by: Pratyoy Mukhopadhyay <[email protected]>
Co-authored-by: Meggie <[email protected]>
Co-authored-by: hghaf099 <[email protected]>
Co-authored-by: John-Michael Faircloth <[email protected]>
Co-authored-by: Brandon Romano <[email protected]>
Co-authored-by: divyapola5 <[email protected]>
Co-authored-by: Chelsea Shaw <[email protected]>
Co-authored-by: Ben Ash <[email protected]>
Co-authored-by: Jason O'Donnell <[email protected]>
Co-authored-by: Alexander Scheel <[email protected]>
Co-authored-by: Mark Lewis <[email protected]>
Co-authored-by: Sai Hemanth Bheemreddy <[email protected]>
Co-authored-by: Kyle Penfound <[email protected]>
Co-authored-by: Victor Rodriguez <[email protected]>

* UI/chart legend (#13437)

* fixes axes lines blend

* add pixel conversions to variable css file

* reorganizes css file

* adds legend

* fixes scales and makes room for legend

* fixes grid for dual charts

* made grid responsive

* fixes legend styling

* fixes legend, removes ticks and fixes scale

* adjusts tooltip target

* un-comment mouse events

* remove console log

* UI/ Client counts range (running total component) (#13477)

* grid for stacked charts

* pass in data as arg from parent

* pull out vertical bar chart component

* refactor to use vertical bar chart component

* remove any chart handling stuff from parent

* rename variables

* refactor horizontal bar chart into separate component

* move descriptions to inside template (not passed in)

* constructs attribution copy

* add sample response to mirage config

* change indenting

* rename to MonthlyUsage

* change name to running totals

* rename variable

* finishes line chart

* pull constants to util

* cleanup add todos

* fix formatNumbers return"

* comments and cleanup

* adds tooltip to line chart

* make cover area larger

* fixes tooltip styling

* adds tooltip styling"

* adds tooltip modal to horizontal chart

* finishes tooltip for horizontal chart

* remove click event arg

* merges main and fixes conflicts

* bumps yarn.lock

* linting fix

* clean up go files and changelog

* more clean up

* remove changelog

* fix

* update component documentation for jsdocs

* removing test to see if that helps with browserstack

* remove new packages to test dep failure

* add ember-modal-dialog

* add ember-tether

* add ember-tether

* fixes mirage config file - merge conflict issue

* remove general spacing variable

Co-authored-by: claire bontempo <[email protected]>
Co-authored-by: Claire Bontempo <[email protected]>
Co-authored-by: Jim Kalafut <[email protected]>
Co-authored-by: Nick Cabatoff <[email protected]>
Co-authored-by: Harsimran Singh Maan <[email protected]>
Co-authored-by: Steven Clark <[email protected]>
Co-authored-by: Loann Le <[email protected]>
Co-authored-by: Jordan Reimer <[email protected]>
Co-authored-by: mickael-hc <[email protected]>
Co-authored-by: Calvin Leung Huang <[email protected]>
Co-authored-by: Mike Green <[email protected]>
Co-authored-by: Noel Quiles <[email protected]>
Co-authored-by: Tom Proctor <[email protected]>
Co-authored-by: Matt Schultz <[email protected]>
Co-authored-by: robison jacka <[email protected]>
Co-authored-by: Theron Voran <[email protected]>
Co-authored-by: Pratyoy Mukhopadhyay <[email protected]>
Co-authored-by: Meggie <[email protected]>
Co-authored-by: hghaf099 <[email protected]>
Co-authored-by: John-Michael Faircloth <[email protected]>
Co-authored-by: Brandon Romano <[email protected]>
Co-authored-by: divyapola5 <[email protected]>
Co-authored-by: Chelsea Shaw <[email protected]>
Co-authored-by: Ben Ash <[email protected]>
Co-authored-by: Jason O'Donnell <[email protected]>
Co-authored-by: Alexander Scheel <[email protected]>
Co-authored-by: Mark Lewis <[email protected]>
Co-authored-by: Sai Hemanth Bheemreddy <[email protected]>
Co-authored-by: Kyle Penfound <[email protected]>
Co-authored-by: Victor Rodriguez <[email protected]>
heppu pushed a commit to heppu/vault that referenced this pull request Jan 13, 2022
* VAULT-1564 report in-flight requests

* adding a changelog

* Changing some variable names and fixing comments

* minor style change

* adding unauthenticated support for in-flight-req

* adding documentation for the listener.profiling stanza

* adding an atomic counter for the inflight requests
addressing comments

* addressing comments

* logging completed requests

* fixing a test

* providing log_requests_info as a config option to determine at which level requests should be logged

* removing a member and a method from the StatusHeaderResponseWriter struct

* adding api docks

* revert changes in NewHTTPResponseWriter

* Fix logging invalid log_requests_info value

* Addressing comments

* Fixing a test

* use an tomic value for logRequestsInfo, and moving the CreateClientID function to Core

* fixing go.sum

* minor refactoring

* protecting InFlightRequests from data race

* another try on fixing a data race

* another try to fix a data race

* addressing comments

* fixing couple of tests

* changing log_requests_info to log_requests_level

* minor style change

* fixing a test

* removing the lock in InFlightRequests

* use single-argument form for interface assertion

* adding doc for the new configuration paramter

* adding the new doc to the nav data file

* minor fix
heppu pushed a commit to heppu/vault that referenced this pull request Jan 13, 2022
* UI/total client usage (hashicorp#13359)

* blah

* setup

* clean up

* rename history to dashboard

* clean up

* Styling fixes (hashicorp#13369)

* styling

* clean up

* UI/ horizontal bar chart component (hashicorp#13361)

* horizontal bar chart component

* adds horizontal chart to dashboard file

* add export class

* yarn install d3 array

* yarn install d3 array

* adds data subtext to chart

* update naming to plural charts"

* updates css grid to 6 columns"

* UI/tooltip (hashicorp#13397)

* working state

* stuff

* adds month tick marks and sort of y-axis, but y scale still messed up

* moves y scale so zero shows again

* fixes translating constants

* format numbers y axis

* actually fixes viewbox

* styling for x and y axis plus gridlines

* clean up

* separates grid types based on content

Co-authored-by: Claire Bontempo <[email protected]>

* Styling and legend component (hashicorp#13430)

* styling

* cleanup

* UI/ Double horizontal bar charts (hashicorp#13398)

* add descriptions and styling to side by side charts

* add border below horizontal charts

* starts legend styling

* center legend

* add to do

* add hover actions/event listeners

* UI/merge main (hashicorp#13436)

* Rename master key to root key (hashicorp#13324)

* See what it looks like to replace "master key" with "root key".  There are two places that would require more challenging code changes: the storage path `core/master`, and its contents (the JSON-serialized EncodedKeyringtructure.)

* Restore accidentally deleted line

* Add changelog

* Update root->recovery

* Fix test

Co-authored-by: Nick Cabatoff <[email protected]>

* Fix typo (hashicorp#13355)

* Add kms_library configuration stanza (hashicorp#13352)

- Add the kms_library configuration stanza to Vault's command/server
 - Provide validation of keys and general configuration.
 - Add initial kms_library configuration documentation
 - Attempt at startup to verify we can read the configured HSM Library
 - Hook in KmsLibrary config into the Validate to detect typo/unused keys

* modifed note (hashicorp#13351)

* Incorporate Ember Flight Icons (hashicorp#12976)

* adds ember-flight-icons dependecy

* adds inline-json-import babel plugin

* adds flight icon styling

* updates Icon component to support flight icons

* updates Icon component usages to new api and updates name values to flight icon set when available

* fixes tests

* updates icon story with flight mappings and fixes issue with flight icons not rendering in storybook

* adds changelog

* fixes typo in sign action glyph name in transit-key model

* adds comments to icon-map

* updates Icon component to use only supported flight icon sizes

* adds icon transform codemod

* updates icon transform formatting to handle edge case

* runs icon transform on templates

* updates Icon usage in toolbar-filter md and story

* updates tests

* docs: winsvc update recommendations (hashicorp#13280)

* docs: update custom database sample code (hashicorp#13211)

* clarify more sink options (hashicorp#12586)

* Update @hashicorp/react-hashi-stack-menu (hashicorp#13354)

* Docs to clarify k8s auth options with short-lived tokens (hashicorp#13275)

* Rework 1.21 content into one heading and add note at top
* Add notes about extended k8s token duration
* Add example of ClusterRoleBinding for using client JWTs

* Adds support for SHA-3 to transit (hashicorp#13367)

* Adding support for SHA3 in the transit backend.

* Adds SHA-3 tests for transit sign/verify path. Adds SHA-3 tests for logical system tools path hash functionality. Updates documentation to include SHA-3 algorithms in system tools path hashing.

* Adds changelog entry.

Co-authored-by: robison jacka <[email protected]>

* agent/cache: differentiate open log messages (hashicorp#13362)

Changes the error output for the second open of the persistent cache
file, to differentiate it from the c.UI.Error message for the initial
open of the cache file, just to make it easier to tell where a problem
occurred.

* Warn user supplying nonce values in FIPS mode for transit encryption requests (hashicorp#13366)

* Warn user supplying nonce values in FIPS mode for transit encryption requests

 - Send back a warning within the response if an end-user supplies nonce
   values that we use within the various transit encrypt apis.
 - We do not send a warning if an end-user supplies a nonce value but we
   don't use it.
 - Affected api methods are encrypt, rewrap and datakey
 - The warning is only sent when we are operating in FIPS mode.

* [VAULT-3252] Add entity-alias behavior change to docs (hashicorp#13370)

* Add entity-alias behavior change to docs

* Add upgrade note about entity-alias mapping change

* Rename 1.7-9 upgrade pages, shuffle upgrade note position

* Update website/content/partials/entity-alias-mapping.mdx

Co-authored-by: Meggie <[email protected]>

* Add incorrect policy issue to the docs

* Add example about entity-alias restriction

Co-authored-by: Meggie <[email protected]>

* VAULT-1564 report in-flight requests (hashicorp#13024)

* VAULT-1564 report in-flight requests

* adding a changelog

* Changing some variable names and fixing comments

* minor style change

* adding unauthenticated support for in-flight-req

* adding documentation for the listener.profiling stanza

* adding an atomic counter for the inflight requests
addressing comments

* addressing comments

* logging completed requests

* fixing a test

* providing log_requests_info as a config option to determine at which level requests should be logged

* removing a member and a method from the StatusHeaderResponseWriter struct

* adding api docks

* revert changes in NewHTTPResponseWriter

* Fix logging invalid log_requests_info value

* Addressing comments

* Fixing a test

* use an tomic value for logRequestsInfo, and moving the CreateClientID function to Core

* fixing go.sum

* minor refactoring

* protecting InFlightRequests from data race

* another try on fixing a data race

* another try to fix a data race

* addressing comments

* fixing couple of tests

* changing log_requests_info to log_requests_level

* minor style change

* fixing a test

* removing the lock in InFlightRequests

* use single-argument form for interface assertion

* adding doc for the new configuration paramter

* adding the new doc to the nav data file

* minor fix

* auth/jwt: Update plugin to v0.11.3 (hashicorp#13365)

* auth/jwt: Update plugin to v0.11.3

* add changelog

* changelog++

* Update alert banner (hashicorp#13375)

* Updating website for 1.9.1 (hashicorp#13378)

* Use os.Hostname instead of a dependency that doesn't work on OpenBSD. (hashicorp#13389)

* Remove another use gopsutil/host. (hashicorp#13390)

* CLI changes for new mount tune config parameter allowed_managed_keys (hashicorp#13255)

* CLI changes for new mount tune config parameter allowed_managed_keys

* Correct allowed_managed_keys description in auth and secrets

* Documentation update for secrets and removed changes for auth

* Add changelog and remove documentation changes for auth

* removed changelog

* Correct the field description

* auth/jwt: update changelog for pkce improvement (hashicorp#13392)

* Fix test validating convergent encryption behaviour across key types (hashicorp#13371)

- The test was attempting to test the convergent encryption behaviour
  with several key types but the common function never used the passed
  in key type. So we ran the test with the default aes256-gcm96 only.

* Fix managed namespace test (hashicorp#13394)

* Fix managed namespace test

* Remove log

* Some changelog tidying for 1.10 preview (hashicorp#13385)

* Some changelog tidying for 1.10 preview

* PR accounted for by different CL entry

* changelog++

Working on a new workflow for generating the preview so I thought I'd leave a note that it's still coming.

* UI/fix client count partial (hashicorp#13396)

* Initial fix

* Add fallback zero values

* Add changelog

* Fix client count current test

* Support clearing an identity alias' custom_metadata (hashicorp#13395)

* Support clearing an identity alias' custom_metadata

Previously, an update to an entity alias supported updating the
custom_metadata as long as the update was not empty, which makes it
impossible to clear the metadata values completely.

Fixes:
- empty custom_metadata parameters are honoured on entity alias update
- update related tests
- drop dependency on mapstructure
- reformat with gofumpt

* Docs: fix invalid link in the kubernetes auth api doc. (hashicorp#13399)

* Clean up whitespace

* auth/azure: add note about debug env (hashicorp#13405)

* auth/azure: add note about debug env

* Update azure.mdx

* Update azure.mdx

* Add universal default key_bits value for PKI endpoints (hashicorp#13080)

* Allow universal default for key_bits

This allows the key_bits field to take a universal default value, 0,
which, depending on key_type, gets adjusted appropriately into a
specific default value (rsa->2048, ec->256, ignored under ed25519).

Signed-off-by: Alexander Scheel <[email protected]>

* Handle universal default key size in certutil

Also move RSA < 2048 error message into certutil directly, instead of in
ca_util/path_roles.

Signed-off-by: Alexander Scheel <[email protected]>

* Add missing RSA key sizes to pki/backend_test.go

Signed-off-by: Alexander Scheel <[email protected]>

* Switch to returning updated values

When determining the default, don't pass in pointer types, but instead
return the newly updated value.

Signed-off-by: Alexander Scheel <[email protected]>

* Add changelog entry

Signed-off-by: Alexander Scheel <[email protected]>

* Re-add fix for ed25519 from hashicorp#13254

Ed25519 internally specifies a hash length; by changing the default from
256 to 0, we fail validation in ValidateSignatureLength(...) unless we
specify the key algorithm.

Signed-off-by: Alexander Scheel <[email protected]>

* Fix logging statement using formatting args (hashicorp#13407)

* Add docs about path param restrictions (hashicorp#13413)

* Add docs about path param restrictions

* Update website/content/api-docs/auth/userpass.mdx

Co-authored-by: Loann Le <[email protected]>

* Update with review suggestion

Co-authored-by: Loann Le <[email protected]>

* Update raftautosnapshots.mdx (hashicorp#13412)

* Main go version bump (hashicorp#13408)

* Go 1.17.2 -> 1.17.5
* Switching to cimg

* Bump yarn cache key version so that it uses the new disk layout we've adopted for using cimg/go. (hashicorp#13420)

* Add vault-api module (hashicorp#13048)

* crt main fix for ecr tag (hashicorp#13425)

* Add no-op method setupManagedKeyRegistry(). (hashicorp#13433)

* github auth: use org id to verify creds (hashicorp#13332)

* github auth: use org id to verify creds

* add check for required org param; add test case

* update UTs

* add nil check for org

* add changelog

* fix typo in ut

* set org ID if it is unset; add more ut coverage

* add optional organization_id

* move client instantiation

* refactor parse URL; add UT for setting org ID

* fix comment in UT

* add nil check

* don't update org name on change; return warning

* refactor verifyCredentials

* error when unable to fetch org ID on config write; add warnings

* fix bug in log message

* update UT and small refactor

* update comments and log msg

* use getter for org ID

Co-authored-by: Jim Kalafut <[email protected]>
Co-authored-by: Nick Cabatoff <[email protected]>
Co-authored-by: Harsimran Singh Maan <[email protected]>
Co-authored-by: Steven Clark <[email protected]>
Co-authored-by: Loann Le <[email protected]>
Co-authored-by: Jordan Reimer <[email protected]>
Co-authored-by: mickael-hc <[email protected]>
Co-authored-by: Calvin Leung Huang <[email protected]>
Co-authored-by: Mike Green <[email protected]>
Co-authored-by: Noel Quiles <[email protected]>
Co-authored-by: Tom Proctor <[email protected]>
Co-authored-by: Matt Schultz <[email protected]>
Co-authored-by: robison jacka <[email protected]>
Co-authored-by: Theron Voran <[email protected]>
Co-authored-by: Pratyoy Mukhopadhyay <[email protected]>
Co-authored-by: Meggie <[email protected]>
Co-authored-by: hghaf099 <[email protected]>
Co-authored-by: John-Michael Faircloth <[email protected]>
Co-authored-by: Brandon Romano <[email protected]>
Co-authored-by: divyapola5 <[email protected]>
Co-authored-by: Chelsea Shaw <[email protected]>
Co-authored-by: Ben Ash <[email protected]>
Co-authored-by: Jason O'Donnell <[email protected]>
Co-authored-by: Alexander Scheel <[email protected]>
Co-authored-by: Mark Lewis <[email protected]>
Co-authored-by: Sai Hemanth Bheemreddy <[email protected]>
Co-authored-by: Kyle Penfound <[email protected]>
Co-authored-by: Victor Rodriguez <[email protected]>

* UI/chart legend (hashicorp#13437)

* fixes axes lines blend

* add pixel conversions to variable css file

* reorganizes css file

* adds legend

* fixes scales and makes room for legend

* fixes grid for dual charts

* made grid responsive

* fixes legend styling

* fixes legend, removes ticks and fixes scale

* adjusts tooltip target

* un-comment mouse events

* remove console log

* UI/ Client counts range (running total component) (hashicorp#13477)

* grid for stacked charts

* pass in data as arg from parent

* pull out vertical bar chart component

* refactor to use vertical bar chart component

* remove any chart handling stuff from parent

* rename variables

* refactor horizontal bar chart into separate component

* move descriptions to inside template (not passed in)

* constructs attribution copy

* add sample response to mirage config

* change indenting

* rename to MonthlyUsage

* change name to running totals

* rename variable

* finishes line chart

* pull constants to util

* cleanup add todos

* fix formatNumbers return"

* comments and cleanup

* adds tooltip to line chart

* make cover area larger

* fixes tooltip styling

* adds tooltip styling"

* adds tooltip modal to horizontal chart

* finishes tooltip for horizontal chart

* remove click event arg

* merges main and fixes conflicts

* bumps yarn.lock

* linting fix

* clean up go files and changelog

* more clean up

* remove changelog

* fix

* update component documentation for jsdocs

* removing test to see if that helps with browserstack

* remove new packages to test dep failure

* add ember-modal-dialog

* add ember-tether

* add ember-tether

* fixes mirage config file - merge conflict issue

* remove general spacing variable

Co-authored-by: claire bontempo <[email protected]>
Co-authored-by: Claire Bontempo <[email protected]>
Co-authored-by: Jim Kalafut <[email protected]>
Co-authored-by: Nick Cabatoff <[email protected]>
Co-authored-by: Harsimran Singh Maan <[email protected]>
Co-authored-by: Steven Clark <[email protected]>
Co-authored-by: Loann Le <[email protected]>
Co-authored-by: Jordan Reimer <[email protected]>
Co-authored-by: mickael-hc <[email protected]>
Co-authored-by: Calvin Leung Huang <[email protected]>
Co-authored-by: Mike Green <[email protected]>
Co-authored-by: Noel Quiles <[email protected]>
Co-authored-by: Tom Proctor <[email protected]>
Co-authored-by: Matt Schultz <[email protected]>
Co-authored-by: robison jacka <[email protected]>
Co-authored-by: Theron Voran <[email protected]>
Co-authored-by: Pratyoy Mukhopadhyay <[email protected]>
Co-authored-by: Meggie <[email protected]>
Co-authored-by: hghaf099 <[email protected]>
Co-authored-by: John-Michael Faircloth <[email protected]>
Co-authored-by: Brandon Romano <[email protected]>
Co-authored-by: divyapola5 <[email protected]>
Co-authored-by: Chelsea Shaw <[email protected]>
Co-authored-by: Ben Ash <[email protected]>
Co-authored-by: Jason O'Donnell <[email protected]>
Co-authored-by: Alexander Scheel <[email protected]>
Co-authored-by: Mark Lewis <[email protected]>
Co-authored-by: Sai Hemanth Bheemreddy <[email protected]>
Co-authored-by: Kyle Penfound <[email protected]>
Co-authored-by: Victor Rodriguez <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants