-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathget-secret.py
58 lines (45 loc) · 1.33 KB
/
get-secret.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# Import the PrivX python library.
import json
import config
# this importation for demonstration purpose only
# for proper importation of privx_api module
# see https://github.com/SSHcom/privx-sdk-for-python#getting-started
try:
# Running example with pip-installed SDK
import privx_api
except ImportError:
# Running example without installing SDK
from utils import load_privx_api_lib_path
load_privx_api_lib_path()
import privx_api
# Replace with the name of the secret you want to fetch
SECRET_NAME = "Name of the secret"
# Initialize the API.
api = privx_api.PrivXAPI(
config.HOSTNAME,
config.HOSTPORT,
config.CA_CERT,
config.OAUTH_CLIENT_ID,
config.OAUTH_CLIENT_SECRET,
)
# Authenticate.
# NOTE: fill in your credentials from secure storage, this is just an example
api.authenticate(config.API_CLIENT_ID, config.API_CLIENT_SECRET)
def get_secret(name: str) -> str:
"""
Return the data of the secret with the given name
Parameters:
name (str): Name of the target secret
Returns:
The secret data JSON.
"""
secret = api.get_secret(name)
if secret.ok:
return secret.data["data"]
else:
return secret.data["details"]
def main():
secret = get_secret(SECRET_NAME)
print(json.dumps(secret, indent=4))
if __name__ == "__main__":
main()