Page Menu
Home
DevCentral
Search
Configure Global Search
Log In
Files
F4030929
D3571.id.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
6 KB
Referenced Files
None
Subscribers
None
D3571.id.diff
View Options
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
Details
Attached
Mime Type
text/plain
Expires
Wed, Jan 22, 05:24 (3 h, 57 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
2367593
Default Alt Text
D3571.id.diff (6 KB)
Attached To
Mode
D3571: Allow to create rc service file
Attached
Detach File
Event Timeline
Log In to Comment