Page MenuHomeDevCentral

D3571.diff
No OneTemporary

D3571.diff

diff --git a/_resources/templates/service/rc/files/rc/__service__.conf b/_resources/templates/service/rc/files/rc/__service__.conf
new file mode 100644
--- /dev/null
+++ b/_resources/templates/service/rc/files/rc/__service__.conf
@@ -0,0 +1,16 @@
+# -------------------------------------------------------------
+# %%service%% — rc configuration
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+# Project: Nasqueron
+# License: Trivial work, not eligible to copyright
+# Source file: %%path%%
+# -------------------------------------------------------------
+#
+# <auto-generated>
+# This file is managed by our rOPS SaltStack repository.
+#
+# Changes to this file may cause incorrect behavior
+# and will be lost if the state is redeployed.
+# </auto-generated>
+
+%%service%%_enable="YES"
diff --git a/_resources/templates/service/rc/service.sls b/_resources/templates/service/rc/service.sls
new file mode 100644
--- /dev/null
+++ b/_resources/templates/service/rc/service.sls
@@ -0,0 +1,24 @@
+# -------------------------------------------------------------
+# Salt — Provision %%service%%
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+# Project: Nasqueron
+# License: Trivial work, not eligible to copyright
+# -------------------------------------------------------------
+
+{% from "map.jinja" import services with context %}
+
+# -------------------------------------------------------------
+# %%service%% service
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+
+{% if services.manager == "rc" %}
+
+/etc/rc.conf.d/%%service%%:
+ file.managed:
+ - source: salt://%%cwd%%/files/rc/%%service%%.conf
+
+%%service%%_running:
+ service.running:
+ - name: %%service%%
+
+{% endif %}
diff --git a/_resources/templates/templates.yml b/_resources/templates/templates.yml
new file mode 100644
--- /dev/null
+++ b/_resources/templates/templates.yml
@@ -0,0 +1,11 @@
+# -------------------------------------------------------------
+# Templates to build repository files
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+
+templates:
+ service/rc:
+ variables:
+ - service
+
+aliases:
+ service: service/rc
diff --git a/utils/templates/create.py b/utils/templates/create.py
new file mode 100755
--- /dev/null
+++ b/utils/templates/create.py
@@ -0,0 +1,142 @@
+#!/usr/bin/env python3
+
+# -------------------------------------------------------------
+# Create from template
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+# Project: Nasqueron
+# Description: Creates file from template
+# License: BSD-2-Clause
+# -------------------------------------------------------------
+
+
+import os
+import subprocess
+import sys
+
+import yaml
+
+
+ROOT_TEMPLATE_DIR = "_resources/templates"
+
+
+# -------------------------------------------------------------
+# Configuration and directories helpers
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+
+
+def run_command(command):
+ process = subprocess.run(command, capture_output=True, text=True)
+ return process.stdout.strip()
+
+
+def get_root_dir():
+ return run_command(["git", "rev-parse", "--show-toplevel"])
+
+
+def get_root_template_dir():
+ return os.path.join(get_root_dir(), ROOT_TEMPLATE_DIR)
+
+
+def load_config():
+ with open(get_root_template_dir() + "/templates.yml") as fd:
+ return yaml.safe_load(fd)
+
+
+# -------------------------------------------------------------
+# Template
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+
+
+class OpsTemplate:
+ def __init__(self, template_dir, target_dir, template_config, values):
+ self.template_dir = template_dir
+ self.target_dir = target_dir
+ self.root_dir = get_root_dir()
+ self.variables = dict(zip(template_config["variables"], values))
+
+ def get_relative_path(self, filename):
+ return os.path.relpath(filename, self.root_dir)
+
+ def write_file(self, source, target):
+ with open(source, "r") as source_fd, open(target, "w") as target_fd:
+ for line in source_fd:
+ for key, value in self.variables.items():
+ line = line.replace(f"%%{key}%%", value)
+ line = line.replace("%%cwd%%", self.get_relative_path(self.target_dir))
+ line = line.replace("%%path%%", self.get_relative_path(target))
+
+ target_fd.write(line)
+
+ def resolve_target_name(self, target_path):
+ for key, value in self.variables.items():
+ target_path = target_path.replace(f"__{key}__", value)
+
+ return target_path
+
+ def apply(self):
+ if not os.path.exists(self.target_dir):
+ os.makedirs(self.target_dir)
+
+ for root, dirs, files in os.walk(self.template_dir):
+ relative_path = os.path.relpath(root, self.template_dir)
+ if relative_path == ".":
+ target_dir = self.target_dir
+ else:
+ target_dir = os.path.join(self.target_dir, relative_path)
+ os.makedirs(target_dir, exist_ok=True)
+
+ for file in files:
+ source_file = os.path.join(root, file)
+ target_file = os.path.join(target_dir, file)
+ target_file = self.resolve_target_name(target_file)
+
+ self.write_file(source_file, target_file)
+
+
+# -------------------------------------------------------------
+# Application entry point
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+
+
+def run(template_name):
+ config = load_config()
+
+ if template_name in config["aliases"]:
+ template_name = config["aliases"][template_name]
+
+ if template_name not in config["templates"]:
+ print(
+ f"Unknown template: {template_name}, check templates.yml", file=sys.stderr
+ )
+ sys.exit(2)
+
+ template_config = config["templates"][template_name]
+ args = sys.argv[2:]
+
+ expected_args_count = len(template_config["variables"])
+ if expected_args_count > len(args):
+ print("Expected template arguments missing.", file=sys.stderr)
+
+ expected_args = [f"<{arg}>" for arg in template_config["variables"]]
+ expected_args = " ".join(expected_args)
+ print(f"Usage: {sys.argv[0]} {sys.argv[1]} {expected_args}", file=sys.stderr)
+
+ sys.exit(4)
+
+ template = OpsTemplate(
+ os.path.join(get_root_template_dir(), template_name),
+ os.getcwd(),
+ template_config,
+ args,
+ )
+ template.apply()
+
+
+if __name__ == "__main__":
+ argc = len(sys.argv)
+
+ if argc < 2:
+ print(f"Usage: {sys.argv[0]} <template name>", file=sys.stderr)
+ sys.exit(1)
+
+ run(sys.argv[1])

File Metadata

Mime Type
text/plain
Expires
Sat, Oct 25, 16:32 (10 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
3103683
Default Alt Text
D3571.diff (6 KB)

Event Timeline