2019-12-02 10:32:03 +07:00
|
|
|
import sys
|
2020-06-19 08:47:51 +07:00
|
|
|
import traceback
|
2019-12-02 10:32:03 +07:00
|
|
|
import pytimeparse
|
|
|
|
from ast import literal_eval
|
2020-01-29 22:18:15 +07:00
|
|
|
from flask import current_app
|
2019-12-02 10:32:03 +07:00
|
|
|
from .base import db
|
2023-04-14 07:12:02 -04:00
|
|
|
from powerdnsadmin.lib.settings import AppSettings
|
2019-12-02 10:32:03 +07:00
|
|
|
|
|
|
|
|
|
|
|
class Setting(db.Model):
|
|
|
|
id = db.Column(db.Integer, primary_key=True)
|
2021-12-11 15:49:05 +01:00
|
|
|
name = db.Column(db.String(64), unique=True, index=True)
|
2019-12-02 10:32:03 +07:00
|
|
|
value = db.Column(db.Text())
|
2023-04-10 07:39:21 -04:00
|
|
|
|
2023-04-14 07:12:02 -04:00
|
|
|
ZONE_TYPE_FORWARD = 'forward'
|
|
|
|
ZONE_TYPE_REVERSE = 'reverse'
|
2023-04-10 07:39:21 -04:00
|
|
|
|
2019-12-02 10:32:03 +07:00
|
|
|
def __init__(self, id=None, name=None, value=None):
|
|
|
|
self.id = id
|
|
|
|
self.name = name
|
|
|
|
self.value = value
|
|
|
|
|
|
|
|
# allow database autoincrement to do its own ID assignments
|
|
|
|
def __init__(self, name=None, value=None):
|
|
|
|
self.id = None
|
|
|
|
self.name = name
|
|
|
|
self.value = value
|
|
|
|
|
|
|
|
def set_maintenance(self, mode):
|
|
|
|
maintenance = Setting.query.filter(
|
|
|
|
Setting.name == 'maintenance').first()
|
|
|
|
|
|
|
|
if maintenance is None:
|
2023-04-14 07:12:02 -04:00
|
|
|
value = AppSettings.defaults['maintenance']
|
2019-12-02 10:32:03 +07:00
|
|
|
maintenance = Setting(name='maintenance', value=str(value))
|
|
|
|
db.session.add(maintenance)
|
|
|
|
|
|
|
|
mode = str(mode)
|
|
|
|
|
|
|
|
try:
|
|
|
|
if maintenance.value != mode:
|
|
|
|
maintenance.value = mode
|
|
|
|
db.session.commit()
|
|
|
|
return True
|
|
|
|
except Exception as e:
|
2020-01-29 22:18:15 +07:00
|
|
|
current_app.logger.error('Cannot set maintenance to {0}. DETAIL: {1}'.format(
|
2019-12-02 10:32:03 +07:00
|
|
|
mode, e))
|
2020-01-29 22:18:15 +07:00
|
|
|
current_app.logger.debug(traceback.format_exec())
|
2019-12-02 10:32:03 +07:00
|
|
|
db.session.rollback()
|
|
|
|
return False
|
|
|
|
|
|
|
|
def toggle(self, setting):
|
|
|
|
current_setting = Setting.query.filter(Setting.name == setting).first()
|
|
|
|
|
|
|
|
if current_setting is None:
|
2023-04-14 07:12:02 -04:00
|
|
|
value = AppSettings.defaults[setting]
|
2019-12-02 10:32:03 +07:00
|
|
|
current_setting = Setting(name=setting, value=str(value))
|
|
|
|
db.session.add(current_setting)
|
|
|
|
|
|
|
|
try:
|
|
|
|
if current_setting.value == "True":
|
|
|
|
current_setting.value = "False"
|
|
|
|
else:
|
|
|
|
current_setting.value = "True"
|
|
|
|
db.session.commit()
|
|
|
|
return True
|
|
|
|
except Exception as e:
|
2020-01-29 22:18:15 +07:00
|
|
|
current_app.logger.error('Cannot toggle setting {0}. DETAIL: {1}'.format(
|
2019-12-02 10:32:03 +07:00
|
|
|
setting, e))
|
2020-01-29 22:18:15 +07:00
|
|
|
current_app.logger.debug(traceback.format_exec())
|
2019-12-02 10:32:03 +07:00
|
|
|
db.session.rollback()
|
|
|
|
return False
|
|
|
|
|
|
|
|
def set(self, setting, value):
|
2023-04-14 18:52:27 -04:00
|
|
|
import json
|
2019-12-02 10:32:03 +07:00
|
|
|
current_setting = Setting.query.filter(Setting.name == setting).first()
|
|
|
|
|
|
|
|
if current_setting is None:
|
|
|
|
current_setting = Setting(name=setting, value=None)
|
|
|
|
db.session.add(current_setting)
|
|
|
|
|
2023-04-14 18:52:27 -04:00
|
|
|
value = AppSettings.convert_type(setting, value)
|
|
|
|
|
|
|
|
if isinstance(value, dict) or isinstance(value, list):
|
|
|
|
value = json.dumps(value)
|
2019-12-02 10:32:03 +07:00
|
|
|
|
|
|
|
try:
|
|
|
|
current_setting.value = value
|
|
|
|
db.session.commit()
|
|
|
|
return True
|
|
|
|
except Exception as e:
|
2023-04-14 07:12:02 -04:00
|
|
|
current_app.logger.error('Cannot edit setting {0}. DETAIL: {1}'.format(setting, e))
|
2020-01-29 22:18:15 +07:00
|
|
|
current_app.logger.debug(traceback.format_exec())
|
2019-12-02 10:32:03 +07:00
|
|
|
db.session.rollback()
|
|
|
|
return False
|
|
|
|
|
|
|
|
def get(self, setting):
|
2023-04-14 07:12:02 -04:00
|
|
|
if setting in AppSettings.defaults:
|
2021-12-01 14:35:05 +01:00
|
|
|
|
2021-11-05 18:22:38 +02:00
|
|
|
if setting.upper() in current_app.config:
|
|
|
|
result = current_app.config[setting.upper()]
|
|
|
|
else:
|
|
|
|
result = self.query.filter(Setting.name == setting).first()
|
2021-12-01 14:35:05 +01:00
|
|
|
|
2019-12-02 10:32:03 +07:00
|
|
|
if result is not None:
|
2023-03-11 14:46:58 -05:00
|
|
|
if hasattr(result, 'value'):
|
2021-12-01 14:35:05 +01:00
|
|
|
result = result.value
|
2023-04-11 18:50:47 -04:00
|
|
|
|
2023-04-14 07:12:02 -04:00
|
|
|
return AppSettings.convert_type(setting, result)
|
2019-12-02 10:32:03 +07:00
|
|
|
else:
|
2023-04-14 07:12:02 -04:00
|
|
|
return AppSettings.defaults[setting]
|
2019-12-02 10:32:03 +07:00
|
|
|
else:
|
2020-01-29 22:18:15 +07:00
|
|
|
current_app.logger.error('Unknown setting queried: {0}'.format(setting))
|
2021-12-01 14:35:05 +01:00
|
|
|
|
2023-04-10 07:39:21 -04:00
|
|
|
def get_group(self, group):
|
2023-04-11 18:50:47 -04:00
|
|
|
if not isinstance(group, list):
|
2023-04-14 07:12:02 -04:00
|
|
|
group = AppSettings.groups[group]
|
2023-04-10 07:39:21 -04:00
|
|
|
|
|
|
|
result = {}
|
|
|
|
|
2023-04-14 07:12:02 -04:00
|
|
|
for var_name, default_value in AppSettings.defaults.items():
|
|
|
|
if var_name in group:
|
|
|
|
result[var_name] = self.get(var_name)
|
2023-04-10 07:39:21 -04:00
|
|
|
|
|
|
|
return result
|
|
|
|
|
2019-12-02 10:32:03 +07:00
|
|
|
def get_records_allow_to_edit(self):
|
|
|
|
return list(
|
2023-04-14 07:12:02 -04:00
|
|
|
set(self.get_supported_record_types(self.ZONE_TYPE_FORWARD) +
|
|
|
|
self.get_supported_record_types(self.ZONE_TYPE_REVERSE)))
|
2019-12-02 10:32:03 +07:00
|
|
|
|
2023-04-14 07:12:02 -04:00
|
|
|
def get_supported_record_types(self, zone_type):
|
|
|
|
setting_value = []
|
|
|
|
|
|
|
|
if zone_type == self.ZONE_TYPE_FORWARD:
|
|
|
|
setting_value = self.get('forward_records_allow_edit')
|
|
|
|
elif zone_type == self.ZONE_TYPE_REVERSE:
|
|
|
|
setting_value = self.get('reverse_records_allow_edit')
|
|
|
|
|
|
|
|
records = literal_eval(setting_value) if isinstance(setting_value, str) else setting_value
|
|
|
|
types = [r for r in records if records[r]]
|
2019-12-02 10:32:03 +07:00
|
|
|
|
|
|
|
# Sort alphabetically if python version is smaller than 3.6
|
2023-04-14 07:12:02 -04:00
|
|
|
if sys.version_info[0] < 3 or (sys.version_info[0] == 3 and sys.version_info[1] < 6):
|
|
|
|
types.sort()
|
|
|
|
|
|
|
|
return types
|
2019-12-02 10:32:03 +07:00
|
|
|
|
|
|
|
def get_ttl_options(self):
|
|
|
|
return [(pytimeparse.parse(ttl), ttl)
|
|
|
|
for ttl in self.get('ttl_options').split(',')]
|