Finish base functionality for trigger execution
This commit is contained in:
parent
7d027225bc
commit
92bb0803eb
2 changed files with 77 additions and 16 deletions
|
@ -21,35 +21,90 @@
|
||||||
#
|
#
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
import os
|
import re
|
||||||
import sys
|
import socket
|
||||||
import time
|
import http.server
|
||||||
import tempfile
|
|
||||||
from http.server import BaseHTTPRequestHandler, HTTPServer
|
from http.server import BaseHTTPRequestHandler, HTTPServer
|
||||||
|
|
||||||
|
import multiprocessing
|
||||||
|
|
||||||
import cdist
|
import cdist
|
||||||
from cdist import core
|
|
||||||
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
class Trigger():
|
class Trigger():
|
||||||
"""cdist trigger handling"""
|
"""cdist trigger handling"""
|
||||||
|
|
||||||
def __init__(self, dry_run=False):
|
def __init__(self, http_port=None, dry_run=False, ipv4only=False):
|
||||||
self.log = logging.getLogger("trigger")
|
self.log = logging.getLogger("trigger")
|
||||||
self.dry_run = dry_run
|
self.dry_run = dry_run
|
||||||
|
self.http_port = int(http_port)
|
||||||
|
self.ipv4only = ipv4only
|
||||||
|
|
||||||
|
# can only be set once
|
||||||
|
multiprocessing.set_start_method('forkserver')
|
||||||
|
|
||||||
|
def run_httpd(self):
|
||||||
|
server_address = ('', self.http_port)
|
||||||
|
|
||||||
|
if self.ipv4only:
|
||||||
|
httpd = HTTPServerV4(server_address, TriggerHttp)
|
||||||
|
else:
|
||||||
|
httpd = HTTPServerV6(server_address, TriggerHttp)
|
||||||
|
|
||||||
def run_http(self):
|
|
||||||
server_address = ('0.0.0.0', 8000)
|
|
||||||
httpd = HTTPServer(server_address, testHTTPServer_RequestHandler)
|
|
||||||
print('running server...')
|
|
||||||
httpd.serve_forever()
|
httpd.serve_forever()
|
||||||
|
|
||||||
|
def run(self):
|
||||||
|
if self.http_port:
|
||||||
|
self.run_httpd()
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def commandline(args):
|
def commandline(args):
|
||||||
print("all good")
|
t = Trigger(http_port=args.http_port, ipv4only=args.ipv4)
|
||||||
pass
|
t.run()
|
||||||
|
|
||||||
|
|
||||||
class TriggerHttp(BaseHTTPRequestHandler):
|
class TriggerHttp(BaseHTTPRequestHandler):
|
||||||
|
def __init__(self, *args, **kwargs):
|
||||||
|
http.server.BaseHTTPRequestHandler.__init__(self, *args, **kwargs)
|
||||||
|
|
||||||
def do_GET(self):
|
def do_GET(self):
|
||||||
pass
|
# FIXME: dispatch to pool instead of single process
|
||||||
|
host = self.client_address[0]
|
||||||
|
code = 200
|
||||||
|
mode = None
|
||||||
|
|
||||||
|
m = re.match("^/(?P<mode>config|install)/.*", self.path)
|
||||||
|
if m:
|
||||||
|
mode = m.group('mode')
|
||||||
|
else:
|
||||||
|
code = 404
|
||||||
|
|
||||||
|
if mode:
|
||||||
|
self.run_cdist(mode, host)
|
||||||
|
|
||||||
|
self.send_response(code)
|
||||||
|
self.end_headers()
|
||||||
|
|
||||||
|
def do_HEAD(self):
|
||||||
|
self.do_GET()
|
||||||
|
|
||||||
|
def do_POST(self):
|
||||||
|
self.do_GET()
|
||||||
|
|
||||||
|
def run_cdist(self, mode, host):
|
||||||
|
log.debug("Running cdist {} {}".format(mode, host))
|
||||||
|
|
||||||
|
|
||||||
|
class HTTPServerV4(http.server.HTTPServer):
|
||||||
|
"""
|
||||||
|
Server that listens to IPv4 and IPv6 requests
|
||||||
|
"""
|
||||||
|
address_family = socket.AF_INET
|
||||||
|
|
||||||
|
|
||||||
|
class HTTPServerV6(http.server.HTTPServer):
|
||||||
|
"""
|
||||||
|
Server that listens both to IPv4 and IPv6 requests
|
||||||
|
"""
|
||||||
|
address_family = socket.AF_INET6
|
||||||
|
|
|
@ -175,12 +175,18 @@ def commandline():
|
||||||
' should be POSIX compatible shell.'))
|
' should be POSIX compatible shell.'))
|
||||||
parser['shell'].set_defaults(func=cdist.shell.Shell.commandline)
|
parser['shell'].set_defaults(func=cdist.shell.Shell.commandline)
|
||||||
|
|
||||||
|
# Trigger
|
||||||
parser['trigger'] = parser['sub'].add_parser(
|
parser['trigger'] = parser['sub'].add_parser(
|
||||||
'trigger', parents=[parser['loglevel'], parser['beta']])
|
'trigger', parents=[parser['loglevel'], parser['beta']])
|
||||||
|
parser['trigger'].add_argument(
|
||||||
|
'-4', '--ipv4',
|
||||||
|
help=('Listen only to IPv4 (instead of IPv4 and IPv4)'), action='store_true')
|
||||||
parser['trigger'].add_argument(
|
parser['trigger'].add_argument(
|
||||||
'-H', '--http-port',
|
'-H', '--http-port',
|
||||||
help=('Create trigger listener via http on specified port'),
|
help=('Create trigger listener via http on specified port'))
|
||||||
action='append')
|
parser['trigger'].add_argument(
|
||||||
|
'-n', '--dry-run',
|
||||||
|
help='Do not execute code', action='store_true')
|
||||||
parser['trigger'].set_defaults(func=cdist.trigger.Trigger.commandline)
|
parser['trigger'].set_defaults(func=cdist.trigger.Trigger.commandline)
|
||||||
|
|
||||||
# Install
|
# Install
|
||||||
|
|
Loading…
Reference in a new issue