-
Notifications
You must be signed in to change notification settings - Fork 6
/
post-issue-smartsheet.py
70 lines (64 loc) · 2.12 KB
/
post-issue-smartsheet.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
60
61
62
63
64
65
66
67
68
69
70
import requests
import smartsheet
import logging
import os
SMART_ACCESS_TOKEN = os.environ['SMART_ACCESS_TOKEN']
GITHUB_ACCESS_TOKEN = os.environ['GH_ACCESS_TOKEN']
ISSUE_NUM = os.environ['ISSUE_NUM']
# Initialize client. Uses the API token in the environment variable 'SMARTSHEET_ACCESS_TOKEN'
smart = smartsheet.Smartsheet(SMART_ACCESS_TOKEN)
# Make sure we don't miss any error
smart.errors_as_exceptions(True)
# Log all calls
logging.basicConfig(filename='rwsheet.log', level=logging.INFO)
# GET request to GitHub API
response = requests.get(
f'https://api.github.com/repos/SeattleColleges/belindas-closet-nextjs/issues/{ISSUE_NUM}',
headers={'Authorization': GITHUB_ACCESS_TOKEN,
'Content-Type': 'application/vnd.github+json',
'X-GitHub-Api-Version': '2022-11-28'})
issues = response.json()
assignee = 'assignee'
try:
if issues['assignee'] is not None:
assignee = issues['assignee']['login']
else:
assignee = 'Missing assignee'
except TypeError:
assignee = 'Missing assignee'
title = issues['title']
repo_url = issues['repository_url']
index = issues['number']
# POST request to Smartsheet API
smartsheet_response = requests.post(
'https://api.smartsheet.com/2.0/sheets/3026189207687044/rows',
headers={'Authorization': f'Bearer {SMART_ACCESS_TOKEN}', 'Content-Type': 'application/json'},
json={
'sheetId': 3026189207687044,
'accessLevel': 'OWNER',
'createdBy': {
'name': 'automation'
},
'cells': [
{
'columnId': 87440606842756,
'displayValue': 'title',
'value': title
},
{
'columnId': 4591040234213252,
'displayValue': 'repo url',
'value': repo_url[45:]
},
{
'columnId': 6842840047898500,
'displayValue': 'assignee',
'value': assignee
},
{
'columnId': 1213340513685380,
'displayValue': 'index',
'value': index
}
]
})