summaryrefslogtreecommitdiffstats
path: root/web/gui/bundle_dashboard.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2021-05-19 12:33:27 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2021-05-19 12:33:27 +0000
commit841395dd16f470e3c051a0a4fff5b91efc983c30 (patch)
tree4115f6eedcddda75067130b80acaff9e51612f49 /web/gui/bundle_dashboard.py
parentAdding upstream version 1.30.1. (diff)
downloadnetdata-841395dd16f470e3c051a0a4fff5b91efc983c30.tar.xz
netdata-841395dd16f470e3c051a0a4fff5b91efc983c30.zip
Adding upstream version 1.31.0.upstream/1.31.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'web/gui/bundle_dashboard.py')
-rwxr-xr-xweb/gui/bundle_dashboard.py105
1 files changed, 105 insertions, 0 deletions
diff --git a/web/gui/bundle_dashboard.py b/web/gui/bundle_dashboard.py
new file mode 100755
index 00000000..4cde01af
--- /dev/null
+++ b/web/gui/bundle_dashboard.py
@@ -0,0 +1,105 @@
+#!/usr/bin/env python3
+#
+# Copyright: © 2021 Netdata Inc.
+# SPDX-License-Identifier: GPL-3.0-or-later
+'''Bundle the dashboard code into the agent repo.'''
+
+import os
+import shutil
+import subprocess
+import sys
+
+from pathlib import Path
+
+os.chdir(Path(__file__).parent.absolute())
+
+BASEPATH = Path('dashboard')
+
+URLTEMPLATE = 'https://github.com/netdata/dashboard/releases/download/{0}/dashboard.tar.gz'
+
+MAKEFILETEMPLATE = '''
+# Auto-generated by generate-dashboard-makefile.py
+# Copyright: © 2021 Netdata Inc.
+# SPDX-License-Identifier: GPL-3.0-or-later
+MAINTAINERCLEANFILES = $(srcdir)/Makefile.in
+
+dist_noinst_DATA = \\
+ README.md
+
+dist_web_DATA = \\
+ {0} \\
+ $(NULL)
+
+webcssdir=$(webdir)/css
+dist_webcss_DATA = \\
+ {1} \\
+ $(NULL)
+
+webfontsdir=$(webdir)/fonts
+dist_webfonts_DATA = \\
+ {2} \\
+ $(NULL)
+
+webimagesdir=$(webdir)/images
+dist_webimages_DATA = \\
+ {3} \\
+ $(NULL)
+
+weblibdir=$(webdir)/lib
+dist_weblib_DATA = \\
+ {4} \\
+ $(NULL)
+
+webstaticcssdir=$(webdir)/static/css
+dist_webstaticcss_DATA = \\
+ {5} \\
+ $(NULL)
+
+webstaticjsdir=$(webdir)/static/js
+dist_webstaticjs_DATA = \\
+ {6} \\
+ $(NULL)
+
+webstaticmediadir=$(webdir)/static/media
+dist_webstaticmedia_DATA = \\
+ {7} \\
+ $(NULL)
+'''
+
+
+def copy_dashboard(tag):
+ '''Fetch and bundle the dashboard code.'''
+ shutil.rmtree(BASEPATH)
+ BASEPATH.mkdir()
+ subprocess.check_call('curl -L -o dashboard.tar.gz ' + URLTEMPLATE.format(tag), shell=True)
+ subprocess.check_call('tar -xvzf dashboard.tar.gz -C ' + str(BASEPATH) + ' --strip-components=1', shell=True)
+ BASEPATH.joinpath('README.md').symlink_to('../.dashboard-notice.md')
+# BASEPATH.joinpath('..', 'dashboard.tar.gz').unlink()
+
+
+def genfilelist(path):
+ '''Generate a list of files for the Makefile.'''
+ files = [f for f in path.iterdir() if f.is_file() and f.name != 'README.md']
+ files = [Path(*f.parts[1:]) for f in files]
+ files.sort()
+ return ' \\\n '.join([str(f) for f in files])
+
+
+def write_makefile():
+ '''Write out the makefile for the dashboard code.'''
+ MAKEFILEDATA = MAKEFILETEMPLATE.format(
+ genfilelist(BASEPATH),
+ genfilelist(BASEPATH.joinpath('css')),
+ genfilelist(BASEPATH.joinpath('fonts')),
+ genfilelist(BASEPATH.joinpath('images')),
+ genfilelist(BASEPATH.joinpath('lib')),
+ genfilelist(BASEPATH.joinpath('static', 'css')),
+ genfilelist(BASEPATH.joinpath('static', 'js')),
+ genfilelist(BASEPATH.joinpath('static', 'media')),
+ )
+
+ BASEPATH.joinpath('Makefile.am').write_text(MAKEFILEDATA)
+
+
+copy_dashboard(sys.argv[1])
+write_makefile()