Merge pull request #23 from 6543/develop

update feature branch
This commit is contained in:
6543 2018-05-20 23:51:20 +02:00 committed by GitHub
commit 226c2567d9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
13 changed files with 262 additions and 64 deletions

View File

@ -1,6 +1,6 @@
Package: remaster Package: remaster
Source: remaster Source: remaster
Version: 2.0.2 Version: 2.0.3
Architecture: all Architecture: all
Maintainer: 6543 <6543@obermui.de> Maintainer: 6543 <6543@obermui.de>
Installed-Size: <SIZE> Installed-Size: <SIZE>

View File

@ -12,6 +12,7 @@ The aim of this Project is to create a daemon for a server, witch update live sy
- wget - wget
- sed - sed
- sendemail - sendemail
- curl


## To Do ## To Do



View File

@ -18,3 +18,9 @@


2018-05-13 - 2.0.2 2018-05-13 - 2.0.2
* hotfix-2.0.2 ( create release folder if not exist ) * hotfix-2.0.2 ( create release folder if not exist )

2018-05-20 - 2.0.3
* make email, proxy optional
* change Strukture.md
* add config check
* some help scripts

View File

@ -1,28 +1,113 @@
# Src # 1. Starte "remaster"


raw scripts .. ## 1.1 Lade Grundfunctionen [-> #functions]


## functions ## 1.2 Überprüfe ...
* auf Updates
* auf Rechte


- creat iso ## 1.3 Lade Richtige Einstellungen [-> #config]
- burn cd ... * Lade /etc/remaster/<Conf>
- clean workspace ... * Überprüfe Conf. (Proj Exist; Mods Exist; ...)


## 1.4 Lade Proj-Func [-> #projects]
* Überlade nach Abhängigkeit
* (z.B. ubuntu.16.04 -> ubuntu -> debian)
* Prüfe Conf. (Proj Conform)


## distros ## 1.5 Lade $n Mods (optional) [-> #mods]
* Überprüfen
* Spechern in MOD_LST


scripts vor distros # 2. Init Chroot
- update
- set network settings
- set OS settings


## mods ## 2.1 Dateien Entpacken
- for example: install & enable xrdp * ISO
- set default passwd * Squashfs
- ...


## web ## 2.2 Config für Chroot (chroot_initial)
placeholder for webfiles ... * (lxc-conf / tmpdir)
* Netzwerk


## pxe ## 2.3 Starte Chroot
placeholder for pxefiles ... * (lxc-start / mount ...)

# 3. Modivikationen

## 3.1 Netzwerk

## 3.2 Proj-Spez.
* (z.B. Desinfect: conky_info)

## 3.3 Packet Mgr
* Updates
* Install
* Delete

## 3.4 Weitere in $MOD_LST
* z.B. xrdp
* z.B. default pw

# 4. Finish

## 4.1 Aufreumen Live-Sys
* tmpfiles
* Packet Mgr

## 4.2 Stop chroot
* Umount

## 4.3. Gen ISO/PXE

## 4.4. Del Chroot

# 5. Send Log

----

## lxc

-> chroot_sh exec lxc-attach

-> chroot_dir = container name

----

## PXE

-> Install
* DHCP Relay
* NFS-Server
* TFTP-Server
* [Samba]

-> Setup
* (use <Lib>/proj/<proj> func)
* SMB/NFS LiveSys export
* TFTP (Boot Menue; Boot Loader; Kernel&Initrd)

-> Deinstall
* RM TFTP-Root
* RM SMB/NFS LiveSys export
* del DHCP Relay conf

----

## Jobs
* Read Confs -> get time interfall I
* Exec remaster <Conf> for I

----

## Web

show/edit #Configs

show (+live) #Logs

start/stop/plan #Jobs

start/stop/edit #PXE menue
* default
* all / single / none
* live view new clients

View File

@ -2,10 +2,12 @@
#remaster lib #remaster lib
[ -d "<LIBDIR>" ] || { echo "LIBDIR not exist"; exit 1; } [ -d "<LIBDIR>" ] || { echo "LIBDIR not exist"; exit 1; }


#beginn func #<function> [param]

function <function>() {
#Code of <function>
}


#this func is standalone executable #this func is standalone executable
[ -n "$1" ] && { [ -n "$1" ] && {
check_user <function> $@
} }

12
script/add_function.sh Executable file
View File

@ -0,0 +1,12 @@
#!/bin/bash

#check param
[ -z "$1" ] && { echo "$0 [name]"; exit 1; }
name="$1"

#gen function
cp "doc/lib-head+tail" "src/func/$name"
sed -i "s/<function>/$name/g" "src/func/$name"

#open
editor "src/func/$name"

3
script/get_version.sh Executable file
View File

@ -0,0 +1,3 @@
#!/bin/bash

grep '@version ' src/remaster.sh | cut -d " " -f 2

View File

@ -8,10 +8,10 @@ date=`date +%Y-%m-%d`
version_sed=`echo $version | sed 's/\./\\./g'` version_sed=`echo $version | sed 's/\./\\./g'`


