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

SM-874: Fix Python Integration #229

Merged
merged 24 commits into from
Nov 27, 2023
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
007bae3
SM-874: Update BitwardenClient in login.py
coltonhurst Aug 29, 2023
c384428
Merge branch 'master' into sm/sm-874
coltonhurst Sep 11, 2023
bfa8d94
sm/sm-874: Fix Python SDK integration
coltonhurst Sep 12, 2023
7628b8a
Merge branch 'master' into sm/sm-874
coltonhurst Sep 12, 2023
1833336
SM-874: Add project_ids param to SecretsClient update function in bit…
coltonhurst Sep 13, 2023
82f0fe1
Merge branch 'master' into sm/sm-874
coltonhurst Sep 14, 2023
8c6b527
SM-874: Add a ProjectsClient and address PR comments
coltonhurst Sep 15, 2023
279253e
Merge branch 'master' into sm/sm-874
coltonhurst Sep 15, 2023
4212204
SM-874: Rename login.py and remove unused functions in bitwarden_clie…
coltonhurst Sep 19, 2023
7559397
Merge branch 'master' into sm/sm-874
coltonhurst Sep 19, 2023
87e4c22
Merge branch 'master' into sm/sm-874
coltonhurst Sep 26, 2023
b10fd14
Merge branch 'master' into sm/sm-874
coltonhurst Oct 17, 2023
8f0885e
SM-874: Handle error cases on secret deletes
coltonhurst Oct 18, 2023
578f41c
SM-874: Fix linting issue
coltonhurst Oct 18, 2023
aca61bf
SM-874: Handle error cases on project deletes
coltonhurst Oct 18, 2023
b489e6d
Merge branch 'master' into sm/sm-874
coltonhurst Oct 19, 2023
171d8a3
SM-874: Revert error.rs, projects/delete.rs, and secrets/delete.rs
coltonhurst Oct 23, 2023
14af6a7
Merge branch 'master' into sm/sm-874
coltonhurst Oct 23, 2023
2d421cb
Merge branch 'master' into sm/sm-874
coltonhurst Nov 16, 2023
f80c4dd
SM-874: Move failure check to run_command function
coltonhurst Nov 16, 2023
c992350
Remove return value from access_token_login
coltonhurst Nov 16, 2023
39c2982
Merge branch 'master' into sm/sm-874
coltonhurst Nov 17, 2023
e8a445b
SM-874: In example.py, secrets.get should pass the id, not an array o…
coltonhurst Nov 17, 2023
08f92db
Merge branch 'master' into sm/sm-874
coltonhurst Nov 20, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions crates/sdk-schemas/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,7 @@ fn main() -> Result<()> {
write_schema_for_response! {
bitwarden::auth::login::ApiKeyLoginResponse,
bitwarden::auth::login::PasswordLoginResponse,
bitwarden::auth::login::AccessTokenLoginResponse,
bitwarden::secrets_manager::secrets::SecretIdentifiersResponse,
bitwarden::secrets_manager::secrets::SecretResponse,
bitwarden::secrets_manager::secrets::SecretsResponse,
Expand Down
25 changes: 17 additions & 8 deletions languages/python/BitwardenClient/bitwarden_client.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import json
from typing import Any, List
from typing import Any, List, Optional
from uuid import UUID
import bitwarden_py
from .schemas import ClientSettings, Command, PasswordLoginRequest, PasswordLoginResponse, ResponseForPasswordLoginResponse, ResponseForSecretIdentifiersResponse, ResponseForSecretResponse, ResponseForSecretsDeleteResponse, ResponseForSyncResponse, ResponseForUserAPIKeyResponse, SecretCreateRequest, SecretGetRequest, SecretIdentifiersRequest, SecretIdentifiersResponse, SecretPutRequest, SecretResponse, SecretVerificationRequest, SecretsCommand, SecretsDeleteRequest, SecretsDeleteResponse, SyncRequest, SyncResponse, UserAPIKeyResponse

from .schemas import ClientSettings, Command, PasswordLoginRequest, PasswordLoginResponse, ResponseForPasswordLoginResponse, ResponseForSecretIdentifiersResponse, ResponseForSecretResponse, ResponseForSecretsDeleteResponse, ResponseForSyncResponse, ResponseForUserAPIKeyResponse, SecretCreateRequest, SecretGetRequest, SecretIdentifiersRequest, SecretIdentifiersResponse, SecretPutRequest, SecretResponse, SecretVerificationRequest, SecretsCommand, SecretsDeleteRequest, SecretsDeleteResponse, SyncRequest, SyncResponse, UserAPIKeyResponse, AccessTokenLoginRequest, AccessTokenLoginResponse, ResponseForAccessTokenLoginResponse

class BitwardenClient:
def __init__(self, settings: ClientSettings = None):
Expand All @@ -18,6 +18,12 @@ def password_login(self, email: str, password: str) -> ResponseForPasswordLoginR
)
return ResponseForPasswordLoginResponse.from_dict(result)
coltonhurst marked this conversation as resolved.
Show resolved Hide resolved

def access_token_login(self, access_token: str) -> AccessTokenLoginResponse:
dani-garcia marked this conversation as resolved.
Show resolved Hide resolved
result = self._run_command(
Command(access_token_login=AccessTokenLoginRequest(access_token))
)
return ResponseForAccessTokenLoginResponse.from_dict(result)

def get_user_api_key(self, secret: str, is_otp: bool = False) -> ResponseForUserAPIKeyResponse:
result = self._run_command(
Command(get_user_api_key=SecretVerificationRequest(
Expand All @@ -38,7 +44,6 @@ def _run_command(self, command: Command) -> Any:
response_json = self.inner.run_command(json.dumps(command.to_dict()))
return json.loads(response_json)


class SecretsClient:
def __init__(self, client: BitwardenClient):
self.client = client
Expand All @@ -52,10 +57,12 @@ def get(self, id: str) -> ResponseForSecretResponse:
def create(self, key: str,
note: str,
organization_id: str,
value: str) -> ResponseForSecretResponse:
value: str,
project_ids: Optional[List[UUID]] = None
) -> ResponseForSecretResponse:
result = self.client._run_command(
Command(secrets=SecretsCommand(
create=SecretCreateRequest(key, note, organization_id, value)))
create=SecretCreateRequest(key, note, organization_id, value, project_ids)))
)
return ResponseForSecretResponse.from_dict(result)

Expand All @@ -70,10 +77,12 @@ def update(self, id: str,
key: str,
note: str,
organization_id: str,
value: str) -> ResponseForSecretResponse:
value: str,
project_ids: Optional[List[UUID]] = None
) -> ResponseForSecretResponse:
result = self.client._run_command(
Command(secrets=SecretsCommand(update=SecretPutRequest(
id, key, note, organization_id, value)))
id, key, note, organization_id, value, project_ids)))
)
return ResponseForSecretResponse.from_dict(result)

