Compare commits
No commits in common. "4e23b67f5d5f580e6ca0d6ec684d09959e20fa4c" and "67692b372fbdff41bcedbfa5c4f5f2f68d46aef6" have entirely different histories.
4e23b67f5d
...
67692b372f
25
src/kv.py
25
src/kv.py
@ -19,17 +19,11 @@ def create_kv(secret, secret_json, content_def):
|
|||||||
if key == "secretScope":
|
if key == "secretScope":
|
||||||
_secret_scope = value
|
_secret_scope = value
|
||||||
if _secret_scope == "login":
|
if _secret_scope == "login":
|
||||||
value = parse_login_scope(secret_json, _secret_key)
|
|
||||||
if value is None:
|
|
||||||
raise Exception(f"Field {_secret_key} has no value in bitwarden secret")
|
|
||||||
secret.data[_secret_ref] = str(base64.b64encode(
|
secret.data[_secret_ref] = str(base64.b64encode(
|
||||||
value.encode("utf-8")), "utf-8")
|
parse_login_scope(secret_json, _secret_key).encode("utf-8")), "utf-8")
|
||||||
if _secret_scope == "fields":
|
if _secret_scope == "fields":
|
||||||
value = parse_fields_scope(secret_json, _secret_key)
|
|
||||||
if value is None:
|
|
||||||
raise Exception(f"Field {_secret_key} has no value in bitwarden secret")
|
|
||||||
secret.data[_secret_ref] = str(base64.b64encode(
|
secret.data[_secret_ref] = str(base64.b64encode(
|
||||||
value.encode("utf-8")), "utf-8")
|
parse_fields_scope(secret_json, _secret_key).encode("utf-8")), "utf-8")
|
||||||
return secret
|
return secret
|
||||||
|
|
||||||
|
|
||||||
@ -70,24 +64,9 @@ def update_managed_secret(spec, status, name, namespace, logger, body, **kwargs)
|
|||||||
|
|
||||||
content_def = body['spec']['content']
|
content_def = body['spec']['content']
|
||||||
id = spec.get('id')
|
id = spec.get('id')
|
||||||
old_config = None
|
|
||||||
old_secret_name = None
|
|
||||||
old_secret_namespace = None
|
|
||||||
if 'kopf.zalando.org/last-handled-configuration' in body.metadata.annotations:
|
|
||||||
old_config = json.loads(body.metadata.annotations['kopf.zalando.org/last-handled-configuration'])
|
|
||||||
old_secret_name = old_config['spec'].get('name')
|
|
||||||
old_secret_namespace = old_config['spec'].get('namespace')
|
|
||||||
secret_name = spec.get('name')
|
secret_name = spec.get('name')
|
||||||
secret_namespace = spec.get('namespace')
|
secret_namespace = spec.get('namespace')
|
||||||
|
|
||||||
if old_config is not None and (old_secret_name != secret_name or old_secret_namespace != secret_namespace):
|
|
||||||
# If the name of the secret or the namespace of the secret is different
|
|
||||||
# We have to delete the secret an recreate it
|
|
||||||
logger.info("Secret name or namespace changed, let's recreate it")
|
|
||||||
delete_managed_secret(old_config['spec'], name, namespace, logger, **kwargs)
|
|
||||||
create_managed_secret(spec, name, namespace, logger, body, **kwargs)
|
|
||||||
return
|
|
||||||
|
|
||||||
unlock_bw(logger)
|
unlock_bw(logger)
|
||||||
logger.info(f"Locking up secret with ID: {id}")
|
logger.info(f"Locking up secret with ID: {id}")
|
||||||
secret_json_object = json.loads(get_secret_from_bitwarden(id))
|
secret_json_object = json.loads(get_secret_from_bitwarden(id))
|
||||||
|
@ -31,8 +31,6 @@ def parse_login_scope(secret_json, key):
|
|||||||
return secret_json["login"][key]
|
return secret_json["login"][key]
|
||||||
|
|
||||||
def parse_fields_scope(secret_json, key):
|
def parse_fields_scope(secret_json, key):
|
||||||
if "fields" not in secret_json:
|
|
||||||
return None
|
|
||||||
for entry in secret_json["fields"]:
|
for entry in secret_json["fields"]:
|
||||||
if entry['name'] == key:
|
if entry['name'] == key:
|
||||||
return entry['value']
|
return entry['value']
|
||||||
|
Loading…
Reference in New Issue
Block a user