#nummer #nummer
sed -i "s/@version\ .\..\../@version\ $version_sed/g" src/remaster.sh sed -i "/#@version\ /c\#@version\ $version_sed" src/remaster.sh


#datum #datum
sed -i "s/@date\ ....-..-../@date\ $date/g" src/remaster.sh sed -i "/#@date\ /c\#@date\ $date" src/remaster.sh
} }


[ -e "changes/remaster.md" ] && { [ -e "changes/remaster.md" ] && {
@ -22,5 +22,5 @@ date=`date +%Y-%m-%d`
} }


[ -f "DEBIAN/control" ] && { [ -f "DEBIAN/control" ] && {
sed -i "s/Version:\ .\..\../Version:\ $version_sed/g" "DEBIAN/control" sed -i "/Version:\ /c\Version:\ $version_sed" "DEBIAN/control"
} }

55
src/func/check_config Executable file
View File

@ -0,0 +1,55 @@
#!/bin/bash
#remaster lib
[ -d "<LIBDIR>" ] || { echo "LIBDIR not exist"; exit 1; }

#check_config
function check_config() {

#Project
[ -f "<LIBDIR>/proj/$distro" ] || {
echo "No Project \"$distro\" is not supported"
return 3
}

#live-system files
if [ -f "$iso_source" ]; then
if [ -n "$iso_destination" ] && [ -d "${iso_destination%/*}" ]; then
#Lable
[ -z "$iso_lable" ] && iso_lable="$distro"

echo 'iso_source -> iso_destination'
echo 'iso_source -> squashfs [optinal]'
else
if [ -n "$filesystem_source" ] && [ -d "${filesystem_source%/*}" ]; then
echo 'iso_source -> squashfs'
else
# ERROR
echo "No corect AIM in Settings"
return 3
fi
fi
else
if [ -f "$filesystem_source" ]; then
if [ -n "$iso_destination" ]; then
# ERROR
echo "only Squashfs source in Settings, cant creat ISO"
return 3
else
echo 'squashfs -> squashfs'
fi
else
# ERROR
echo "No corect Source in Settings"
return 3
fi
fi




}

#this func is standalone executable
[ -n "$1" ] && {
check_config $@
}

View File

@ -5,9 +5,9 @@
#check_update #check_update
function check_update() { function check_update() {
if curl https://raw.githubusercontent.com/6543/remaster/master/changes/remaster.md | diff - <(zcat <ROOTDIR>/usr/share/doc/remaster/changelog.gz ); then if curl https://raw.githubusercontent.com/6543/remaster/master/changes/remaster.md | diff - <(zcat <ROOTDIR>/usr/share/doc/remaster/changelog.gz ); then
echo 'REMASTER: Aktuell' echo 'INFO: Programm Aktuell'
else else
echo 'REMASTER: Warning: neue Version verfügbar' echo 'WARNUNG: neue Version verfügbar'
fi fi
} }



View File

@ -4,28 +4,31 @@


#on_exit [error_level] #on_exit [error_level]
function on_exit() { function on_exit() {
#send log and errorlevel[success/errorr xy] ### send mail
[ -n "$log_mail_aim" ] && {
#send log and errorlevel[success/errorr xy]
if [ "$1" != "0" ]; then
log_mail_subject="$log_mail_subject [ERROR]"
else
log_mail_subject="$log_mail_subject [Success]"
fi


if [ "$1" != "0" ]; then #Mail Body:
log_mail_subject="$log_mail_subject [ERROR]" for mail_aim in `echo "$log_mail_aim" | tr "," " "`; do
else {
log_mail_subject="$log_mail_subject [Success]" echo "$log_mail_subject"
fi echo $'####################################################################################\n\n'
cat "$log_file"
} | sendemail -s "$log_mail_smtp" -f "$log_mail_source" -t "$mail_aim" -u "$log_mail_subject" -o tls=no
done
}


#Mail Body: ### clean up
for mail_aim in `echo "$log_mail_aim" | tr "," " "`; do [ "$1" != "0" ] && {
{ chroot_umount$distro "$chroot_path" 2> /dev/null
echo "$log_mail_subject" workspace_erase "$iso_extr_dir/" "$chroot_path/" 2> /dev/null
echo $'####################################################################################\n\n' }
cat "$log_file" exit $1
} | sendemail -s "$log_mail_smtp" -f "$log_mail_source" -t "$mail_aim" -u "$log_mail_subject" -o tls=no
done

[ "$1" != "0" ] && {
chroot_umount$distro "$chroot_path" 2> /dev/null
workspace_erase "$iso_extr_dir/" "$chroot_path/" 2> /dev/null
}
exit $1
} }


#this func is standalone executable #this func is standalone executable

0
src/proj/desinfect2017 Normal file
View File

View File