Expand Down
6 changes: 5 additions & 1 deletion languages/python/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,10 @@
```bash
pip install setuptools_rust
```
- dateutil
```bash
pip install python-dateutil
```

# Installation

Expand All @@ -18,7 +22,7 @@ From the `languages/python/` directory,
python3 ./setup.py develop
```

Move the the resulting `.so` file to `bitwarden_py.so`, if it isn't already there.
Rename the the resulting `.so` file to `bitwarden_py.so`, if it isn't already there.

# Run

Expand Down
17 changes: 7 additions & 10 deletions languages/python/login.py
coltonhurst marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -4,21 +4,18 @@
from BitwardenClient.schemas import client_settings_from_dict

client = BitwardenClient(client_settings_from_dict({
"api_url": "http://localhost:4000",
"identity_url": "http://localhost:33656",
"user_agent": "Python",
"apiUrl": "http://localhost:4000",
"deviceType": "SDK",
coltonhurst marked this conversation as resolved.
Show resolved Hide resolved
"identityUrl": "http://localhost:33656",
"userAgent": "Python",
}))

logging.basicConfig(level=logging.DEBUG)

result = client.password_login("[email protected]", "asdfasdf")
print(result)
print(client.get_user_api_key("asdfasdf"))
result = client.access_token_login("access token here")

coltonhurst marked this conversation as resolved.
Show resolved Hide resolved
sync = client.sync()
secret = client.secrets().create("TEST_SECRET", "This is a test secret", "organization id here", "Secret1234!", ["project id here"])

secret = client.secrets().create("TEST_SECRET", "This is a test secret",
sync.data.profile.organizations[0].id, "Secret1234!")
print(secret)
input("Press Enter to delete the secret...")

client.secrets().delete([secret.data.id])