Secrets Manager Java SDK
The Java language wrapper for interacting with the Bitwarden Secrets Manager. The SDK, like the Secrets Manager CLI built on-top of it, can be used to execute the following operations:
Authenticate using an access token.
List all secrets, secrets in a project, or projects.
備考
This SDK is a beta release. Therefore, some functionality may be missing.
Setting up a Secrets Manager account prior to using the Java SDK is recommended. This includes:
Enabling the Secrets Manager CLI.
Setting up machine accounts.
Setting up access tokens.
Locate the Java GitHub repository here.
Insert the created access token
to authorize the Secrets Manager session:
BashBitwardenSettings bitwardenSettings = new BitwardenSettings();
bitwardenSettings.setApiUrl("https://api.bitwarden.com");
bitwardenSettings.setIdentityUrl("https://identity.bitwarden.com");
BitwardenClient bitwardenClient = new BitwardenClient(bitwardenSettings);
bitwardenClient.accessTokenLogin("<access-token>");
Once the Bitwarden client has been created and authorized, Secrets Manager CLI commands can be passed into the client:
The project command is used to access, manipulate, and create projects. The scope of access assigned to your machine account will determine what actions can be completed with the project
command.
create project
BashUUID organizationId = UUID.fromString("<organization-id>");
var projectResponse = bitwardenClient.projects().create(organizationId, "TestProject");
list projects
Bashvar projectsResponse = bitwardenClient.projects().list(organizationId);
update project
BashUUID projectId = projectResponse.getID();
projectResponse = bitwardenClient.projects().get(projectId);
projectResponse = bitwardenClient.projects.update(projectId, organizationId, "TestProjectUpdated");
delete project
BashbitwardenClient.projects().delete(new UUID[]{projectId});
The secret command is used to access, manipulate and create secrets. As with all commands, secrets and projects outside your access token's scope of access cannot be read or written-to.
create secret
BashString key = "key";
String value = "value";
String note = "note";
var secretResponse = bitwardenClient.secrets().create(key, value, note, organizationId, new UUID[]{projectId});
UUID secretId = secretResponse.getID();
update secret
BashbitwardenClient.secrets().update(secretId, key2, value2, note2, organizationId, new UUID[]{projectId});
list secrets
Bashvar secretIdentifiersResponse secretIdentifiersResponse = bitwardenClient.secrets().list(organizationId);
delete secret
BashbitwardenClient.secrets().delete(new UUID[]{secretId});