From 837bde531ff6a19dbe8d7e9b13505f725db3e6e6 Mon Sep 17 00:00:00 2001 From: Benjamin Bohard Date: Mon, 14 Jun 2021 10:54:13 +0200 Subject: [PATCH] First commit --- Makefile | 26 ++++++ apps.mk | 90 ++++++++++++++++++++ dicos/50_smb.xml | 34 ++++++++ eole.mk | 187 +++++++++++++++++++++++++++++++++++++++++ tmpl/eole-smb_smb.conf | 14 +++ 5 files changed, 351 insertions(+) create mode 100644 Makefile create mode 100644 apps.mk create mode 100644 dicos/50_smb.xml create mode 100644 eole.mk create mode 100644 tmpl/eole-smb_smb.conf diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..e7d6d86 --- /dev/null +++ b/Makefile @@ -0,0 +1,26 @@ +################################ +# Makefile pour XXX-XXX +################################ + +SOURCE=XXX-XXX +VERSION=X.X +EOLE_VERSION=2.3|2.4 +PKGAPPS=non|web|flask +#FLASK_MODULE= + +################################ +# Début de zone à ne pas éditer +################################ + +include eole.mk +include apps.mk + +################################ +# Fin de zone à ne pas éditer +################################ + +# Makefile rules dedicated to application +# if exists +ifneq (, $(strip $(wildcard $(SOURCE).mk))) +include $(SOURCE).mk +endif diff --git a/apps.mk b/apps.mk new file mode 100644 index 0000000..918aa18 --- /dev/null +++ b/apps.mk @@ -0,0 +1,90 @@ +# +# NE PAS EDITER CE FICHIER +# +# Utiliser .mk à inclure à la fin de Makefile + +# Le variables suivantes sont a votre disposition : +# +# SRC_APPS : Répertoire des sources de l'application +# SRC_APPS_PLUGIN : Répertoires des plugins pour l'application +# SRC_APPS_LANG : Répértoires des traductions +# + +########################## +# Application web envole # +########################## +ifneq (, $(filter oui web, $(PKGAPPS))) +# Envole +sharenvole_PROG_DIR := $(DESTDIR)/usr/share/envole/$(SOURCE) + +SRC_APPS := src/$(SOURCE)-$(VERSION) +SRC_APPS_PLUGIN := src/plugins-$(VERSION) +SRC_APPS_LANG := src/lang-$(VERSION) + +APPS_DEST := $(DESTDIR)/var/www/html/$(SOURCE) +LANG_DEST := $(APPS_DEST)/lang +PLUGIN_DEST := $(APPS_DEST)/plugin + +# Sanity check +ifeq (, $(filter-out X.X, $(strip $(VERSION)))) +$(error $$(VERSION) variable has incorrect value '$(VERSION)') +endif + +ifeq (, $(strip $(wildcard $(SRC_APPS)))) +$(error $$(PKGAPPS) is enable but $$(SRC_APPS)='$(SRC_APPS)' does not exist) +endif + +endif + +########################## +# Application EOLE flask # +########################## +ifneq (, $(filter flask, $(PKGAPPS))) +# Sanity check +ifeq (, $(filter-out XXX, $(strip $(FLASK_MODULE)))) +$(error $$(FLASK_MODULE) variable has incorrect value '$(FLASK_MODULE)') +endif + +ifeq (, $(strip $(wildcard src/$(FLASK_MODULE).conf))) +$(error missing eoleflask configuration file 'src/$(FLASK_MODULE).conf') +endif + +# Static files +SRC_APPS := src/$(FLASK_MODULE)/static +APPS_MOUNT_POINT:= $(shell sed -ne 's|^"MOUNT_POINT"[[:space:]]*:[[:space:]]*"/\([^"]*\)",|\1|p' \ + src/$(FLASK_MODULE).conf) +APPS_DEST := $(DESTDIR)/usr/share/eole/flask/$(APPS_MOUNT_POINT)/static + +SRC_APPS_PLUGIN := nonexistent +SRC_APPS_LANG := nonexistent + +# eole-flask configuration +src_DATA_DIR := $(DESTDIR)/etc/eole/flask/available +endif + + +################ +# Common rules # +################ +ifneq (, $(filter oui web flask, $(PKGAPPS))) + +install-apps-dirs:: + test ! -d $(SRC_APPS) || $(INSTALL_DIRECTORY) $(APPS_DEST) + test ! -d $(SRC_APPS_LANG) || $(INSTALL_DIRECTORY) $(LANG_DEST) + test ! -d $(SRC_APPS_PLUGIN) || $(INSTALL_DIRECTORY) $(PLUGIN_DEST) + +install-apps:: install-apps-dirs + # Installation de l'application + $(call fc_install_file,$(INSTALL_RECURSIVE),$(SRC_APPS),$(APPS_DEST)) + + # Installation des répertoires de plugins + $(call fc_install_file,$(INSTALL_RECURSIVE),$(SRC_APPS_PLUGIN),$(PLUGIN_DEST)) + + # Installation des répertoires de traductions (lang) + $(call fc_install_file,$(INSTALL_RECURSIVE),$(SRC_APPS_LANG),$(LANG_DEST)) + +## Add install-apps +install:: install-apps +endif + +.PHONY: install-apps install-apps-dirs diff --git a/dicos/50_smb.xml b/dicos/50_smb.xml new file mode 100644 index 0000000..a0f18f4 --- /dev/null +++ b/dicos/50_smb.xml @@ -0,0 +1,34 @@ + + + + + + + + eole-smb-pkg + smbd + + + + + + non + + + + + + + + smb_share_path + + + non + smb_share_name + smb_share + + + + Afficher les variables permettant de configurer des partages SMB + + diff --git a/eole.mk b/eole.mk new file mode 100644 index 0000000..4f936ba --- /dev/null +++ b/eole.mk @@ -0,0 +1,187 @@ +# +# NE PAS EDITER CE FICHIER +# +# Utiliser .mk à inclure à la fin de Makefile + +################# +# Sanity checks # +################# + +ifeq (, $(DESTDIR)) +$(warning $$(DESTDIR) is empty, installation will be done in /) +endif + +ifeq (, $(filter-out XXX-XXX, $(strip $(SOURCE)))) +$(error $$(SOURCE) variable has incorrect value '$(SOURCE)') +endif + +######################### +# Variables definitions # +######################### + +INSTALL := install +INSTALL_DATA := install -m 644 +INSTALL_PROGRAM := install -m 755 +INSTALL_DIRECTORY := install -m 755 -d +INSTALL_RECURSIVE := cp -dr --no-preserve=ownership + +# Base +eole_DIR := $(DESTDIR)/usr/share/eole + +ifeq ($(strip $(EOLE_VERSION)), 2.3) +diagnose_PROG_DIR := $(eole_DIR)/diagnose/module +else +diagnose_PROG_DIR := $(eole_DIR)/diagnose/ +endif + +# Creole +creole_DIR := $(eole_DIR)/creole +dicos_DATA_DIR := $(creole_DIR)/dicos +tmpl_DATA_DIR := $(creole_DIR)/distrib +pretemplate_PROG_DIR := $(eole_DIR)/pretemplate +posttemplate_PROG_DIR := $(eole_DIR)/posttemplate +postservice_PROG_DIR := $(eole_DIR)/postservice +firewall_DATA_DIR := $(eole_DIR)/firewall +bacula_restore_DATA_DIR := $(eole_DIR)/bacula/restore +bacula_fichier_DATA_DIR := $(DESTDIR)/etc/bacula/baculafichiers.d +schedule_pre_PROG_DIR := $(eole_DIR)/schedule/pre +schedule_post_PROG_DIR := $(eole_DIR)/schedule/post +extra_REC_DIR := $(creole_DIR)/extra + +# Zéphir +zephir_DATA_DIR := $(DESTDIR)/usr/share/zephir +zephir_configs_DATA_DIR := $(zephir_DATA_DIR)/monitor/configs +zephir_srv_DATA_DIR := $(zephir_configs_DATA_DIR)/services + +# SSO +sso_DATA_DIR := $(DESTDIR)/usr/share/sso +sso_filtres_DATA_DIR := $(sso_DATA_DIR)/app_filters +sso_user-info_DATA_DIR := $(sso_DATA_DIR)/user_infos + +# EAD +ead_DATA_DIR := $(DESTDIR)/usr/share/ead2/backend/config +ead_actions_DATA_DIR := $(ead_DATA_DIR)/actions +ead_perms_DATA_DIR := $(ead_DATA_DIR)/perms +ead_roles_DATA_DIR := $(ead_DATA_DIR)/roles + +# Program libraries goes under /usr/lib// +lib_$(SOURCE)_DATA_DIR := $(DESTDIR)/usr/lib/$(SOURCE) + +# Scripts Eole +scripts_PROG_DIR := $(eole_DIR)/sbin +lib_eole_DATA_DIR := $(DESTDIR)/usr/lib/eole + +# LDAP +ldap_passwords_DATA_DIR := $(eole_DIR)/annuaire/password_files + +# LXC +lxc_DATA_DIR := $(eole_DIR)/lxc +lxc_fstab_DATA_DIR := $(lxc_DATA_DIR)/fstab +lxc_hosts_DATA_DIR := $(lxc_DATA_DIR)/hosts + +# SQL +sql_DATA_DIR := $(eole_DIR)/mysql/$(SOURCE) +sql_gen_DATA_DIR := $(sql_DATA_DIR)/gen +sql_updates_DATA_DIR := $(sql_DATA_DIR)/updates + +sql_conf_gen_DATA_DIR := $(eole_DIR)/applications/gen +sql_conf_passwords_DATA_DIR := $(eole_DIR)/applications/passwords +sql_conf_updates_DATA_DIR := $(eole_DIR)/applications/updates/$(SOURCE) + +# Certifs +certs_DATA_DIR := $(eole_DIR)/certs + +# Logrotate +logrotate_DATA_DIR := $(DESTDIR)/etc/logrotate.d + + +# Python modules +ifneq ($(DESTDIR),) +PYTHON_OPTS := --root $(DESTDIR) +endif + +############################################# +# Common directories and files installation # +############################################# + +all: + +install:: install-dirs install-files + +# $1 = command to run +# $2 = source directory +# $3 = destination directory +define fc_install_file + if [ -d $2 ]; then \ + for file in `ls -1 $2/`; do \ + $1 $2/$$file $3 || true; \ + done; \ + fi +endef + +## +## Directory creation +## + +# use % to catch local name in $* +# data, program and recursive directory require a corresponding +# directory in local sources +%_DATA_DIR %_PROG_DIR %REC_DIR: + test ! -d $(subst _,/,$*) || $(INSTALL_DIRECTORY) $($@) + +# Create the directory referenced by the variable without a local one. +%_DIR: + $(INSTALL_DIRECTORY) $($@) + +## +## Install files present directly under data, program and recursive directories +## + +# $* : name of variable +# $($*): value of variable +%-instdata: + $(call fc_install_file, $(INSTALL_DATA), $(subst _,/,$(subst _DATA_DIR,,$*)), $($*)) + +%-instprog: + $(call fc_install_file, $(INSTALL_PROGRAM), $(subst _,/,$(subst _PROG_DIR,,$*)), $($*)) + +%-instrec: + $(call fc_install_file, $(INSTALL_RECURSIVE), $(subst _,/,$(subst _REC_DIR,,$*)), $($*)) + + +# Use second expansion as variables may be created in included +# Makefiles +.SECONDEXPANSION: + +# List of all directories +installdirs_LIST = $(foreach V, $(filter %_DIR, $(.VARIABLES)), \ + $(if $(filter file, $(origin $(V))), \ + $(V))) +# List of data directories +installdata_LIST = $(filter %_DATA_DIR, $(installdirs_LIST)) +# List of program directories +installprog_LIST = $(filter %_PROG_DIR, $(installdirs_LIST)) +# List of recursive directories +installrec_LIST = $(filter %_REC_DIR, $(installdirs_LIST)) + +# Expand directories to create as dependency +# Use double-colon to permit user to define additionnal install-dirs +install-dirs:: $$(installdirs_LIST) + +# Expand files to install as dependency +# Use double-colon to permit user to define additionnal install-files +install-files:: install-data-files install-prog-files install-rec-dirs + +install-data-files: $$(patsubst %,%-instdata,$$(installdata_LIST)) + +install-prog-files: $$(patsubst %,%-instprog,$$(installprog_LIST)) + +install-rec-dirs: $$(patsubst %,%-instrec,$$(installrec_LIST)) + +# Installation of python modules +ifeq ($(shell test -f setup.py && echo 0), 0) +install-files:: + python setup.py install --no-compile --install-layout=deb $(PYTHON_OPTS) +endif + +.PHONY: install install-dirs install-files install-data-files install-prog-files install-rec-dirs diff --git a/tmpl/eole-smb_smb.conf b/tmpl/eole-smb_smb.conf new file mode 100644 index 0000000..6bd52f5 --- /dev/null +++ b/tmpl/eole-smb_smb.conf @@ -0,0 +1,14 @@ +[global] + map to guest = Bad User + log file = /var/log/samba/%m + log level = 1 +%for %%share in %%smb_share_name + +[%%share.smb_share_name] + # This share allows anonymous (guest) access + # without authentication! + path = %%share.smb_share_path + read only = no + guest ok = yes + guest only = yes +%endfor