-
Notifications
You must be signed in to change notification settings - Fork 0
/
create_or_update_repo_secret.py
59 lines (48 loc) · 1.99 KB
/
create_or_update_repo_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
59
import requests
import os
from datetime import datetime
import pytz
def current_ist_time():
"""code to return time in IST"""
# Get the current time in IST
ist = pytz.timezone('Asia/Kolkata')
ist_now = datetime.now(ist)
# Format and print the current time in IST
ist_now_formatted = ist_now.strftime('%Y-%m-%d %H:%M:%S %Z%z')
return ist_now_formatted
def create_or_update_repository_secret_github(organization: str, secret_name: str):
"""
Create or update org level secret in GitHub
Ref https://docs.github.com/en/rest/actions/secrets?apiVersion=2022-11-28#create-or-update-an-organization-secret
The token must have the following permission set: organization_secrets:write
"""
encrypted_secret = os.getenv('ENCRYPTED_SECRET')
repo_name = os.getenv('REPOSITORY_NAME')
if not encrypted_secret:
print("ENCRYPTED_SECRET environment variable is not set or is empty.")
print(f'encrypted sec is: {encrypted_secret}')
ist_now_formatted = current_ist_time()
github_repo_secret_endpoint = f"https://api.github.com/repos/{organization}/{repo_name}/actions/secrets/{secret_name}"
headers = {
"Accept": "application/vnd.github+json",
"Authorization": f"Bearer {os.getenv('GH_TOKEN')}",
"X-GitHub-Api-Version": "2022-11-28"
}
data = {
"encrypted_value": encrypted_secret,
"visibility": "all",
"key_id": os.getenv('REPOSITORY_PUBLIC_KEY_ID')
}
response = requests.put(github_repo_secret_endpoint, headers=headers, json=data)
if response.status_code == 201:
print(f"Secret {secret_name} created {repo_name} at {ist_now_formatted} ")
else:
print(f"Secret {secret_name} updated on {repo_name} at {ist_now_formatted} ")
def main():
"""To test the code"""
organization = os.getenv('organization')
secret_name = os.getenv('secret_name')
# Function call
create_or_update_repository_secret_github(organization, secret_name)
if __name__ == "__main__":
main()