vault-secret-collection-manager

command
v0.0.0-...-c780de0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 21, 2024 License: Apache-2.0 Imports: 25 Imported by: 0

README

Vault secret collection manager

Description

A webservice that allows to manage secret collections in Vault. A secret collection is a named kv store path in Vault to which members of the secret collection have access.

Authentication is assumed to be delegated to oauth2 proxy and user identity is inferred from the X-Forwarded-Email header. The domain portion is stripped.

How does it work? The secret collection manager has CRUD endpoints for managing a secret collection. A secret collection consists of a group and a policy. The group is needed because policies are an attribute of either a group or a user. Assigning them to users directly would make secret collection membership lookups very expensive, as we would need to list all users.

Usernames are expected to come from an alias. Because vault internally uses IDs and not names, the

  • GroupName <-> GroupID
  • AliasName <-> UserID

mappings are cached after first lookup and assumed to be immutable.

The names of created policies and groups is prefixed with secret-collection-manager-managed-. All secret collections are below a configurable prefix (default: secret/self-managed).

Endpoints:

  • GET /secretcollection: Returns a list of all secret collections for the current user
  • PUT /secretcollection/:name: Creates a new secret collection using the provided name. The secret collection must not exist yet.
  • PATCH /secretcollection/:name: Changes the members of an existing secret colltion. The requesting user must be a member of the collection.

Get the members of a collection's group

  • Login to Vault and click the Access tab.
  • On the Groups tab, Lookup by name and input "secret-collection-manager-managed-<collection-name>"
  • Click Edit in the returned group and find the list of "Member Identity IDs"
  • On the Entities tab, Lookup by id will return the entity.

Development

  • Use docker-compose to start, vault, an oauth2 proxy and a dex instance as an IDP: cd cmd/vault-secret-collection-manager && docker-compose up
  • If you change the typescript, you need to recompile it via make md/vault-secret-collection-manager/index.js
  • Run the secret-collection-manager via go run ./cmd/vault-secret-collection-manager -vault-token=jpuxZFWWFW7vM882GGX2aWOE
  • Visit http://127.0.0.1:4180 and login via admin and password

Documentation

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL