mirror of
https://github.com/KevinMidboe/mktxp-no-cli.git
synced 2025-10-29 17:50:23 +00:00
cli options
This commit is contained in:
@@ -15,6 +15,7 @@
|
|||||||
from http.server import HTTPServer
|
from http.server import HTTPServer
|
||||||
from prometheus_client.core import REGISTRY
|
from prometheus_client.core import REGISTRY
|
||||||
from prometheus_client import MetricsHandler, start_http_server
|
from prometheus_client import MetricsHandler, start_http_server
|
||||||
|
from mktxp.cli.config.config import config_handler
|
||||||
from mktxp.collectors_handler import CollectorsHandler
|
from mktxp.collectors_handler import CollectorsHandler
|
||||||
from mktxp.metrics_handler import RouterMetricsHandler
|
from mktxp.metrics_handler import RouterMetricsHandler
|
||||||
|
|
||||||
@@ -26,10 +27,12 @@ class MKTXPProcessor:
|
|||||||
def start():
|
def start():
|
||||||
router_metrics_handler = RouterMetricsHandler()
|
router_metrics_handler = RouterMetricsHandler()
|
||||||
REGISTRY.register(CollectorsHandler(router_metrics_handler))
|
REGISTRY.register(CollectorsHandler(router_metrics_handler))
|
||||||
MKTXPProcessor.run()
|
port=config_handler.mktxp_port()
|
||||||
|
MKTXPProcessor.run(port=port)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def run(server_class=HTTPServer, handler_class=MetricsHandler, port=8000):
|
def run(server_class=HTTPServer, handler_class=MetricsHandler, port = None):
|
||||||
server_address = ('', port)
|
server_address = ('', port)
|
||||||
httpd = server_class(server_address, handler_class)
|
httpd = server_class(server_address, handler_class)
|
||||||
|
print(f'Running HTTP collector server on port {port}')
|
||||||
httpd.serve_forever()
|
httpd.serve_forever()
|
||||||
|
|||||||
15
mktxp/cli/config/.mktxp.conf
Normal file
15
mktxp/cli/config/.mktxp.conf
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
## Copyright (c) 2020 Arseniy Kuznetsov
|
||||||
|
##
|
||||||
|
## This program is free software; you can redistribute it and/or
|
||||||
|
## modify it under the terms of the GNU General Public License
|
||||||
|
## as published by the Free Software Foundation; either version 2
|
||||||
|
## of the License, or (at your option) any later version.
|
||||||
|
##
|
||||||
|
## This program is distributed in the hope that it will be useful,
|
||||||
|
## but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
## GNU General Public License for more details.
|
||||||
|
|
||||||
|
|
||||||
|
[MKTXP]
|
||||||
|
port = 49090
|
||||||
@@ -44,7 +44,6 @@ class MKTXPConfigKeys:
|
|||||||
FE_WIRELESS_KEY = 'wireless'
|
FE_WIRELESS_KEY = 'wireless'
|
||||||
FE_CAPSMAN_KEY = 'capsman'
|
FE_CAPSMAN_KEY = 'capsman'
|
||||||
|
|
||||||
|
|
||||||
# UnRegistered entries placeholder
|
# UnRegistered entries placeholder
|
||||||
NO_ENTRIES_REGISTERED = 'NoEntriesRegistered'
|
NO_ENTRIES_REGISTERED = 'NoEntriesRegistered'
|
||||||
|
|
||||||
@@ -55,12 +54,16 @@ class MKTXPConfigKeys:
|
|||||||
# Default ports
|
# Default ports
|
||||||
DEFAULT_API_PORT = 8728
|
DEFAULT_API_PORT = 8728
|
||||||
DEFAULT_API_SSL_PORT = 8729
|
DEFAULT_API_SSL_PORT = 8729
|
||||||
|
DEFAULT_MKTXP_PORT = 49090
|
||||||
|
|
||||||
BOOLEAN_KEYS = [ENABLED_KEY, SSL_KEY, SSL_CERTIFICATE,
|
BOOLEAN_KEYS = [ENABLED_KEY, SSL_KEY, SSL_CERTIFICATE,
|
||||||
FE_DHCP_KEY, FE_DHCP_LEASE_KEY, FE_DHCP_POOL_KEY, FE_INTERFACE_KEY,
|
FE_DHCP_KEY, FE_DHCP_LEASE_KEY, FE_DHCP_POOL_KEY, FE_INTERFACE_KEY,
|
||||||
FE_MONITOR_KEY, FE_ROUTE_KEY, FE_WIRELESS_KEY, FE_CAPSMAN_KEY]
|
FE_MONITOR_KEY, FE_ROUTE_KEY, FE_WIRELESS_KEY, FE_CAPSMAN_KEY]
|
||||||
STR_KEYS = [HOST_KEY, USER_KEY, PASSWD_KEY]
|
STR_KEYS = [HOST_KEY, USER_KEY, PASSWD_KEY]
|
||||||
|
|
||||||
|
# MKTXP config entry nane
|
||||||
|
MKTXP_CONFIG_ENTRY_NAME = 'MKTXP'
|
||||||
|
|
||||||
|
|
||||||
class ConfigEntry:
|
class ConfigEntry:
|
||||||
MKTXPEntry = namedtuple('MKTXPEntry', [MKTXPConfigKeys.ENABLED_KEY, MKTXPConfigKeys.HOST_KEY, MKTXPConfigKeys.PORT_KEY,
|
MKTXPEntry = namedtuple('MKTXPEntry', [MKTXPConfigKeys.ENABLED_KEY, MKTXPConfigKeys.HOST_KEY, MKTXPConfigKeys.PORT_KEY,
|
||||||
@@ -121,17 +124,24 @@ class MKTXPConfigHandler:
|
|||||||
|
|
||||||
# if needed, stage the user config data
|
# if needed, stage the user config data
|
||||||
self.usr_conf_data_path = os.path.join(self.os_config.mktxp_user_dir_path, 'mktxp.conf')
|
self.usr_conf_data_path = os.path.join(self.os_config.mktxp_user_dir_path, 'mktxp.conf')
|
||||||
if not os.path.exists(self.usr_conf_data_path):
|
self.mktxp_conf_path = os.path.join(self.os_config.mktxp_user_dir_path, '.mktxp.conf')
|
||||||
# stage from the mktxp conf template
|
|
||||||
lookup_path = resource_filename(Requirement.parse("mktxp"), "mktxp/cli/config/mktxp.conf")
|
|
||||||
shutil.copy(lookup_path, self.usr_conf_data_path)
|
|
||||||
|
|
||||||
self.read_from_disk()
|
self._create_os_path(self.usr_conf_data_path, 'mktxp/cli/config/mktxp.conf')
|
||||||
|
self._create_os_path(self.mktxp_conf_path, 'mktxp/cli/config/.mktxp.conf')
|
||||||
|
|
||||||
def read_from_disk(self):
|
self._read_from_disk()
|
||||||
|
|
||||||
|
def _read_from_disk(self):
|
||||||
''' (Force-)Read conf data from disk
|
''' (Force-)Read conf data from disk
|
||||||
'''
|
'''
|
||||||
self.config = ConfigObj(self.usr_conf_data_path)
|
self.config = ConfigObj(self.usr_conf_data_path)
|
||||||
|
self.mktxp_config = ConfigObj(self.mktxp_conf_path)
|
||||||
|
|
||||||
|
def _create_os_path(self, os_path, resource_path):
|
||||||
|
if not os.path.exists(os_path):
|
||||||
|
# stage from the conf templates
|
||||||
|
lookup_path = resource_filename(Requirement.parse("mktxp"), resource_path)
|
||||||
|
shutil.copy(lookup_path, os_path)
|
||||||
|
|
||||||
|
|
||||||
# MKTXP entries
|
# MKTXP entries
|
||||||
@@ -179,6 +189,12 @@ class MKTXPConfigHandler:
|
|||||||
entry_reader = self._entry_reader(entry_name)
|
entry_reader = self._entry_reader(entry_name)
|
||||||
return ConfigEntry.MKTXPEntry(**entry_reader)
|
return ConfigEntry.MKTXPEntry(**entry_reader)
|
||||||
|
|
||||||
|
def mktxp_port(self):
|
||||||
|
if self.mktxp_config.get(MKTXPConfigKeys.MKTXP_CONFIG_ENTRY_NAME) and \
|
||||||
|
self.mktxp_config[MKTXPConfigKeys.MKTXP_CONFIG_ENTRY_NAME].get(MKTXPConfigKeys.PORT_KEY):
|
||||||
|
return self.mktxp_config[MKTXPConfigKeys.MKTXP_CONFIG_ENTRY_NAME].as_int(MKTXPConfigKeys.PORT_KEY)
|
||||||
|
return MKTXPConfigKeys.DEFAULT_MKTXP_PORT
|
||||||
|
|
||||||
# Helpers
|
# Helpers
|
||||||
def _entry_reader(self, entry_name):
|
def _entry_reader(self, entry_name):
|
||||||
entry = {}
|
entry = {}
|
||||||
@@ -206,3 +222,15 @@ class MKTXPConfigHandler:
|
|||||||
# Simplest possible Singleton impl
|
# Simplest possible Singleton impl
|
||||||
config_handler = MKTXPConfigHandler()
|
config_handler = MKTXPConfigHandler()
|
||||||
|
|
||||||
|
|
||||||
|
''' if not os.path.exists(self.usr_conf_data_path):
|
||||||
|
# stage from the mktxp conf template
|
||||||
|
lookup_path = resource_filename(Requirement.parse("mktxp"), "mktxp/cli/config/mktxp.conf")
|
||||||
|
shutil.copy(lookup_path, self.usr_conf_data_path)
|
||||||
|
|
||||||
|
if not os.path.exists(self.mktxp_conf_path):
|
||||||
|
# stage from the mktxp conf template
|
||||||
|
lookup_path = resource_filename(Requirement.parse("mktxp"), "mktxp/cli/config/.mktxp.conf")
|
||||||
|
shutil.copy(lookup_path, self.mktxp_conf_path)
|
||||||
|
|
||||||
|
'''
|
||||||
|
|||||||
Reference in New Issue
Block a user