-
Notifications
You must be signed in to change notification settings - Fork 65
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #77 from stormshield-gt/add_Identity_secrets_engine
Add identity secrets engine: `Entity`, `EntityAlias`, `Group` and `GroupAlias`
- Loading branch information
Showing
22 changed files
with
2,079 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,7 @@ | ||
pub mod auth; | ||
pub mod aws; | ||
pub mod database; | ||
pub mod identity; | ||
pub mod kv1; | ||
pub mod kv2; | ||
pub mod pki; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
pub mod entity; | ||
pub mod entity_alias; | ||
pub mod group; | ||
pub mod group_alias; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
pub mod requests; | ||
pub mod responses; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,258 @@ | ||
use rustify_derive::Endpoint; | ||
use serde::Serialize; | ||
use std::{collections::HashMap, fmt::Debug}; | ||
|
||
use super::responses::{ | ||
CreateEntityResponse, ListEntitiesByIdResponse, ListEntitiesByNameResponse, | ||
ReadEntityByIdResponse, ReadEntityByNameResponse, | ||
}; | ||
|
||
/// ## Create an entity | ||
/// | ||
/// This endpoint creates or updates an Entity. | ||
/// | ||
/// Note that it's not possible to set the ID to update an existing entity, [`identity::entity::update_by_id`] | ||
/// is the function to call for that use case. | ||
/// | ||
/// * Path: identity/entity | ||
/// * Method: POST | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#create-an-entity | ||
/// | ||
/// [`identity::entity::update_by_id`]: crate::identity::entity::update_by_id | ||
#[derive(Builder, Debug, Default, Endpoint)] | ||
#[endpoint( | ||
path = "identity/entity", | ||
method = "POST", | ||
builder = "true", | ||
response = "CreateEntityResponse" | ||
)] | ||
#[builder(setter(into, strip_option), default)] | ||
pub struct CreateEntityRequest { | ||
/// Name of the entity. | ||
pub name: Option<String>, | ||
/// Metadata to be associated with the entity. | ||
pub metadata: Option<HashMap<String, String>>, | ||
/// Policies to be tied to the entity. | ||
pub policies: Option<Vec<String>>, | ||
/// Whether the entity is disabled. Disabled entities' associated tokens cannot be used, but are not revoked. | ||
pub disabled: Option<bool>, | ||
} | ||
|
||
/// ## Read entity by ID | ||
/// | ||
/// This endpoint queries the entity by its identifier. | ||
/// | ||
/// * Path: identity/entity/id/{self.id} | ||
/// * Method: GET | ||
/// * Response: [ReadEntityByIdResponse] | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#read-entity-by-id | ||
#[derive(Builder, Debug, Endpoint)] | ||
#[endpoint( | ||
path = "identity/entity/id/{self.id}", | ||
method = "GET", | ||
builder = "true", | ||
response = "ReadEntityByIdResponse" | ||
)] | ||
#[builder(setter(into))] | ||
pub struct ReadEntityByIdRequest { | ||
/// Identifier of the entity. | ||
#[endpoint(skip)] | ||
pub id: String, | ||
} | ||
|
||
/// ## Update entity by ID | ||
/// | ||
/// This endpoint is used to update an existing entity. | ||
/// | ||
/// * Path: identity/entity/id/{self.id} | ||
/// * Method: POST | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#update-entity-by-id | ||
#[derive(Builder, Debug, Default, Endpoint)] | ||
#[endpoint( | ||
path = "identity/entity/id/{self.id}", | ||
method = "POST", | ||
builder = "true" | ||
)] | ||
#[builder(setter(into, strip_option), default)] | ||
pub struct UpdateEntityByIdRequest { | ||
/// Identifier of the entity. | ||
#[endpoint(skip)] | ||
pub id: String, | ||
/// Name of the entity. | ||
pub name: Option<String>, | ||
/// Metadata to be associated with the entity. | ||
pub metadata: Option<HashMap<String, String>>, | ||
/// Policies to be tied to the entity. | ||
pub policies: Option<Vec<String>>, | ||
/// Whether the entity is disabled. Disabled entities' associated tokens cannot be used, but are not revoked. | ||
pub disabled: Option<bool>, | ||
} | ||
|
||
/// ## Delete entity by ID | ||
/// | ||
/// This endpoint deletes an entity and all its associated aliases. | ||
/// | ||
/// * Path: identity/entity/id/{self.id} | ||
/// * Method: DELETE | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#delete-entity-by-id | ||
#[derive(Builder, Debug, Default, Endpoint)] | ||
#[endpoint( | ||
path = "identity/entity/id/{self.id}", | ||
method = "DELETE", | ||
builder = "true" | ||
)] | ||
#[builder(setter(into, strip_option), default)] | ||
pub struct DeleteEntityByIdRequest { | ||
/// Identifier of the entity. | ||
#[endpoint(skip)] | ||
pub id: String, | ||
} | ||
|
||
/// ## Batch delete entities | ||
/// | ||
/// This endpoint deletes all entities provided. | ||
/// | ||
/// * Path: identity/entity/batch-delete | ||
/// * Method: POST | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#batch-delete-entities | ||
#[derive(Builder, Debug, Default, Endpoint)] | ||
#[endpoint( | ||
path = "identity/entity/batch-delete", | ||
method = "POST", | ||
builder = "true" | ||
)] | ||
#[builder(setter(into, strip_option), default)] | ||
pub struct BatchDeleteRequest { | ||
/// List of entity identifiers to delete. | ||
pub entity_ids: Vec<String>, | ||
} | ||
|
||
/// ## List entities by ID | ||
/// | ||
/// This endpoint returns a list of available entities by their identifiers. | ||
/// | ||
/// * Path: identity/entity/id | ||
/// * Method: LIST | ||
/// * Response: [ListEntitiesByIdResponse] | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#list-entities-by-id | ||
#[derive(Builder, Debug, Endpoint, Default)] | ||
#[endpoint( | ||
path = "identity/entity/id", | ||
method = "LIST", | ||
builder = "true", | ||
response = "ListEntitiesByIdResponse" | ||
)] | ||
#[builder(setter(into, strip_option), default)] | ||
pub struct ListEntitiesByIdRequest {} | ||
|
||
/// ## Create/Update an entity by name | ||
/// | ||
/// This endpoint is used to create or update an entity by a given name. | ||
/// | ||
/// * Path: identity/entity/name/{self.name} | ||
/// * Method: POST | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#create-update-entity-by-name | ||
#[derive(Builder, Debug, Default, Endpoint)] | ||
#[endpoint( | ||
path = "identity/entity/name/{self.name}", | ||
method = "POST", | ||
builder = "true" | ||
)] | ||
#[builder(setter(into, strip_option), default)] | ||
pub struct CreateEntityByNameRequest { | ||
/// Name of the entity. | ||
#[endpoint(skip)] | ||
pub name: String, | ||
/// Metadata to be associated with the entity. | ||
pub metadata: Option<HashMap<String, String>>, | ||
/// Policies to be tied to the entity. | ||
pub policies: Option<Vec<String>>, | ||
/// Whether the entity is disabled. Disabled entities' associated tokens cannot be used, but are not revoked. | ||
pub disabled: Option<bool>, | ||
} | ||
|
||
/// ## Read entity by name | ||
/// This endpoint queries the entity by its name. | ||
/// | ||
/// * Path: identity/entity/name/{self.name} | ||
/// * Method: GET | ||
/// * Response: [ReadEntityByNameResponse] | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#read-entity-by-name | ||
#[derive(Builder, Debug, Endpoint, Default)] | ||
#[endpoint( | ||
path = "identity/entity/name/{self.name}", | ||
method = "GET", | ||
builder = "true", | ||
response = "ReadEntityByNameResponse" | ||
)] | ||
#[builder(setter(into, strip_option), default)] | ||
pub struct ReadEntityByNameRequest { | ||
/// Name of the entity. | ||
#[endpoint(skip)] | ||
pub name: String, | ||
} | ||
|
||
/// ## Delete entity by name | ||
/// | ||
/// This endpoint deletes an entity and all its associated aliases, given the entity name. | ||
/// | ||
/// * Path: identity/entity/name/{self.name} | ||
/// * Method: DELETE | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#delete-entity-by-name | ||
#[derive(Builder, Debug, Default, Endpoint)] | ||
#[endpoint( | ||
path = "identity/entity/name/{self.name}", | ||
method = "DELETE", | ||
builder = "true" | ||
)] | ||
#[builder(setter(into, strip_option), default)] | ||
pub struct DeleteEntityByNameRequest { | ||
/// Name of the entity. | ||
#[endpoint(skip)] | ||
pub name: String, | ||
} | ||
|
||
/// ## List entities by name | ||
/// | ||
/// This endpoint returns a list of available entities by their names. | ||
/// | ||
/// * Path: identity/entity/name | ||
/// * Method: LIST | ||
/// * Response: [ListEntitiesByNameResponse] | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#list-entities-by-name | ||
#[derive(Builder, Debug, Endpoint, Default)] | ||
#[endpoint( | ||
path = "identity/entity/name", | ||
method = "LIST", | ||
builder = "true", | ||
response = "ListEntitiesByNameResponse" | ||
)] | ||
#[builder(setter(into, strip_option), default)] | ||
pub struct ListEntitiesByNameRequest {} | ||
|
||
/// ## Merge entities | ||
/// | ||
/// This endpoint merges many entities into one entity. | ||
/// | ||
/// * Path: identity/entity/merge | ||
/// * Method: POST | ||
/// * Reference: https://developer.hashicorp.com/vault/api-docs/secret/identity/entity#merge-entities | ||
#[derive(Builder, Debug, Endpoint, Default)] | ||
#[endpoint(path = "identity/entity/merge", method = "POST", builder = "true")] | ||
#[builder(setter(into, strip_option), default)] | ||
pub struct MergeEntitiesRequest { | ||
/// Entity IDs which need to get merged. | ||
pub from_entity_ids: Vec<String>, | ||
/// Entity ID into which all the other entities need to get merged. | ||
pub to_entity_id: String, | ||
/// Setting this will follow the 'mine' strategy for merging MFA secrets. | ||
/// If there are secrets of the same type both in entities that are merged from and in entity into | ||
/// which all others are getting merged, secrets in the destination will be unaltered. | ||
/// If not set, this API will throw an error containing all the conflicts. | ||
pub force: Option<bool>, | ||
/// A list of entity aliases to keep in the case where the to-Entity and from-Entity have aliases | ||
/// with the same mount accessor. In the case where alias share mount accessors, the alias ID given | ||
/// in this list will be kept or merged, and the other alias will be deleted. | ||
/// Note that merges requiring this parameter must have only one from-Entity. | ||
pub conflicting_alias_ids_to_keep: Option<String>, | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
use std::collections::HashMap; | ||
|
||
use serde::{Deserialize, Serialize}; | ||
|
||
/// Response from executing | ||
/// [CreateEntityRequest](crate::api::identity::entity::requests::CreateEntityRequest) | ||
#[derive(Deserialize, Debug, Serialize)] | ||
pub struct CreateEntityResponse { | ||
pub id: String, | ||
pub alias: Option<Vec<Alias>>, | ||
} | ||
|
||
/// Response from executing | ||
/// [ReadEntityByIdRequest](crate::api::identity::entity::requests::ReadEntityByIdRequest) | ||
#[derive(Deserialize, Debug, Serialize)] | ||
pub struct ReadEntityByIdResponse { | ||
pub id: String, | ||
pub name: String, | ||
pub disabled: bool, | ||
pub policies: Vec<String>, | ||
pub last_update_time: String, | ||
pub creation_time: String, | ||
pub metadata: Option<HashMap<String, String>>, | ||
pub aliases: Vec<Alias>, | ||
} | ||
|
||
/// Response from executing | ||
/// [ReadEntityByNameRequest](crate::api::identity::entity::requests::ReadEntityByNameRequest) | ||
#[derive(Deserialize, Debug, Serialize)] | ||
pub struct ReadEntityByNameResponse { | ||
pub id: String, | ||
pub name: String, | ||
pub disabled: bool, | ||
pub policies: Vec<String>, | ||
pub last_update_time: String, | ||
pub creation_time: String, | ||
pub metadata: Option<HashMap<String, String>>, | ||
pub aliases: Vec<Alias>, | ||
pub direct_group_ids: Vec<String>, | ||
pub group_ids: Vec<String>, | ||
pub inherited_group_ids: Vec<String>, | ||
pub merged_entity_ids: Option<Vec<String>>, | ||
pub namespace_id: String, | ||
} | ||
|
||
#[derive(Deserialize, Debug, Serialize)] | ||
pub struct Alias { | ||
pub id: String, | ||
pub canonical_id: String, | ||
pub mount_accessor: String, | ||
pub name: String, | ||
pub creation_time: String, | ||
pub last_update_time: String, | ||
pub local: bool, | ||
pub mount_type: String, | ||
pub mount_path: String, | ||
pub custom_metadata: Option<HashMap<String, String>>, | ||
pub metadata: Option<HashMap<String, String>>, | ||
pub merged_from_canonical_ids: Option<Vec<String>>, | ||
} | ||
|
||
/// Response from executing | ||
/// [ListEntitiesById](crate::api::identity::entity::requests::ListEntitiesByIdRequest) | ||
#[derive(Deserialize, Debug, Serialize)] | ||
pub struct ListEntitiesByIdResponse { | ||
pub keys: Vec<String>, | ||
} | ||
|
||
/// Response from executing | ||
/// [CreateEntityByNameRequest](crate::api::identity::entity::requests::CreateEntityByNameRequest) | ||
#[derive(Deserialize, Debug, Serialize)] | ||
pub struct CreateEntityByNameResponse { | ||
pub aliases: Option<Vec<Alias>>, | ||
pub id: String, | ||
pub name: String, | ||
} | ||
|
||
/// Response from executing | ||
/// [ListEntitiesById](crate::api::identity::entity::requests::ListEntitiesByNameRequest) | ||
#[derive(Deserialize, Debug, Serialize)] | ||
pub struct ListEntitiesByNameResponse { | ||
pub keys: Vec<String>, | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
pub mod requests; | ||
pub mod responses; |
Oops, something went wrong.