mirror of
https://github.com/hyperknot/openfreemap.git
synced 2026-05-22 14:32:15 +00:00
work
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
|
import json
|
||||||
import subprocess
|
import subprocess
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
|
||||||
@@ -28,7 +29,7 @@ class Configuration:
|
|||||||
repo_root = Path(__file__).parent.parent.parent.parent
|
repo_root = Path(__file__).parent.parent.parent.parent
|
||||||
ofm_config_dir = repo_root / 'config'
|
ofm_config_dir = repo_root / 'config'
|
||||||
|
|
||||||
jsonc_config = json5.loads((ofm_config_dir / 'config.jsonc').read_text())
|
json_config = json.loads((ofm_config_dir / 'config.json').read_text())
|
||||||
|
|
||||||
deployed_versions_dir = ofm_config_dir / 'deployed_versions'
|
deployed_versions_dir = ofm_config_dir / 'deployed_versions'
|
||||||
|
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ def write_nginx_config():
|
|||||||
for file in config.nginx_certs_dir.glob('ofm-*'):
|
for file in config.nginx_certs_dir.glob('ofm-*'):
|
||||||
file.unlink()
|
file.unlink()
|
||||||
|
|
||||||
conf = config.jsonc_config
|
conf = config.json_config
|
||||||
|
|
||||||
curl_help_lines = []
|
curl_help_lines = []
|
||||||
|
|
||||||
@@ -40,12 +40,9 @@ def write_nginx_config():
|
|||||||
|
|
||||||
|
|
||||||
def process_domain(domain_data):
|
def process_domain(domain_data):
|
||||||
domain_slug = slugify(domain_data['domain'], separator='_')
|
|
||||||
domain_data['slug'] = domain_slug
|
|
||||||
|
|
||||||
if domain_data['cert'] == 'upload':
|
if domain_data['cert'] == 'upload':
|
||||||
domain_data['cert_file'] = config.nginx_certs_dir / f'{domain_slug}.cert'
|
domain_data['cert_file'] = config.nginx_certs_dir / f'{domain_data["slug"]}.cert'
|
||||||
domain_data['key_file'] = config.nginx_certs_dir / f'{domain_slug}.key'
|
domain_data['key_file'] = config.nginx_certs_dir / f'{domain_data["slug"]}.key'
|
||||||
|
|
||||||
if not domain_data['cert_file'].is_file() or not domain_data['key_file'].is_file():
|
if not domain_data['cert_file'].is_file() or not domain_data['key_file'].is_file():
|
||||||
sys.exit(
|
sys.exit(
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ requirements = [
|
|||||||
'click',
|
'click',
|
||||||
'pycurl',
|
'pycurl',
|
||||||
'requests',
|
'requests',
|
||||||
'json5',
|
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
2
setup.py
2
setup.py
@@ -5,7 +5,7 @@ requirements = [
|
|||||||
'click',
|
'click',
|
||||||
'fabric',
|
'fabric',
|
||||||
'nginxfmt',
|
'nginxfmt',
|
||||||
'python-dotenv',
|
# 'python-dotenv',
|
||||||
'ruff',
|
'ruff',
|
||||||
'marko',
|
'marko',
|
||||||
'requests',
|
'requests',
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ from pathlib import Path
|
|||||||
|
|
||||||
|
|
||||||
class Configuration:
|
class Configuration:
|
||||||
# Local paths relative to this file
|
# local paths relative to this file
|
||||||
local_assets_dir = Path(__file__).parent / 'assets'
|
local_assets_dir = Path(__file__).parent / 'assets'
|
||||||
local_config_dir = Path(__file__).parent.parent / 'config'
|
local_config_dir = Path(__file__).parent.parent / 'config'
|
||||||
local_modules_dir = Path(__file__).parent.parent / 'modules'
|
local_modules_dir = Path(__file__).parent.parent / 'modules'
|
||||||
@@ -14,7 +14,9 @@ class Configuration:
|
|||||||
else:
|
else:
|
||||||
local_config_jsonc = local_config_dir / f'config.{ENV}.jsonc'
|
local_config_jsonc = local_config_dir / f'config.{ENV}.jsonc'
|
||||||
|
|
||||||
# remote paths (always Linux /, not using pathlib)
|
config_schema_json = local_config_dir / 'config.schema.json'
|
||||||
|
|
||||||
|
# remote paths (always forward / on Linux - not using pathlib)
|
||||||
ofm_dir = '/data/ofm'
|
ofm_dir = '/data/ofm'
|
||||||
remote_config = f'{ofm_dir}/config'
|
remote_config = f'{ofm_dir}/config'
|
||||||
venv_bin = f'{ofm_dir}/venv/bin'
|
venv_bin = f'{ofm_dir}/venv/bin'
|
||||||
|
|||||||
@@ -1,17 +1,20 @@
|
|||||||
import json
|
import json
|
||||||
|
|
||||||
|
import json5
|
||||||
|
|
||||||
from ssh_lib.benchmark import c1000k, wrk
|
from ssh_lib.benchmark import c1000k, wrk
|
||||||
from ssh_lib.config import config
|
from ssh_lib.config import config
|
||||||
from ssh_lib.kernel import kernel_limits1m, kernel_somaxconn65k
|
from ssh_lib.kernel import kernel_limits1m, kernel_somaxconn65k
|
||||||
from ssh_lib.nginx import certbot, nginx
|
from ssh_lib.nginx import certbot, nginx
|
||||||
from ssh_lib.utils import put, put_dir, sudo_cmd
|
from ssh_lib.slugify import slugify
|
||||||
|
from ssh_lib.utils import put, put_dir, put_str, sudo_cmd
|
||||||
|
|
||||||
|
|
||||||
def prepare_http_host(c):
|
def prepare_http_host(c):
|
||||||
kernel_somaxconn65k(c)
|
kernel_somaxconn65k(c)
|
||||||
kernel_limits1m(c)
|
kernel_limits1m(c)
|
||||||
|
|
||||||
upload_config_json(c)
|
upload_config_and_certs(c)
|
||||||
|
|
||||||
nginx(c)
|
nginx(c)
|
||||||
certbot(c)
|
certbot(c)
|
||||||
@@ -29,20 +32,40 @@ def prepare_http_host(c):
|
|||||||
c.sudo(f'{config.venv_bin}/pip install -e {config.http_host_bin} --use-pep517')
|
c.sudo(f'{config.venv_bin}/pip install -e {config.http_host_bin} --use-pep517')
|
||||||
|
|
||||||
|
|
||||||
def upload_config_json(c):
|
def upload_config_and_certs(c):
|
||||||
if not config.local_config_jsonc.is_file():
|
if not config.local_config_jsonc.is_file():
|
||||||
print(f'{config.local_config_jsonc} not found. Make sure it exists in the /config dir')
|
print(f'{config.local_config_jsonc} not found. Make sure it exists in the /config dir')
|
||||||
return
|
return
|
||||||
|
|
||||||
# validate using json5 + jsonschema
|
# validate using json5 + jsonschema
|
||||||
config_data = json.loads(config.local_config_jsonc.read_text())
|
# use config.config_schema_json
|
||||||
|
config_data = json5.loads(config.local_config_jsonc.read_text())
|
||||||
|
|
||||||
# if ok, upload the file
|
# pre-generate all the slugs
|
||||||
put(
|
for domain_data in config_data['domains']:
|
||||||
c,
|
domain_data['slug'] = slugify(domain_data['domain'], separator='_')
|
||||||
config.local_config_jsonc,
|
|
||||||
f'{config.remote_config}/config.jsonc',
|
if domain_data['cert']['type'] == 'upload':
|
||||||
)
|
local_cert_path = domain_data['cert']['cert_path']
|
||||||
|
cert_basename = local_cert_path.basename
|
||||||
|
local_key_path = local_cert_path.parent / f'{cert_basename}.key'
|
||||||
|
if not local_cert_path.is_file() or local_key_path.is_file():
|
||||||
|
print(
|
||||||
|
f'cert or key file for {domain_data["domain"]} is not found. Make sure these files exists: {local_cert_path} {local_key_path}'
|
||||||
|
)
|
||||||
|
|
||||||
|
remote_cert_path = f'/data/nginx/certs/ofm-{domain_data["slug"]}.cert'
|
||||||
|
remote_key_path = f'/data/nginx/certs/ofm-{domain_data["slug"]}.key'
|
||||||
|
|
||||||
|
# TODO fix permissions
|
||||||
|
put(c, local_cert_path, remote_cert_path)
|
||||||
|
put(c, local_key_path, remote_key_path)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# generate a normal JSON and upload it
|
||||||
|
config_str = json.dumps(config_data, indent=2, ensure_ascii=False)
|
||||||
|
put_str(c, f'{config.remote_config}/config.json', config_str)
|
||||||
|
|
||||||
|
|
||||||
def upload_http_host_files(c):
|
def upload_http_host_files(c):
|
||||||
@@ -52,7 +75,9 @@ def upload_http_host_files(c):
|
|||||||
put_dir(c, config.local_modules_dir / 'http_host', config.http_host_bin, file_permissions='755')
|
put_dir(c, config.local_modules_dir / 'http_host', config.http_host_bin, file_permissions='755')
|
||||||
|
|
||||||
for dirname in ['http_host_lib', 'scripts']:
|
for dirname in ['http_host_lib', 'scripts']:
|
||||||
put_dir(c, config.local_modules_dir / 'http_host' / dirname, f'{config.http_host_bin}/{dirname}')
|
put_dir(
|
||||||
|
c, config.local_modules_dir / 'http_host' / dirname, f'{config.http_host_bin}/{dirname}'
|
||||||
|
)
|
||||||
|
|
||||||
put_dir(
|
put_dir(
|
||||||
c,
|
c,
|
||||||
|
|||||||
Reference in New Issue
Block a user