forked from sdruskat/cfftracker
-
Notifications
You must be signed in to change notification settings - Fork 0
/
query_api.py
53 lines (41 loc) · 1.71 KB
/
query_api.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
# SPDX-FileCopyrightText: 2021 Stephan Druskat <[email protected]>
# SPDX-License-Identifier: MIT
import requests
from datetime import date
import csv
import re
import os
from time import sleep
sleep_time = 10
def query():
# Retrieve the total count of CITATION.cff files on GitHub via the GitHub API
token = os.environ.get('GITHUB_TOKEN')
query_url = 'https://api.github.com/search/code?q=filename:CITATION.cff'
response = requests.get(query_url, headers={'Authorization': 'token ' + token})
response_json = response.json()
# Catch if the total_count key doesn't exist and try again
try:
count = response_json['total_count']
# Write a new line in the csv file containing the current date and the count
with open('cff_counts.csv', 'a+', newline='') as csv_file:
today = str(date.today())
csv.writer(csv_file).writerow([today, count])
# Write a file with just the current_count in it so that it can be reused elsewhere
with open('current_count.txt', 'w') as countfile:
countfile.write(str(count))
# Replace the current count in README.md
readme = 'README.md'
# Read in the file
with open(readme, 'r') as fi:
readme_data = fi.read()
# Replace the target string
readme_data = re.sub(r'## Current count: \d+', '## Current count: ' + str(count), readme_data)
# Write the file out again
with open(readme, 'w') as fo:
fo.write(readme_data)
except KeyError:
print('No field "total_count" found in API reponse, retrying in ' + str(sleep_time) + ' seconds...')
sleep(sleep_time)
query()
if __name__ == "__main__":
query()