mirror of
https://github.com/hyperknot/openfreemap.git
synced 2026-05-21 14:02:15 +00:00
assets work
This commit is contained in:
@@ -107,7 +107,8 @@ def upload_https_host_files(c):
|
||||
c.sudo(f'mkdir -p {HTTP_HOST_BIN}')
|
||||
|
||||
for file in [
|
||||
'downloader.py',
|
||||
'download_assets.py',
|
||||
'download_tiles.py',
|
||||
'mounter.py',
|
||||
'metadata_to_tilejson.py',
|
||||
]:
|
||||
@@ -129,8 +130,14 @@ def upload_https_host_files(c):
|
||||
create_parent_dir=True,
|
||||
)
|
||||
|
||||
put(c, SCRIPTS_DIR / 'http_host' / 'cron.d' / 'ofm_http_host', '/etc/cron.d/')
|
||||
|
||||
c.sudo('chown -R ofm:ofm /data/ofm/http_host')
|
||||
|
||||
c.sudo('rm -rf /data/ofm/http_host/logs')
|
||||
c.sudo('mkdir -p /data/ofm/http_host/logs')
|
||||
c.sudo('chown root:root /data/ofm/http_host/logs')
|
||||
|
||||
|
||||
def upload_certificates(c):
|
||||
for file in (CONFIG_DIR / 'certs').iterdir():
|
||||
|
||||
4
scripts/http_host/cron.d/ofm_http_host
Normal file
4
scripts/http_host/cron.d/ofm_http_host
Normal file
@@ -0,0 +1,4 @@
|
||||
PYTHON=/data/ofm/venv/bin/python
|
||||
|
||||
# every minute download_asset.py
|
||||
* * * * * root $PYTHON /data/ofm/http_host/bin/download_assets.py > /data/ofm/http_host/logs/download_assets.log 2>&1
|
||||
@@ -32,18 +32,49 @@ def cli(assets_dir):
|
||||
|
||||
|
||||
def download_fonts(assets_dir):
|
||||
"""
|
||||
Download and extract font assets if their file differ.
|
||||
Making updates atomic, with extract to temp + move instead of extracting in place.
|
||||
"""
|
||||
|
||||
fonts_dir = assets_dir / 'fonts'
|
||||
fonts_dir.mkdir(exist_ok=True, parents=True)
|
||||
|
||||
fonts_temp = assets_dir / 'fonts_temp'
|
||||
|
||||
for font in ['ml', 'omt', 'pm']:
|
||||
url = f'https://assets.openfreemap.com/fonts/{font}.tgz'
|
||||
local_file = fonts_dir / f'{font}.tgz'
|
||||
download_if_size_differs(url, local_file)
|
||||
if not download_if_size_differs(url, local_file):
|
||||
continue
|
||||
|
||||
shutil.rmtree(fonts_temp, ignore_errors=True)
|
||||
fonts_temp.mkdir()
|
||||
|
||||
subprocess.run(
|
||||
['tar', '-xzf', local_file, '-C', fonts_temp],
|
||||
check=True,
|
||||
)
|
||||
|
||||
target_dir = fonts_dir / font
|
||||
target_dir_renamed = fonts_dir / f'{font}.bak'
|
||||
temp_dir = fonts_temp / font
|
||||
|
||||
if target_dir.exists():
|
||||
target_dir.rename(target_dir_renamed)
|
||||
temp_dir.rename(target_dir)
|
||||
|
||||
shutil.rmtree(target_dir_renamed, ignore_errors=True)
|
||||
|
||||
shutil.rmtree(fonts_temp, ignore_errors=True)
|
||||
|
||||
|
||||
def download_if_size_differs(url: str, local_file: Path):
|
||||
if not local_file.exists() or local_file.stat().st_size != get_remote_file_size(url):
|
||||
download_file(url, local_file)
|
||||
return True
|
||||
|
||||
return False
|
||||
|
||||
|
||||
def get_remote_file_size(url: str):
|
||||
@@ -61,8 +92,10 @@ def download_file(url, local_file):
|
||||
'--split=8',
|
||||
'--max-connection-per-server=8',
|
||||
'--file-allocation=none',
|
||||
'-d',
|
||||
local_file.parent,
|
||||
'-o',
|
||||
local_file,
|
||||
local_file.name,
|
||||
url,
|
||||
],
|
||||
check=True,
|
||||
|
||||
Reference in New Issue
Block a user