@ -1,7 +1,7 @@
#!/bin/bash #!/bin/bash
#@version 2.0.2 #@version 2.0.3
#@autor 6543@obermui.de #@autor 6543@obermui.de
#@date 2018-05-13 #@date 2018-05-20
#@licence GNUv3 #@licence GNUv3


##################################################################################### #####################################################################################
@ -25,6 +25,23 @@ else
exit 1 exit 1
fi fi
fi fi
#check LOG
{
[ -z "$log_file" ] && log_file="/tmp/remaster_`date '+%Y-%m-%d'`"

if [ -f "$log_file" ]; then
echo > "$log_file"
else
#check if folder exist
[ -d "${log_file%/*}" ] || {
# N-> exit 3
echo "Directory for Log didnt exist"
exit 3
}
#create LOG
touch "$log_file"
fi
}


##################################################################################### #####################################################################################
################## M o d e s ######################################################## ################## M o d e s ########################################################
@ -32,8 +49,7 @@ fi


#remaster.sh renew #remaster.sh renew
function main_renew() { function main_renew() {

#Start LOG
[ -f "$log_file" ] || touch "$log_file"
tail -f "$log_file" --pid="$$" & tail -f "$log_file" --pid="$$" &


chroot_path="`mktemp -d`" chroot_path="`mktemp -d`"
@ -90,7 +106,10 @@ function main_renew() {
check_dependency check_dependency
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"


check_update | tee -a "$log_file" check_config >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

check_update >> "$log_file"


[ "$distro" != "" ] && distro="_$distro" [ "$distro" != "" ] && distro="_$distro"


@ -113,9 +132,10 @@ function main_renew() {
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"


# 5. Setzen der Netzwerk-Einstellungen: # 5. Setzen der Netzwerk-Einstellungen:

[ -n "$proxy_host" ] && {
proxy_enable$distro "$chroot_path" "$proxy_host" "$proxy_port" >> "$log_file" proxy_enable$distro "$chroot_path" "$proxy_host" "$proxy_port" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"
}


dns_set "$chroot_path" "$domain" "$nameserver" >> "$log_file" dns_set "$chroot_path" "$domain" "$nameserver" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"
@ -194,8 +214,7 @@ function main_renew() {
#remaster.sh update_pxe #remaster.sh update_pxe
function main_update_pxe() { function main_update_pxe() {


[ "$log_file" == "" ] && log_file="`mktemp`" #Start LOG
[ -f "$log_file" ] || touch "$log_file"
tail -f "$log_file" --pid="$$" & tail -f "$log_file" --pid="$$" &


chroot_path="`mktemp -d`" chroot_path="`mktemp -d`"
@ -239,11 +258,14 @@ function main_update_pxe() {
check_user check_user
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"


check_update | tee -a "$log_file" check_update >> "$log_file"


check_dependency check_dependency
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"


check_config >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

[ "$distro" != "" ] && distro="_$distro" [ "$distro" != "" ] && distro="_$distro"


# 1. Entpacken der Dateien des Live-Systems # 1. Entpacken der Dateien des Live-Systems
@ -307,7 +329,7 @@ function main_update_pxe() {


#remaster.sh update_iso #in arbeit #remaster.sh update_iso #in arbeit
function main_update_iso() { function main_update_iso() {
[ -f "$log_file" ] || touch "$log_file" #Start LOG
tail -f "$log_file" --pid="$$" & tail -f "$log_file" --pid="$$" &


chroot_path="`mktemp -d`" chroot_path="`mktemp -d`"
@ -361,11 +383,14 @@ function main_update_iso() {
check_user check_user
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"


check_update | tee -a "$log_file" check_update >> "$log_file"


check_dependency check_dependency
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"


check_config >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

[ "$distro" != "" ] && distro="_$distro" [ "$distro" != "" ] && distro="_$distro"


# 2. Entpacke ISO # 2. Entpacke ISO
@ -397,9 +422,10 @@ function main_update_iso() {
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"


# 5. Setzen der Netzwerk-Einstellungen: # 5. Setzen der Netzwerk-Einstellungen:

[ -n "$proxy_host" ] && {
proxy_enable$distro "$chroot_path" "$proxy_host" "$proxy_port" >> "$log_file" proxy_enable$distro "$chroot_path" "$proxy_host" "$proxy_port" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"
}


dns_set "$chroot_path" "$domain" "$nameserver" >> "$log_file" dns_set "$chroot_path" "$domain" "$nameserver" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file" error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"
@ -477,6 +503,9 @@ function main_update_iso() {


### Error Handlings ### ### Error Handlings ###


#check_config
source <LIBDIR>/func/check_config

#on_exit [error_level] #on_exit [error_level]
source <LIBDIR>/func/on_exit source <LIBDIR>/func/on_exit


@ -490,6 +519,8 @@ source <LIBDIR>/func/check_user
# -> 0 | -> 16 # -> 0 | -> 16
source <LIBDIR>/func/check_dependency source <LIBDIR>/func/check_dependency


#check_update
source <LIBDIR>/func/check_update


### Workspace ### ### Workspace ###