mirror of
https://github.com/Adam-Ant/drone-trigger
synced 2024-11-05 05:36:23 +00:00
Initial Commit
This commit is contained in:
commit
2f140230a2
7
Readme.md
Normal file
7
Readme.md
Normal file
@ -0,0 +1,7 @@
|
||||
# Drone Trigger
|
||||
An application to trigger Drone builds based on a changed JSON input.
|
||||
|
||||
|
||||
# How to use
|
||||
|
||||
[[TODO]]
|
137
main.py
Normal file
137
main.py
Normal file
@ -0,0 +1,137 @@
|
||||
import configparser
|
||||
import os
|
||||
import argparse
|
||||
import configparser
|
||||
import time
|
||||
|
||||
import requests
|
||||
|
||||
from json import loads as jload
|
||||
|
||||
defaultconfig = '''
|
||||
# WARNING: COMMENTS IN THIS FILE WILL BE ERASED WHEN PROGRAM IS RUN!
|
||||
[Connection]
|
||||
# Specify the URL to the drone server, including port and protocol
|
||||
host = https://drone.example.org
|
||||
auth_key = eyJEXAMPLE.AUTH.KEY
|
||||
# Specified in seconds (Default: 300)
|
||||
# sleep_time = 300
|
||||
|
||||
#[ExampleGitHubBuild]
|
||||
# Example shown uses githubs api to find and compare on the sha of the latest commit
|
||||
# Name of the repo to trigger in drone
|
||||
#drone_repo = Example/HelloWorld
|
||||
|
||||
# URL of the json structure that needs curling
|
||||
#url = https://api.github.com/repos/Kaylee/ShinyRepo/git/refs/heads/master
|
||||
|
||||
# JSON Tree needed to resolve the value.
|
||||
# structure = object.sha
|
||||
|
||||
|
||||
#[ExampleGitHubRelease]
|
||||
#drone_repo = Example/HelloRelease
|
||||
#url = https://api.github.com/repos/Kaylee/ShinyRepo/releases/latest
|
||||
#structure = name
|
||||
'''
|
||||
|
||||
|
||||
def runbuild(repo: str):
|
||||
url = drone_host + '/api/repos/' + repo
|
||||
latest = jload(requests.get(url + '/builds/latest',
|
||||
headers={'Authorization': auth}).text)['number']
|
||||
buildurl = url + '/builds/' + str(latest) + '?fork=true'
|
||||
# [[TODO]] Add functionality for checking if build was triggered successfully?
|
||||
return (requests.post(buildurl, headers={'Authorization': drone_auth_key}))
|
||||
|
||||
|
||||
def jsonVal(jraw, struct):
|
||||
try:
|
||||
dataDict = jload(jraw)
|
||||
for i in struct.split('.'):
|
||||
dataDict = dataDict[i]
|
||||
return dataDict
|
||||
except KeyError:
|
||||
print('Error: Invalid structure: ' + struct)
|
||||
print(dataDict)
|
||||
exit(1)
|
||||
except:
|
||||
raise
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
argparser = argparse.ArgumentParser(
|
||||
prog='DroneTrigger.py', description='Drone Triggerer triggers drone builds based on updates to arbitrary GitHub repos.')
|
||||
argparser.add_argument(
|
||||
'-c', '--config', help='Specify directory for config file')
|
||||
cmdargs = argparser.parse_args()
|
||||
|
||||
if not (cmdargs.config):
|
||||
filepath = '.'
|
||||
else:
|
||||
filepath = cmdargs.config
|
||||
|
||||
if not (os.path.isdir(filepath)):
|
||||
print('Error: Config directory does not exist. Exiting...')
|
||||
exit(1)
|
||||
|
||||
if not (os.path.isfile(filepath + '/dronetrigger.cfg')):
|
||||
print('Warn: Config file does not exist, writing example config. Please configure and try again.')
|
||||
c = open(filepath + '/dronetrigger.cfg', 'w')
|
||||
c.write(defaultconfig)
|
||||
c.close()
|
||||
exit(78) # 78 is the exit code for invalid config
|
||||
|
||||
config = configparser.ConfigParser()
|
||||
config.read(filepath + '/dronetrigger.cfg')
|
||||
if not ('Connection' in config):
|
||||
print('Error: Connection block not found, please check your config')
|
||||
exit(78)
|
||||
if not (config['Connection'].get('host', False)) or not (config['Connection'].get('auth_key', False)):
|
||||
print('Error: Missing connection details. please check your config')
|
||||
exit(78)
|
||||
if (len(config.sections()) < 2):
|
||||
print('Error: Please configure some monitoring blocks!')
|
||||
exit(78)
|
||||
# These can be assumed since we have verified
|
||||
drone_host = config['Connection']['host']
|
||||
drone_auth_key = config['Connection']['auth_key']
|
||||
sleep_time = config['Connection'].getint('sleep_time', 300)
|
||||
|
||||
for service in config.sections():
|
||||
if service == 'Connection':
|
||||
continue
|
||||
if not (config[service].get('url', False)) or not (config[service].get('structure', False)) or not(config[service].get('drone_repo'), False):
|
||||
print('Error: Missing required value in status block ' + service)
|
||||
exit(78)
|
||||
try:
|
||||
r = requests.get(config[service].get('url'))
|
||||
r.raise_for_status()
|
||||
curr_value = jsonVal(r.text, config[service].get('structure'))
|
||||
except:
|
||||
raise
|
||||
if not (config[service].get('current_value', False)):
|
||||
print('Writing Initial value for ' + service + ': ' + curr_value)
|
||||
config[service]['current_value'] = curr_value
|
||||
with open(filepath + '/dronetrigger.cfg', 'w') as configfile:
|
||||
config.write(configfile)
|
||||
|
||||
while(True):
|
||||
for service in config.sections():
|
||||
if service == 'Connection':
|
||||
continue
|
||||
try:
|
||||
r = requests.get(config[service].get('url'))
|
||||
r.raise_for_status()
|
||||
new_value = jsonVal(r.text, config[service].get('structure'))
|
||||
if (new_value != config[service]['current_value']):
|
||||
print(date.strftime("%d/%m/%Y %H:%M:%S") +
|
||||
': Got new build - ' + new_value)
|
||||
runbuild(config[service].get('drone_repo'))
|
||||
config[service]['current_value'] = new_value
|
||||
with open(filepath + '/dronetrigger.cfg', 'w') as configfile:
|
||||
config.write(configfile)
|
||||
|
||||
except:
|
||||
raise
|
||||
time.sleep(sleep_time)
|
Loading…
Reference in New Issue
Block a user