Compare commits

...

166 Commits

Author SHA1 Message Date
6543 73d1c97f3a
clean up 2021-06-06 21:59:22 +02:00
6543 686d3ef8c2
remove useless FOSSA Status 2020-01-14 20:23:49 +01:00
6543 27913b4a59
switch from github to gitea 2019-09-21 01:05:28 +02:00
6543 70c002bff2
Set Version 2.1.0 2019-09-20 05:04:35 +02:00
6543 9fbdea3a1d
Release 2.1.0
checkout Changelog
2019-09-20 05:01:53 +02:00
6543 7fd11f9cd6
ready for v2.1.0 2019-09-20 04:59:23 +02:00
6543 d34f7a39bd
mv Changelog
resolve issue #26
2019-09-20 04:47:32 +02:00
6543 1af13587dc
Update README.md 2019-09-20 04:40:14 +02:00
6543 e0262554ce
Merge pull request #25 from fossabot/master
Add license scan report and status
2019-09-20 04:39:17 +02:00
6543 0caa4f6af2
README: add PGP shield 2019-09-18 23:17:01 +02:00
6543 67be4705a5
README: add shields for Release and License 2019-09-18 23:00:46 +02:00
fossabot 2a3aa53d2f Add license scan report and status
Signed-off-by: fossabot <badges@fossa.io>
2019-09-04 10:33:31 -07:00
6543 df734f1f34
Merge branch 'config-as-param' into develop 2019-07-13 21:04:34 +02:00
6543 2ac2fd9cd2
finisch custom config option 2019-07-13 21:04:19 +02:00
6543 90926de1d6
add clear_config func() 2019-07-13 21:03:30 +02:00
6543 189fd6d56c
read custom config file 2019-07-13 20:57:25 +02:00
6543 ff5d90c312
catch --config param 2019-07-13 20:53:04 +02:00
6543 ade9e795b6
Merge branch 'print-version-help' into develop 2019-07-13 20:50:28 +02:00
6543 e26f391b49
add help menue (resolve #24) 2019-07-13 20:47:24 +02:00
6543 3643b745ae
update dev script set_version
now also has to update the output of --version|-V
2019-07-13 20:37:01 +02:00
6543 f5db5a154d
just work normal if no argument is given 2019-07-13 20:34:45 +02:00
6543 3149285ab9
Add Section "Help & Info" 2019-07-13 20:34:07 +02:00
6543 db0ae5e4fe
fix dev script
use system variable EDITOR to start the default editor
2019-07-13 20:06:14 +02:00
6543 18b42628a0 restruct config 2018-06-02 22:49:54 +02:00
6543 f809343015 report corect meaning 2018-06-01 01:56:41 +02:00
6543 4cb8816cc1 notes, smal fix 2018-05-22 12:46:20 +02:00
6543 ffdab66b35 Merge branch 'release-2.0.4' 2018-05-22 02:20:31 +02:00
6543 de495758b4 del old proj for release 2018-05-22 02:19:04 +02:00
6543 aa0e1fbd6d v 2.0.4 2018-05-22 01:51:17 +02:00
6543 83d8ace4e5 Merge branch 'feature-iso-extract-from-url' into develop 2018-05-22 01:47:46 +02:00
6543 2b7eb9620a Merge branch 'restructure-as-describe-in-doc' into develop 2018-05-22 01:47:34 +02:00
6543 32cfb2a7a4 finish 2018-05-22 01:47:10 +02:00
6543 05bf2a4cdf add new sub func 2018-05-22 01:38:30 +02:00
6543 2a081ad517 add logic 2018-05-22 01:34:32 +02:00
6543 7d4c1015d5 switch checks 2018-05-22 01:30:35 +02:00
6543 f3c3ba82f5 Merge branch 'restructure-mv-last-dependencys' into restructure-as-describe-in-doc 2018-05-22 01:25:35 +02:00
6543 23e39f21f6 readd proj mods 2018-05-22 01:25:13 +02:00
6543 f303797810 add new base function 2018-05-22 01:20:55 +02:00
6543 fad9574ebb Merge branch 'restructure-rm-diff-modes' into restructure-as-describe-in-doc 2018-05-22 01:17:36 +02:00
6543 cd15118bb8 beautysh -f src/remaster.sh 2018-05-22 01:17:02 +02:00
6543 756d389c6d mv renew position 2018-05-22 01:16:14 +02:00
6543 eb96f7a0e4 rm unused modes 2018-05-22 01:15:08 +02:00
6543 9b5cc1665d use renew as base template 2018-05-22 01:14:21 +02:00
6543 631d78798d Merge branch 'restructure-use-overide' into restructure-as-describe-in-doc 2018-05-22 01:08:33 +02:00
6543 04e4e98525 semilicon fix 2018-05-22 01:05:32 +02:00
6543 32d09b764b overlod functions... 2018-05-22 00:58:05 +02:00
6543 2752dcc5ca change desinfect.17 to overload some funktions 2018-05-22 00:47:11 +02:00
6543 29a8d529c9 remove special function cals 2018-05-22 00:46:31 +02:00
6543 c4eeb44eaa use online functions instead alias 2018-05-22 00:30:51 +02:00
6543 15f5ad5fab example in debian template 2018-05-21 16:25:43 +02:00
6543 7601e2b93f Merge branch 'restructure-add-base-proj' into restructure-as-describe-in-doc 2018-05-21 16:21:10 +02:00
6543 013edd6c0f change debian template for script 2018-05-21 16:20:42 +02:00
6543 8990b7ea1e add base template 2018-05-21 16:16:22 +02:00
6543 10dce09e4d add proj gen script 2018-05-21 16:16:07 +02:00
6543 f77f690751 change proj-head docu for script 2018-05-21 16:15:36 +02:00
6543 fbf1a80b7b add idear 2018-05-21 13:05:02 +02:00
6543 0ffbae48a7 das große wandern 2018-05-21 13:04:37 +02:00
6543 636aba43d5 docu ... 2018-05-21 12:45:42 +02:00
6543 e32c217fea generalize project file format 2018-05-21 12:42:10 +02:00
6543 7c46700bd5 init 2018-05-21 12:34:55 +02:00
6543 be32c02a81 add some more messages to log 2018-05-21 12:07:47 +02:00
6543 f6aa1b24fd Merge branch 'change_names' into develop 2018-05-21 01:04:05 +02:00
6543 6bc29a5011 remove tmp-fix 2018-05-21 00:46:33 +02:00
6543 002487c5d1 some name changes 2018-05-21 00:25:27 +02:00
6543 6076f1372d docu ... 2018-05-21 00:16:26 +02:00
6543 9301b1a39c fix duble report 2018-05-20 23:44:26 +02:00
6543 c0ddfe7c1c v 2.0.3 2018-05-20 23:29:33 +02:00
6543 d41fa9e1b0 Merge branch 'feature-check-config' into develop
add feature check_config
2018-05-20 23:26:44 +02:00
6543 cee345cd25 fix until name change 2018-05-20 23:16:24 +02:00
6543 20bb090cb3 fixes... 2018-05-20 23:12:12 +02:00
6543 310b670631 aktivate 2018-05-20 23:04:52 +02:00
6543 6ce556ef84 add lable; smal fix 2018-05-20 22:55:54 +02:00
6543 242421fbab format... 2018-05-20 22:53:00 +02:00
6543 cdf2cc900e add project check 2018-05-20 22:52:20 +02:00
6543 8b782fa5e1 add live-system files check 2018-05-20 22:44:33 +02:00
6543 74b3a8b12b log check at init 2018-05-20 22:43:33 +02:00
6543 d11b96947c add log check 2018-05-20 21:53:56 +02:00
6543 832decf3d1 Merge branch 'feature-script-add-function' into develop 2018-05-20 21:17:07 +02:00
6543 89053e3ed1 add script 2018-05-20 21:16:19 +02:00
6543 051f8636a2 init check_config 2018-05-20 21:02:45 +02:00
6543 3510f44ef8 appropriate name 2018-05-20 20:50:06 +02:00
6543 fb4afed081 subvers 2018-05-20 20:32:55 +02:00
6543 6bb0f2ab06 Merge branch 'feature-proxy-optional' into develop 2018-05-20 14:15:24 +02:00
6543 22c8d8081e Load check_update func 2018-05-20 12:24:51 +02:00
6543 d65cddc2f5 proxy optional 2018-05-20 11:59:47 +02:00
6543 28f59fb94b Merge branch 'doc-struckture' into develop
add draft
2018-05-20 01:34:46 +02:00
6543 6aa13ce326 draft_v3 2018-05-20 01:34:10 +02:00
6543 ff9a384ce6 draft_v2 2018-05-20 01:29:25 +02:00
6543 897ddfd3a6 format 2018-05-20 01:13:03 +02:00
6543 5767355c21 draft 2018-05-20 00:43:38 +02:00
6543 d0c53279b5 update Dependencys <- update feature 2018-05-19 22:45:42 +02:00
6543 1d52508d77 Merge remote-tracking branch 'origin/feature-mail-optional' into develop 2018-05-19 22:30:40 +02:00
6543 ca02c443d3 make mail optional 2018-05-17 01:05:56 +02:00
6543 55a17ad2ce beautysh 2018-05-17 01:04:21 +02:00
6543 fcbfdff33a Merge branch 'hotfix-2.0.2' into develop 2018-05-13 00:40:39 +02:00
6543 1a301100b7 hotfix-2.0.2 2018-05-13 00:36:05 +02:00
6543 b3894fedc9 hotfix-2.0.2 2018-05-13 00:33:39 +02:00
6543 d2f7a45d6c hotfix-2.0.2 2018-05-13 00:30:53 +02:00
6543 cdd40d5195 Merge branch 'feature-check-update' into develop 2018-05-13 00:05:14 +02:00
6543 a2517232a1 add feature check_update 2018-05-13 00:05:02 +02:00
6543 66372fadcc add update check 2018-05-13 00:02:09 +02:00
6543 263587222e spelling 2018-05-12 23:44:00 +02:00
6543 57b2383ef3 spelling 2018-05-12 23:12:17 +02:00
6543 c9116e1cfd Merge branch 'release-2.0.0' 2018-05-12 23:06:43 +02:00
6543 3a3083cda8 Merge branch 'release-2.0.0' into develop
release-2.0.0
2018-05-12 23:06:09 +02:00
6543 ab4622e37a release-2.0.0 2018-05-12 23:05:54 +02:00
6543 baa3dcf419 merge dev 2018-05-12 22:58:51 +02:00
6543 1134235acd clean 2018-05-12 22:56:13 +02:00
6543 727cf6ed3c Merge branch 'feature-debian-packages' into develop
lintian improvements
2018-05-12 22:41:08 +02:00
6543 d63d13fe80 del dummy func 2018-05-12 22:40:41 +02:00
6543 b0ce2cfa16 lintian improvements 2018-05-12 22:37:35 +02:00
6543 cee0bd03ca Merge branch 'feature-debian-packages' into develop
add feauture build-deb
2018-05-12 20:20:08 +02:00
6543 8885e4881f autogen beautysh 2018-05-12 20:19:38 +02:00
6543 7aadb795ff autogen irreführende namen geändert 2018-05-12 20:19:12 +02:00
6543 80d2ad753d debian init 2018-05-12 19:54:34 +02:00
6543 e5edbb3f8d Merge branch 'fix-standalone_executable' into develop
fix-standalone_executable
2018-05-11 00:04:43 +02:00
6543 2513b645c1 standalone executable 2018-05-11 00:04:02 +02:00
6543 401abf1f4b Merge branch 'hotfix-1.9.3' into develop
hotfix-1.9.3
2018-05-10 22:47:55 +02:00
6543 c43fb3b724 hotfix-1.9.3 2018-05-10 22:47:24 +02:00
6543 ec93ab93a8 Merge branch 'bugfix-1.9.2' into develop
docu
2018-05-10 18:51:44 +02:00
6543 a5345457d4 docu 2018-05-10 18:51:34 +02:00
6543 c5c5327826 spelling 2018-05-10 18:36:34 +02:00
6543 fcf59dc1d9 spelling 2018-05-10 18:28:49 +02:00
6543 7905649b4e Merge branch 'bugfix-1.9.2' into develop
finished bugfix-1.9.2
2018-05-10 17:14:21 +02:00
6543 81d0a5c8c3 add Doc "Server Bedienung" 2018-05-10 17:13:52 +02:00
6543 98e0b6c835 exec singel func 2018-05-10 17:13:19 +02:00
6543 49901e1f32 scripts 2018-05-10 14:19:14 +02:00
6543 aa57178d15 spelling 2018-05-10 13:41:01 +02:00
6543 01a0709563 add Docu 2018-05-10 12:26:22 +02:00
6543 07e4e0d663 lib header 2018-05-08 00:28:32 +02:00
6543 41e020e645 del test vars 2018-05-07 03:01:16 +02:00
6543 26d0950665 code format bug 2018-05-07 02:56:46 +02:00
6543 50ddcac6f6 Update License 2018-05-07 02:44:22 +02:00
6543 1d392d7460 docu... 2018-05-07 02:43:27 +02:00
6543 bfdad6d547 Update License 2018-05-07 02:42:10 +02:00
6543 41946e6584 docu ... 2018-05-07 02:34:25 +02:00
6543 c4f2f7367a docu ... 2018-05-07 02:08:20 +02:00
6543 c6103a8fb4 source cant use variables (p5-final) 2018-05-07 01:58:55 +02:00
6543 6616478014 source cant use variables (p4) 2018-05-07 01:49:19 +02:00
6543 80d8a9bedf code format 2018-05-07 01:34:59 +02:00
6543 1aff83904c source cant use variables (p3) 2018-05-07 01:30:50 +02:00
6543 b6eb652c50 atom-beautify 2018-05-07 01:11:25 +02:00
6543 801da8e4af source cant use variables (p2) 2018-05-07 01:09:19 +02:00
6543 4b9bbe22af atom-beautify 2018-05-06 19:31:13 +02:00
6543 838a1e709a source cant use variables (p1) 2018-05-06 19:26:21 +02:00
6543 f2b3b5f530 Split main func (no os/proj dependency) 2018-04-30 18:57:01 +02:00
6543 b5ab4f1ec9 - bugfix '"'
- def lib-header
2018-04-30 18:12:45 +02:00
6543 aecc9d5b9c rename gendeb to autogen 2018-04-28 11:32:26 +02:00
6543 be87936dc4 2018-04-05 2018-04-27 14:01:08 +02:00
6543 c28eaa1a38
Merge pull request #17 from 6543/changes-on-server
2018-04-05
2018-04-27 12:07:02 +02:00
6543 ab55ed8b3d 2018-04-05 2018-04-27 12:04:05 +02:00
6543 074b92b984 smal fixes 2018-04-27 09:33:02 +02:00
6543 da68365153 restructure: seperate config 2018-04-26 20:58:19 +02:00
6543 1c4dc6ac56 create docu p2 2018-04-26 19:46:17 +02:00
6543 eedeecbcb6 ... 2018-04-26 18:43:56 +02:00
6543 365cb8a069
Merge pull request #14 from 6543/clean
del unfinished things
2018-04-26 18:28:03 +02:00
6543 9d907e9028 del unfinished things 2018-04-26 18:26:28 +02:00
6543 5a86bb3237
Merge pull request #13 from 6543/clean
clean repo
2018-04-26 18:25:09 +02:00
6543 3321ce059a done 2018-04-26 18:23:42 +02:00
6543 b05a5cfb7b create docu p1
mk placeholder
2018-04-26 17:16:09 +02:00
6543 432e01e762 Beschreibung aktualisert 2018-04-26 13:33:08 +02:00
6543 f6b3415c17 add build 2018-04-26 13:23:51 +02:00
6543 b38a62aa8b restructure ... begin 2018-04-26 13:04:35 +02:00
6543 c52b58b9f5 1.8.1 2018-03-26 14:53:48 +02:00
6543 479ed25411 v1.8.0 2018-03-26 14:52:46 +02:00
6543 d0b6c3d271 v1.7.3 2018-03-26 14:50:34 +02:00
53 changed files with 1855 additions and 1773 deletions

2
.gitignore vendored Normal file
View File

@ -0,0 +1,2 @@
/build
/release

42
Changelog.md Normal file
View File

@ -0,0 +1,42 @@
2018-04-26 - 1.9.1
* seperate script and config

2018-05-10 - 1.9.2
* exec singel func

2018-05-10 - 1.9.3
* hotfix-1.9.3

2018-05-12 - 2.0.0
* add feature build debian packages
* add Doc "Server Bedienung"
* split functions
* separate config into /etc/remaster/

2018-05-13 - 2.0.1
* Update-Prüfmechanismus #15

2018-05-13 - 2.0.2
* 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

2018-05-22 - 2.0.4
* add iso_source as URL
* restructure code
* use proj templates
* some help scripts

2019-09-20 - 2.1.0
* fixes
- filesystem_extract: filesystem_get_type
- update dev scripts
- work without arguments
* check_update: acuret message
* restruct sample config
* add "Help & Info" menue/section (#24) (#20)
* --config | custom config (#25)

1
DEBIAN/conffiles Normal file
View File

@ -0,0 +1 @@
/etc/remaster/config.sample.cfg

12
DEBIAN/control Normal file
View File

@ -0,0 +1,12 @@
Package: remaster
Source: remaster
Version: 2.1.0
Architecture: all
Maintainer: 6543 <6543@obermui.de>
Installed-Size: <SIZE>
Depends: squashfs-tools, xorriso, wget, sed (>= 4.2), sendemail, bash (>= 4.3)
Suggests: nfs-kernel-server, isc-dhcp-server
Section: utils
Priority: optional
Homepage: https://github.com/6543/remaster
Description: The aim of this Project is to create a daemon for a server, witch update live systems.

1
DEBIAN/postinst Executable file
View File

@ -0,0 +1 @@
#!/bin/sh

1
DEBIAN/postrm Executable file
View File

@ -0,0 +1 @@
#!/bin/sh

1
DEBIAN/preinst Executable file
View File

@ -0,0 +1 @@
#!/bin/sh

1
DEBIAN/prerm Executable file
View File

@ -0,0 +1 @@
#!/bin/sh

View File

@ -632,7 +632,7 @@ state the exclusion of warranty; and each file should have at least
the "copyright" line and a pointer to where the full notice is found.

{one line to give the program's name and a brief idea of what it does.}
Copyright (C) {year} {name of author}
Copyright (C) 2018 6543@obermui.de

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@ -652,7 +652,7 @@ Also add information on how to contact you by electronic and paper mail.
If the program does terminal interaction, make it output a short
notice like this when it starts in an interactive mode:

{project} Copyright (C) {year} {fullname}
remaster Copyright (C) 2018 6543@obermui.de
This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
This is free software, and you are welcome to redistribute it
under certain conditions; type `show c' for details.

View File

@ -1,9 +1,36 @@
[![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)
[![Release](https://img.shields.io/badge/dynamic/json.svg?label=release&url=https://code.obermui.de/api/v1/repos/6543/remaster/releases&query=$[0].tag_name)](https://code.obermui.de/6543/remaster/releases)
[![PGP Sig](https://img.shields.io/keybase/pgp/6543)](https://mh.obermui.de/publickey.gpg)
[![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2F6543%2Fremaster.svg?type=shield)](https://app.fossa.io/projects/git%2Bgithub.com%2F6543%2Fremaster?ref=badge_shield)

# remaster

for testing ...
## Description

The aim of this Project is to create a daemon for a server, witch update live systems. You should only have to install the modules for different OS/Live-Projects. It also set the right network settings (Proxy, DNS, ...) and will be extendible wit PXE menu. additional: Web Interface (Create/Change/Delete Jobs; Download Latest ISO; Start/Stop PXE Server)

This script updates/change Live Linux CDs
(At the moment only Ubuntu/Debian; Desinfect15,16)
## Dependencys

Perhaps this will be split in parts and an config file in /etc/remaster/ controls it ...
- squashfs-tools
- xorriso
- wget
- sed
- sendemail
- curl

## To Do

- Support more Projects

- Debian
- Ubuntu
- Desinfect17
- CentOS

- Add Job-Scheduler

## At the Moment

- Ubuntu/Debian
- Desinfect17
- one config file

131
autogen.sh Executable file
View File

@ -0,0 +1,131 @@
#!/bin/bash
# install | clean | debug | build-deb

function clean() {
echo "clear build"
[ -d build ] && rm -v -R build
mkdir build
}
function copy() {
echo "copy files ..."
# remaster
mkdir -p build/usr/bin/
cp -v src/remaster.sh build/usr/bin/remaster
chmod +x build/usr/bin/remaster

# modules
mkdir -p build/usr/lib/remaster/
for i in proj func mods; do
mkdir -p build/usr/lib/remaster/$i
cp -v src/$i/* build/usr/lib/remaster/$i/
done

# setting
mkdir -p build/etc/remaster/
cp -v src/config.sample.cfg build/etc/remaster/config.sample.cfg

#changelog
mkdir -p build/usr/share/doc/remaster
cp -v changes/remaster.md build/usr/share/doc/remaster/changelog
gzip --best build/usr/share/doc/remaster/changelog
}

#config ...
function set_rootdir() {
sed -i "s#<ROOTDIR>#$1#g" build/usr/bin/remaster
for i in proj func mods; do
sed -i "s#<ROOTDIR>#$1#g" build/usr/lib/remaster/$i/*
done
}
function set_libdir() {
sed -i "s#<LIBDIR>#$1#g" build/usr/bin/remaster
for i in proj func mods; do
sed -i "s#<LIBDIR>#$1#g" build/usr/lib/remaster/$i/*
done
}

#modes
function debug() {
clean

#prebuild
copy
set_rootdir "`pwd`/build"
set_libdir "`pwd`/build/usr/lib/remaster"
}
function install() {
#überprüfe auf root
[ "`id -u`" != "0" ] && { echo "Error start as root"; exit 1; }

#lösche alltes build dir
clean

#prebuild
copy
set_rootdir ""
set_libdir "/usr/lib/remaster"

#set owner
chown -r root:root build/

#install
cp -f -r build/* /
}
function build-deb() {
#überprüfe auf root
[ "`id -u`" != "0" ] && { echo "Error start as root"; exit 1; }

#lösche alltes build dir
clean

#prebuild
copy
set_rootdir ""
set_libdir "/usr/lib/remaster"
####
## changes for deb file
####
cp -v -r -f DEBIAN build/
#create md5sums
find ./build -type f -exec md5sum {} \; | grep -v './build/DEBIAN' | sed 's/\.\/build\///g' > build/DEBIAN/md5sums
chmod 0644 build/DEBIAN/md5sums

#set size
SIZE="`du --exclude=build/DEBIAN -c build/ | cut -f 1 | tail -n 1`"
sed -i "s/<SIZE>/$SIZE/g" build/DEBIAN/control

#set owner
chown -r root:root build/

##
#build deb
##
dpkg -b build/
version="`cat build/DEBIAN/control | grep Version | cut -d " " -f 2`"
arch="`cat build/DEBIAN/control | grep Arch | cut -d " " -f 2`"
[ -f "release/remaster_"$version"_"$arch".deb" ] && rm "release/remaster_"$version"_"$arch".deb"
mkdir -p release
mv -v "build.deb" "release/remaster_"$version"_"$arch".deb"
}


case "$1" in
install)
install || exit 1
;;
clean)
clean || exit 1
;;
debug)
debug || exit 1
;;
copy)
copy || exit 1
;;
build-deb)
build-deb || exit 1
;;
*)
echo "Usage: install | clean | debug | build-deb"
exit 1
esac

12
doc/buid_vars.md Normal file
View File

@ -0,0 +1,12 @@
variablen, welche um zu funktionieren mit statischen pfaden
ausgetauscht werden müssen:

remaster.sh
* <ROOTDIR>
-(install)> ""
-(debug)> 'pwd'/build

remaster.sh; <LIBDIR>/*/*;
* <LIBDIR>
-(install)> /usr/lib/remaster
-(debug)> 'pwd'/build/usr/lib/remaster

Binary file not shown.

Binary file not shown.

View File

@ -1,13 +1,13 @@
Erorr Liste:
Erorrs:

ID: Description
----------------------------------------------------
1 Allgemeiner Fehler
2 No Paramters / wrong parameters
3 Wrong Settings!
4 Programm missing
1 general error
2 no paramters / wrong parameters
3 wrong settings
4 programm missing

10 no root
10 need root permission
11 file no found
12 dir not found
13 cant create/delete file/dir

13
doc/lib-head+tail Normal file
View File

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

#<function> [param]
function <function>() {
#Code of <function>
}

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

8
doc/proj-head Executable file
View File

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

#<PROJECT_NAME>
#<project_relation>
source <LIBDIR>/proj/<BASE>
project_relation="<PROJECT_NAME> $project_relation"

111
doc/structure.md Normal file
View File

@ -0,0 +1,111 @@
## 1.1 Load base functions [-> #functions]

## 1.2 Check ...
* for updates
* for rights

## 1.3 Load settings [-> #config]
* lade /etc/remaster/<Conf>
* verify config (Proj Exist; Mods Exist; ...)

## 1.4 Load Proj-Func [-> #projects]
* overload based on dependencys
* (z.B. ubuntu.16.04 -> ubuntu -> debian)
* verify config (Proj Conform)

## 1.5 Load $n Mods (optional) [-> #mods]
* check
* save in MOD_LST

# 2. Init Chroot

## 2.1 Extrackt Files
* ISO
* Squashfs

## 2.2 Config for Chroot (chroot_initial)
* (lxc-conf / tmpdir)
* network

## 2.3 Start Chroot
* (lxc-start / mount ...)

# 3. Modivikationen

## 3.1 Network

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

## 3.3 Packet Mgr
* Updates
* Install
* Delete

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

# 4. Finish

## 4.1 Clean-Up Live-System
* tmpfiles
* Packet Mgr

## 4.2 Stop chroot
* Umount

## 4.3. Generate ISO/PXE

## 4.4. Delete 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

File diff suppressed because it is too large Load Diff

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"

34
script/add_project.sh Executable file
View File

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

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

#gen project
cp "doc/proj-head" "src/proj/$name"

#set base_relations
if [ -z "$base" ]; then
base_relations="base"
base="base"
sed -i "/project_relation=/c\project_relation=\"<PROJECT_NAME>\"" "src/proj/$name"
else
[ -f "src/proj/$base" ] || {
echo "BASE: $base dont exist"
exit 1
}
#get base of $base
base_base=`grep '# . ->' src/proj/$base`
base_relations=`echo $base_base | sed "s/#\ \./$base/g"`
fi

## replace strings
# . -> <PROJECT_PARENT> -> base
sed -i "s/<project_relation>/\ \.\ ->\ $base_relations/g" "src/proj/$name"
#<PROJECT_NAME>
sed -i "s/<PROJECT_NAME>/$name/g" "src/proj/$name"
sed -i "s/<BASE>/$base/g" "src/proj/$name"

#open
editor "src/proj/$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

27
script/set_version.sh Executable file
View File

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

version=$1
date=`date +%Y-%m-%d`

[ -e "src/remaster.sh" ] && {

version_sed=`echo $version | sed 's/\./\\./g'`

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

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

[ -e "Changelog.md" ] && {

echo >> Changelog.md
echo $date - $version >> Changelog.md
$EDITOR Changelog.md
}

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

39
src/config.sample.cfg Normal file
View File

@ -0,0 +1,39 @@

#########################################################
## sample-config rename it to config.cfg after changes ##
#########################################################

## Quelle der Project CD/DVD
iso_source="/data/local/Desinfect_Remaster/tmp/desinfect-2017.iso"

## Pfad zum gepakten Live System
## (kann anstat einer ISO auch als Quelle dienen, dann aber auch zwingend als Ziel)
# squashfs_path="/data/local/Desinfect_Remaster/tmp/filesystem.squashfs"

## Ziel, Lable der zu erstellenden CD/DVD
iso_aim="/data/local/Desinfect_Remaster/tmp/custom_desinfect_`date '+%Y-%m-%d'`.iso"
iso_lable="DESINFECT_`date '+%Y-%m-%d'`"


## Netzwerk Sinstellungen
## Proxy:
# proxy_host="10.40.8.108"
# proxy_port="8080"
domain="fritz.box"
nameserver="10.40.255.254"

## Project / Distro
## Aktuell unterstützt: debian; ubuntu; ubuntu.14.04; ubuntu.16.04; desinfect.17
project="desinfect.17"

## LOG Einstellungen
## log_file ist optionall
log_file="/data/local/Desinfect_Remaster/tmp/logs/`date '+%Y-%m-%d'`.log"
## Senden mit sendmail einen Report
# log_mail_source="desinfect@email.clocal"
# log_mail_smtp="smtp.mail.local:25"
# log_mail_aim="6543@email.clocal"
# log_mail_subject="Desinfect_Remaster"

#Sonstiges
tools_list="xrdp clamav nano htop nmon iftop tmux dsniff nmap openssh-server tightvncserver rsync e2fsprogs foremost gddrescue recoverjpeg safecopy sleuthkit testdisk arp-scan"

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/$project" ] || {
echo "No Project \"$project\" is not supported"
return 3
}

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

echo 'iso_source -> iso_aim'
echo 'iso_source -> squashfs [optinal]'
else
if [ -n "$squashfs_path" ] && [ -d "${squashfs_path%/*}" ]; then
echo 'iso_source -> squashfs'
else
# ERROR
echo "No corect AIM in Settings"
return 3
fi
fi
else
if [ -f "$squashfs_path" ]; then
if [ -n "$iso_aim" ]; 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 $@
}

20
src/func/check_dependency Executable file
View File

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

#check_dependency
# -> 0 | -> 16
function check_dependency() {
for packet in squashfs-tools xorriso wget sed sendemail; do
[ "`dpkg -l $packet 2>&1`" == "dpkg-query: Kein Paket gefunden, das auf $packet passt" ] && {
echo "### ERROR ### Packet $packet not installed"
return 16
}
done
return 0
}

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

17
src/func/check_update Executable file
View File

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

#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
echo 'INFO: Programm Aktuell'
else
echo 'WARNUNG: Ausgeführte Version entspricht nicht dem offiziellen Release'
fi
}

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

20
src/func/check_url Normal file
View File

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

#check_url [URL]
function check_url() {
URL="$1"
if [[ `wget -S --spider "$URL" 2>&1 | grep 'HTTP/1.1 200 OK'` ]]; then
echo "true"
return 0
else
echo "false"
return 1
fi
}

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

17
src/func/check_user Executable file
View File

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

#check_user
function check_user() {
#check root
[ "`whoami`" == "root" ] || {
echo "### ERROR ### Remaster need ROOT permision!"
return 10
}
}

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

22
src/func/chroot_clean Executable file
View File

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

#chroot_clean [chroot_dir]
function chroot_clean() {
echo "clean chroot ... "

chroot_dir="$1"

chroot "$chroot_dir" /bin/bash -c "apt-get clean"
chroot "$chroot_dir" /bin/bash -c "rm -r /var/cache/apt/*"
chroot "$chroot_dir" /bin/bash -c "apt-get update"
chroot "$chroot_dir" /bin/bash -c "apt-get check"

echo "done"
}

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

31
src/func/chroot_initial Executable file
View File

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

#chroot_initial [chroot_dir]
function chroot_initial() {
echo -n "initial chroot ... "

#check chroot dir
chroot_dir="$1"
[ -d "$chroot_dir" ] || {
echo "### ERROR ### chroot_initial: chroot directory not exist"
return 12
}

#mount virus definitions
mount -t tmpfs tmpfs "$chroot_dir/tmp"
mount -t tmpfs tmpfs "$chroot_dir/root"
mount --bind /dev "$chroot_dir/dev"
mount --bind /proc "$chroot_dir/proc"

rm "$chroot_dir/etc/resolv.conf"
cp "/etc/resolv.conf" "$chroot_dir/etc/resolv.conf"

echo "done"
}

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

22
src/func/chroot_is_mounted Executable file
View File

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

#chroot_is_mounted [chroot_dir]
#(Boolean)-> true | false
function chroot_is_mounted() {
#$1 = chroot directory

if [ "`mount | grep "$1"`" != "" ] ; then
#ther is smething mounted
echo "true"
else
#nothing mounted
echo "false"
fi
}

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

29
src/func/chroot_sh Executable file
View File

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

#chroot_sh [chroot_dir] [command]
function chroot_sh() {
#check chroot dir
chroot_dir="$1"
[ -d "$chroot_dir" ] || {
echo "### ERROR ### chroot_sh: chroot directory not exist!"
return 12
}

command="$2"

[ -f "$chroot_dir/tmp/env.sh" ] || {
#if not exist create environment skript
cat "$chroot_dir/etc/environment" | grep -v "#" | grep "=" > "$chroot_dir/tmp/env"
while read line; do echo export $line; done < "$chroot_dir/tmp/env" > "$chroot_dir/tmp/env.sh"
chmod +x "$chroot_dir/tmp/env.sh" && rm "$chroot_dir/tmp/env"
}

chroot "$chroot_dir" /bin/bash --login -c ". /tmp/env.sh; $command"
}

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

31
src/func/chroot_umount Executable file
View File

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

#chroot_umount [chroot_dir]
function chroot_umount() {
echo -n "unmount chroot ... "

#check chroot dir
chroot_dir="$1"
[ -d "$chroot_dir" ] || {
echo "### ERROR ### chroot_umount: chroot directory not exist!"
return 12
}

for d in "$chroot_dir/tmp" "$chroot_dir/root" "$chroot_dir/proc" "$chroot_dir/dev" ; do
umount $d
retval=$?
[ "$retval" -gt 0 ] && {
echo "### ERROR ### chroot_umount: can't umount \"$d\"!"
return 21
}
done

echo "done"
}

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

35
src/func/clear_config Executable file
View File

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

#check_config
function clear_config() {

## Source & Aim options
iso_source=
squashfs_path=
iso_aim=
iso_lable=

## network
proxy_host=
proxy_port=
domain=
nameserver=

## Project / Distro
project=

## LOG Settings
log_file=
log_mail_source=
log_mail_smtp=
log_mail_aim=
log_mail_subject=

}

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

68
src/func/error_code Executable file
View File

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

#error_code [error_level]
function error_code() {
code="$1"
case $code in
"")
echo $'ID:\tDescription\n----------------------------------------------------\n1\tAllgemeiner Fehler\n2\tNo Paramters / wrong parameters'
echo $'3\tWrong Settings\n4\tProgramm missing\n\n10\tno root\n11\tfile no found\n12\tdir not found\n13\tcant create/delete file/dir'
echo $'14\tcorrupt file (unsquashfs, mount iso, ...)\n15\twrong file (iso has no squashfs-file ...)\n16\trequired Packet not found\n\n20\tmount error\n21\tunmoun error\n22\twrong filesystem'
;;
1)
echo "Allgemeiner Fehler"
;;
2)
echo "No Paramters / wrong parameters"
;;
3)
echo "Wrong Settings"
;;
4)
echo "Programm missing"
;;
10)
echo "not executed as Root"
;;
11)
echo "file no found"
;;
12)
echo "dir not found"
;;
13)
echo "cant create/delete file/dir"
;;
14)
echo "corrupt file (unsquashfs, mount iso, ...)"
;;
15)
echo "wrong file (iso has no squashfs-file ...)"
;;
16)
echo "required Packet not found"
;;
20)
echo "tmount error"
;;
21)
echo "unmoun error"
;;
22)
echo "wrong filesystem"
;;
all)
error_code
;;
*)
echo $'No Defined Error Code.\nPerhaps an Error ocure on a Command wich was started by this Skritp.'
;;
esac
}

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

51
src/func/filesystem_extract Executable file
View File

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

#dependency
source <LIBDIR>/func/filesystem_get_type

#filesystem_extract [filesystem_img_source] [chroot_path]
function filesystem_extract() {
echo "extract filesystem ..."

#$1 = filesystem_img_source
#$2 = chroot_path
filesystem_img_source="$1"
chroot_path="$2"
filesystem_log="`mktemp`"

#Überfrüfen der Parameter
[ -f "$filesystem_img_source" ] || {
echo "### ERROR ### filesystem_extract: squashfs \"$filesystem_img_source\" not exist!"
return 11
}

[ "`mkdir -p "$chroot_path"`" != "" ] && {
echo "### ERROR ### filesystem_extract: chroot_path \"$chroot_path\" can't create!"
return 13
}

[ "`filesystem_get_type $chroot_path`" != "ext4" ] && [ "`filesystem_get_type $chroot_path`" != "btrfs" ] && {
echo "### ERROR ### filesystem_extract: wrong filesystem (`filesystem_get_type $chroot_path`)!"
return 22
}

rm -r "$chroot_path"

#eigendliches entpacken
unsquashfs -d "$chroot_path" "$filesystem_img_source" > "$filesystem_log" || {
echo "### ERROR ### filesystem_extract: unsquashfs failed!"
return 14
}

grep -v "\[" "$filesystem_log"
rm "$filesystem_log"

echo "done"
}

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

15
src/func/filesystem_get_type Executable file
View File

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

#filesystem_get_type [dir]
#(String)-> ext4, ext2, btfs, fuse, ...
function filesystem_get_type() {
fs_aTemp=(`df -T "$1"`)
echo ${fs_aTemp[9]}
}

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

37
src/func/filesystem_pack Executable file
View File

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

#filesystem_pack [chroot_path] [filesystem_img_destination]
function filesystem_pack() {
echo "pack filesystem ..."

#$1 = chroot_path
#$2 = filesystem_img_destination
chroot_path="$1"
filesystem_img_destination="$2"
filesystem_log="`mktemp`"

#Überfrüfen der Parameter
[ -d "$chroot_path" ] || {
echo "### ERROR ### filesystem_extract: chroot_path \"$chroot_path\" not exist!"
return 12
}

#loslegen ...
rm -f "$filesystem_img_destination"
mksquashfs "$chroot_path" "$filesystem_img_destination" > "$filesystem_log" || {
echo "### ERROR ### filesystem_pack: mksquashfs failed!"
return 13
}

grep -v "\[" "$filesystem_log"
rm "$filesystem_log"

echo "done"
}

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

31
src/func/iso_create Executable file
View File

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

#iso_create [chroot_path] [iso_extr_dir] [iso_destination] [iso_lable]
function iso_create() {
echo -n "create iso ..."

chroot_path="$1"
iso_extr_dir="$2"
iso_destination="$3"
iso_lable="$4"

[ -e "$iso_destination" ] && rm "$iso_destination"

xorriso -as mkisofs -graft-points -c isolinux/boot.cat -b isolinux/isolinux.bin \
-no-emul-boot -boot-info-table -boot-load-size 4 -isohybrid-mbr \
"$iso_extr_dir/isolinux/isolinux.bin" \
-eltorito-alt-boot -e boot/grub/efi.img -no-emul-boot \
-isohybrid-gpt-basdat -V "$iso_lable" \
-o "$iso_destination" \
-r -J "$iso_extr_dir" \
--sort-weight 0 / --sort-weight 2 /boot --sort-weight 1 /isolinux

echo "done"
}

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

61
src/func/iso_extract Executable file
View File

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

#iso_extract [iso_source] [iso_extr_dir]
function iso_extract() {
echo -n "extract iso ... "

#$1 = iso_source
#$2 = iso_extr_dir

#check root
[ "`whoami`" == "root" ] || {
echo "### ERROR ### iso_extract: need root permision!"
return 10
}

iso_extr_dir="$2"
[ -d "$iso_extr_dir" ] || {
echo "### ERROR ### iso_extract: aim directory not exist!"
return 12
}

iso_source="$1"
[ -f "$iso_source" ] || {
#if it is an url...
if [ "`check_url $iso_source`" == "true" ]; then
#dl to tmp + set iso_source
iso_tmp="`mktemp --suffix=.iso`"; rm "$iso_tmp"
wget -O "$iso_tmp" "$iso_source"
else
echo "### ERROR ### iso_extract: ISO \"$iso_source\" not exist!"
return 11
fi
}


#mace tmp mountpoint
tmpdir="`mktemp -d`"
[ -d "$iso_extr_dir" ] && {
rm -r "$iso_extr_dir/"
mkdir "$iso_extr_dir"
}

#copy files ...
mount -o loop,ro "$iso_source" "$tmpdir"
cp -f -r "$tmpdir/"* "$iso_extr_dir"

#clear tmp mountpoint
umount "$iso_source"
rm -r "$tmpdir"
[ -n "$iso_tmp" ] && rm "$iso_tmp"
tmpdir=

echo "done"
}

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

37
src/func/on_exit Executable file
View File

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

#on_exit [error_level]
function on_exit() {
### 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

#Mail Body:
for mail_aim in `echo "$log_mail_aim" | tr "," " "`; do
{
echo "$log_mail_subject"
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
}

### clean up
[ "$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
[ -n "$1" ] && {
on_exit $@
}

19
src/func/workspace_erase Executable file
View File

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

#workspace_erase [workspace_path]
function workspace_erase() {
echo -n "erase workspace ... "

for dir in "$@"; do
[ -d "$dir" ] && rm -r -f "$dir"
done

echo "done"
}

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

16
src/mods/xrdp Executable file
View File

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



## ...





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

34
src/proj/base Executable file
View File

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

##################
##### B a s e ####
##################
# .
project_relation=""
[ -z "$project" ] && project=base

#tools_add [chroot_dir] [tools_list]
function tools_add() {
echo "$project: tools_add ot available"
}

#os_update [chroot_dir]
function os_update() {
echo "$project: os_update ot available"
}

#proxy_enable [chroot_dir] [proxy_host] [proxy_port]
function proxy_enable() {
echo "$project: proxy_enable ot available"
}

#dns_set [chroot_dir] [domain] [nameserver]
function dns_set() {
echo "$project: dns_set ot available"
}

function project_mods() {
echo "$project: project_mods ot available"
}

98
src/proj/debian Executable file
View File

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

source <LIBDIR>/proj/base
#debian
# . -> base
project_relation="debian"

####################################
##### Base Template D E B I A N ####
####################################


#tools_add [chroot_dir] [tools_list]
function tools_add-debian() {
echo "add tools ... "
#$1 = chroot directory
chroot_dir="$1"
tools_list="$2"

chroot "$chroot_dir" /bin/bash -c "apt-get update" > /dev/null
[ "$?" == "0" ] && echo "apt-get update: success"
chroot "$chroot_dir" /bin/bash -c "apt-get install -y $tools_list" | grep -v "wird eingerichtet ..." | grep -v "Vormals nicht ausgewähltes Paket" | grep -v "Entpacken von" | grep -v "Holen: " | grep -v "Trigger für" | grep -v "update-alternatives:"
echo "done"
}
function tools_add() { tools_add-debian $@; }

#os_update [chroot_dir]
function os_update-debian() {
echo "updating os ... "
#$1 = chroot directory

chroot_dir="$1"

chroot "$chroot_dir" /bin/bash -c "apt-get update" > /dev/null
[ "$?" == "0" ] && echo "apt-get update: success"
chroot "$chroot_dir" /bin/bash -c "apt-get dist-upgrade -y" | grep -v "wird eingerichtet ..." | grep -v "Vormals nicht ausgewähltes Paket" | grep -v "Entpacken von" | grep -v "Holen: " | grep -v "Trigger für" | grep -v "update-alternatives:"
chroot "$chroot_dir" /bin/bash -c "apt-get clean"

echo "done"
}
function os_update() { os_update-debian $@; }

#proxy_enable [chroot_dir] [proxy_host] [proxy_port]
function proxy_enable-debian() {
echo -n "enable proxy ... "

chroot_dir="$1"
proxy_host="$2"
proxy_port="$3"

[ -d "$chroot_dir" ] || {
echo "### ERROR ### chroot_umount_desinfect: chroot directory not exist!"
return 12
}

#Wenn alle zwei Parameter gegeben
if [ "$proxy_host" != "" ] && [ "$proxy_port" != "" ] ; then
echo "http_proxy=\"http://$proxy_host:$proxy_port\"" >> $chroot_dir/etc/environment
echo "https_proxy=\"http://$proxy_host:$proxy_port\"" >> $chroot_dir/etc/environment
echo "ftp_proxy=\"http://$proxy_host:$proxy_port\"" >> $chroot_dir/etc/environment

echo "HTTP_PROXY=\"http://$proxy_host:$proxy_port\"" >> $chroot_dir/etc/environment
echo "HTTPS_PROXY=\"http://$proxy_host:$proxy_port\"" >> $chroot_dir/etc/environment
echo "FTP_PROXY=\"http://$proxy_host:$proxy_port\"" >> $chroot_dir/etc/environment

echo "Acquire::http::Proxy \"http://$proxy_host:$proxy_port\"\;" > $chroot_dir/etc/apt/apt.conf.d/90proxy
echo "Acquire::ftp::Proxy \"ftp://$proxy_host:$proxy_port\"\;" >> $chroot_dir/etc/apt/apt.conf.d/90proxy

echo "done"
else
if [ "$proxy_host" == "" ] && [ "$proxy_port" == "" ] ; then
echo "done"
else
echo "### ERROR ### proxy_enable: wrong parameters! (\"$chroot_dir\"; \"$proxy_host\"; \"$proxy_port\")"
echo "proxy_enable [chroot_dir] [proxy_host] [proxy_port]"
return 2
fi
fi
}
function proxy_enable() { proxy_enable-debian $@; }

#dns_set [chroot_dir] [domain] [nameserver]
function dns_set-debian() {
echo -n "set dns config ... "

rm "$chroot_dir/etc/resolv.conf"

[ "$2" != "" ] && echo "domain $2" >> "$chroot_dir/etc/resolv.conf"
echo "search $2" >> "$chroot_dir/etc/resolv.conf"
for namesv in `echo "$3" | tr "," " "`; do
echo "nameserver $namesv" >> "$chroot_dir/etc/resolv.conf"
done

echo "done"
}
function dns_set() { dns_set-debian $@; }

263
src/proj/desinfect.17 Executable file
View File

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

#desinfect.17
# . -Y ubuntu.16.04 -> ubuntu -> debian
source <LIBDIR>/proj/ubuntu.16.04
project_relation="desinfect.17 $project_relation"


#sourcelist_desinfect_set_nomal2017 [chroot_dir]
function sourcelist_desinfect_set_nomal2017() {
echo -n "build normal source.list ... "
#$1 = chroot directory

sourcelist="$1/etc/apt/sources.list"


echo "#### Desinfe't 2017 ####" > "$sourcelist"
echo "" >> "$sourcelist"
echo "deb http://www.heise.de/ct/projekte/desinfect/ubuntu 2017 main" >> "$sourcelist"
echo "" >> "$sourcelist"
echo "" >> "$sourcelist"
echo "# #### Ubuntu 16.04 LTS (Xenial) ####" >> "$sourcelist"
echo "#" >> "$sourcelist"
echo "# deb http://archive.ubuntu.com/ubuntu xenial main restricted universe multiverse" >> "$sourcelist"
echo "# deb-src http://archive.ubuntu.com/ubuntu xenial main restricted universe multiverse" >> "$sourcelist"
echo "#" >> "$sourcelist"
echo "# deb http://security.ubuntu.com/ubuntu xenial-updates main restricted universe multiverse" >> "$sourcelist"
echo "# deb-src http://security.ubuntu.com/ubuntu xenial-updates main restricted universe multiverse" >> "$sourcelist"
echo "#" >> "$sourcelist"
echo "# deb http://security.ubuntu.com/ubuntu xenial-security main restricted universe multiverse" >> "$sourcelist"
echo "# deb-src http://security.ubuntu.com/ubuntu xenial-security main restricted universe multiverse" >> "$sourcelist"
echo "#" >> "$sourcelist"
echo "# ## This software is not part of Ubuntu, but is offered by third-party" >> "$sourcelist"
echo "# ## developers who want to ship their latest software." >> "$sourcelist"
echo "# deb http://extras.ubuntu.com/ubuntu xenial main" >> "$sourcelist"

echo "done"
}

#sourcelist_desinfect_set_extendet2017 [chroot_dir]
function sourcelist_desinfect_set_extendet2017() {
echo -n "build extendet source.list ... "

sourcelist="$1/etc/apt/sources.list"


echo "#### Desinfe't 2017 ####" > "$sourcelist"
echo "" >> "$sourcelist"
echo "deb http://www.heise.de/ct/projekte/desinfect/ubuntu 2017 main" >> "$sourcelist"
echo "" >> "$sourcelist"
echo "" >> "$sourcelist"
echo "#### Ubuntu 16.04 LTS (Xenial) ####" >> "$sourcelist"
echo "" >> "$sourcelist"
echo "deb http://archive.ubuntu.com/ubuntu xenial main restricted universe multiverse" >> "$sourcelist"
echo "deb-src http://archive.ubuntu.com/ubuntu xenial main restricted universe multiverse" >> "$sourcelist"
echo "" >> "$sourcelist"
echo "deb http://security.ubuntu.com/ubuntu xenial-updates main restricted universe multiverse" >> "$sourcelist"
echo "deb-src http://security.ubuntu.com/ubuntu xenial-updates main restricted universe multiverse" >> "$sourcelist"
echo "" >> "$sourcelist"
echo "deb http://security.ubuntu.com/ubuntu xenial-security main restricted universe multiverse" >> "$sourcelist"
echo "deb-src http://security.ubuntu.com/ubuntu xenial-security main restricted universe multiverse" >> "$sourcelist"
echo "" >> "$sourcelist"
echo "## This software is not part of Ubuntu, but is offered by third-party" >> "$sourcelist"
echo "## developers who want to ship their latest software." >> "$sourcelist"
echo "deb http://extras.ubuntu.com/ubuntu xenial main" >> "$sourcelist"

echo "done"
}

#os_update-desinfect.17 [chroot_dir]
function os_update-desinfect.17() {
#$1 = chroot directory

chroot_dir="$1"

#call main os_update from debian
os_update-debian "$chroot_dir"

echo "update virus definitions ... "

#Avast Avira
{
echo "Avira ..."
#chroot "$chroot_dir" /bin/bash --login -c ". /tmp/env.sh; /AntiVirUpdate/avupdate" | grep -v " -> "
chroot_sh "$chroot_dir" "/AntiVirUpdate/avupdate" | grep -v " -> "
echo "Avira done"
}

#Clam AV
{
echo "ClamAV..."
#chroot "$chroot_dir" /bin/bash --login -c ". /tmp/env.sh; freshclam" > /dev/null
chroot_sh "$chroot_dir" "freshclam" > /dev/null
rm -f "$chroot_dir/var/lib/clamav/daily.cld"
echo "ClamAV done"
}

#Eset AV
{
echo "Eset AV ..."
tmp_file_23421="`mktemp`"
cat "$chroot_dir/etc/opt/eset/esets/esets.cfg" | grep -v "av_update_username" | grep -v "av_update_password" > "$tmp_file_23421"
cat "$tmp_file_23421" > "$chroot_dir/etc/opt/eset/esets/esets.cfg"
chroot "$chroot_dir" /bin/bash -c "/usr/bin/esetrand" >> "$chroot_dir/etc/opt/eset/esets/esets.cfg"

av_eaet_timeout=300
echo "set timeout: $((av_eaet_timeout/60))min"
tmp_var_3092="`chroot "$chroot_dir" /bin/bash -c "/opt/desinfect/conky_info.sh eset"`"

#eig. update routine
#chroot "$chroot_dir" /bin/bash -c "/etc/init.d/esets restart"
chroot_sh "$chroot_dir" "/etc/init.d/esets restart"
sleep 2
#chroot "$chroot_dir" /bin/bash --login -c "/opt/eset/esets/sbin/esets_daemon --update"
chroot_sh "$chroot_dir" "/opt/eset/esets/sbin/esets_daemon --update"

#warten auf daemon update ...
echo "wait $((av_eaet_timeout/60))min for Eset AV update"
while [ "`chroot "$chroot_dir" /bin/bash -c "/opt/desinfect/conky_info.sh eset"`" == "$tmp_var_3092" ]; do
sleep 10
av_eaet_timeout=$((av_eaet_timeout-10))
[ $av_eaet_timeout -gt 0 ] || tmp_var_3092=
done

sleep 4

#chroot "$chroot_dir" /bin/bash -c "/etc/init.d/esets stop"
chroot_sh "$chroot_dir" "/etc/init.d/esets stop"

cat "$tmp_file_23421" > "$chroot_dir/etc/opt/eset/esets/esets.cfg"

rm "$tmp_file_23421"
tmp_file_23421=
tmp_var_3092=
echo "Eset AV done"
}

#Sophos
{
echo "Sophos..."
#chroot "$chroot_dir" /bin/bash --login -c "/opt/sophos-av/bin/savupdate -v3"
chroot_sh "$chroot_dir" "/opt/sophos-av/bin/savupdate -v3"
chroot_sh "$chroot_dir" "/opt/sophos-av/bin/savdstatus --version"
#chroot "$chroot_dir" /bin/bash -c "/opt/sophos-av/bin/savupdate -v3 -a"
echo "Sophos done"
}

#F-Secure
{
echo "F-Secure..."
chroot_sh "$chroot_dir" "/etc/init.d/fsaua start"
chroot_sh "$chroot_dir" "/etc/init.d/fsupdate stop"
( sleep 1m; chroot_sh "$chroot_dir" "/etc/init.d/fsaua start" ) &
chroot_sh "$chroot_dir" "/opt/f-secure/fssp/bin/dbupdate_lite" && echo "Update Success"
sleep 1m
chroot_sh "$chroot_dir" "/etc/init.d/fsaua stop"
chroot_sh "$chroot_dir" "/etc/init.d/fsupdate stop"
echo "F-Secure done"
}

echo "update virus definitions done"
}
function os_update() { os_update-desinfect.17 $@; }

#proxy_enable-desinfect.17 [chroot_dir] [proxy_host] [proxy_port]
function proxy_enable-desinfect.17() {

proxy_enable-debian $1 $2 $3

echo "enable proxy for desinfect's av ... "

chroot_dir="$1"
proxy_host="$2"
proxy_port="$3"
tmp_file_344532="`mktemp`"

#Avast AntiVirus
if [ -f "$chroot_dir/AntiVirUpdate/avupdate" ]; then
echo "Avast AntiVirus: Found"
sed -i "s/--skip-master-file/--skip-master-file --proxy-host=$proxy_host --proxy-port=$proxy_port/g" "$chroot_dir/AntiVirUpdate/avupdate"
sed -i "s/--proxy-host=$proxy_host --proxy-port=$proxy_port --proxy-host=$proxy_host --proxy-port=$proxy_port/--proxy-host=$proxy_host --proxy-port=$proxy_port/g" "$chroot_dir/AntiVirUpdate/avupdate"
else
eco "Avast AntiVirus: NOT Found"
fi

#Eset AV
if [ -f "$chroot_dir/etc/opt/eset/esets/esets.cfg" ]; then
echo "Eset AV: Found"
cat "$chroot_dir/etc/opt/eset/esets/esets.cfg" | grep -v "proxy_addr" | grep -v "proxy_port" > "$tmp_file_344532"
rm "$chroot_dir/etc/opt/eset/esets/esets.cfg"
cp "$tmp_file_344532" "$chroot_dir/etc/opt/eset/esets/esets.cfg"

echo "proxy_addr = \"$proxy_host\"" >> "$chroot_dir/etc/opt/eset/esets/esets.cfg"
echo "proxy_port = $proxy_port" >> "$chroot_dir/etc/opt/eset/esets/esets.cfg"
else
eco "Eset AV: NOT Found"
fi

#ClamAV
if [ -f "$chroot_dir/etc/clamav/freshclam.conf" ]; then
echo "ClamAV: Found"
cat "$chroot_dir/etc/clamav/freshclam.conf" | grep -v "HTTPProxyServer" | grep -v "HTTPProxyPort" > "$tmp_file_344532"
rm "$chroot_dir/etc/clamav/freshclam.conf"
cp "$tmp_file_344532" "$chroot_dir/etc/clamav/freshclam.conf"

echo "HTTPProxyServer $proxy_host" >> "$chroot_dir/etc/clamav/freshclam.conf"
echo "HTTPProxyPort $proxy_port" >> "$chroot_dir/etc/clamav/freshclam.conf"
else
eco "ClamAV: NOT Found"
fi

#Sophos
if [ -f ""$chroot_dir/opt/sophos-av/etc/savd.cfg"" ]; then
echo "Sophos: Found"
echo "<Source>sophos:</Source><Proxy><Address>http://$proxy_host:$proxy_port</Proxy></Address>" >> "$chroot_dir/opt/sophos-av/etc/savd.cfg"
else
eco "Sophos: NOT Found"
fi

#F-Secure
if [ -f "$chroot_dir/opt/f-secure/fsaua/fsaua_config.template" ]; then
echo "F-Secure: Found"
echo "enable_fsma=no" >> "$chroot_dir/opt/f-secure/fsaua/fsaua_config.template"
echo "update_servers=http://fsbwserver-direct.f-secure.com" >> "$chroot_dir/opt/f-secure/fsaua/fsaua_config.template"
echo "update_proxies=http://$proxy_host:$proxy_port" >> "$chroot_dir/opt/f-secure/fsaua/fsaua_config.template"
echo "http_proxies=http://$proxy_host:$proxy_port" >> "$chroot_dir/opt/f-secure/fsaua/fsaua_config.template"
cat "$chroot_dir/opt/f-secure/fsaua/fsaua_config.template" > "$chroot_dir/etc/opt/f-secure/fsaua/fsaua_config"
else
eco "F-Secure: NOT Found"
fi


rm "$tmp_file_344532"
tmp_file_344532=

echo "done"
}
function proxy_enable() { proxy_enable-desinfect.17 $@; }

#tools_add-desinfect.17 [chroot_dir] [tools_list]
function tools_add-desinfect.17() {
#$1 = chroot directory
chroot_dir="$1"
tools_list="$2"

sourcelist_desinfect_set_extendet2017 "$chroot_dir"
tools_add-debian "$chroot_dir" "$tools_list"
sourcelist_desinfect_set_nomal2017 "$chroot_dir"
}
function tools_add() { tools_add-desinfect.17 $@; }


function project_mods-desinfect.17() {
#config xrdp to start xfce
[ -d "$chroot_path/etc/xrdp/" ] && {
echo '#!/bin/sh' > "$chroot_path"/etc/xrdp/startwm.sh
echo "export LANG=\"de_DE.UTF-8\"" >> "$chroot_path"/etc/xrdp/startwm.sh
echo "startxfce4" >> "$chroot_path"/etc/xrdp/startwm.sh
}
}
function project_mods() { project_mods-desinfect.17 $@; }

10
src/proj/ubuntu Executable file
View File

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

####################################
##### Base Template U B U N T U ####
####################################
# . -> debian
source <LIBDIR>/proj/debian
project_relation="ubuntu $project_relation"

8
src/proj/ubuntu.14.04 Executable file
View File

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

#ubuntu.14.04
# . -> ubuntu -> debian
source <LIBDIR>/proj/ubuntu
project_relation="ubuntu.14.04 $project_relation"

8
src/proj/ubuntu.16.04 Executable file
View File

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

#ubuntu.16.04
# . -> ubuntu -> debian
source <LIBDIR>/proj/ubuntu
project_relation="ubuntu.16.04 $project_relation"

0
src/pxe/pxe.cfg Normal file
View File

310
src/remaster.sh Executable file
View File

@ -0,0 +1,310 @@
#!/bin/bash
#@version 2.1.0
#@autor 6543@obermui.de
#@date 2019-09-20
#@licence GNUv3

#####################################################################################
################## S e t t i n g s ##################################################
#####################################################################################

#set functions
[ -d "<LIBDIR>" ] || {
echo "ERROR Librarys not found"
exit 1
}

#read main setting
if [ -f "<ROOTDIR>/etc/remaster/config.cfg" ]; then
source "<ROOTDIR>/etc/remaster/config.cfg"
else
if [ -f "<ROOTDIR>/etc/remaster/config.sample.cfg" ]; then
source "<ROOTDIR>/etc/remaster/config.sample.cfg"
else
echo "ERROR config not found"
exit 1
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
}

#####################################################################################
################## H e l p & I n f o ##############################################
#####################################################################################


case $(echo $1 | tr -d '-') in
'') ;;
version|V)
echo Remaster 2.1.0
exit 0
;;
config|c)
if [ -f "$2" ]; then
source <LIBDIR>/func/clear_config
source "$2"
else
echo "ERROR Config \"$2\" not found"
exit 1
fi
else
;;
*)
echo 'Remaster update Live Systems'
echo ' more information at: https://github.com/6543/remaster/'
echo ''
echo ' --version|-V show current version'
echo ' --config|-c <config> run remaster with custom config'
exit 0
;;
esac


#####################################################################################
################## F u n c t i o n s ################################################
#####################################################################################

### Error Handlings ###

#check_config
source <LIBDIR>/func/check_config

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

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

#check_user
source <LIBDIR>/func/check_user

#check_dependency
# -> 0 | -> 16
source <LIBDIR>/func/check_dependency

#check_update
source <LIBDIR>/func/check_update

### Workspace ###

#workspace_erase [workspace_path]
source <LIBDIR>/func/workspace_erase


### Filesystem ###

#filesystem_extract [filesystem_img_source] [chroot_path]
source <LIBDIR>/func/filesystem_extract

#filesystem_pack [chroot_path] [filesystem_img_destination]
source <LIBDIR>/func/filesystem_pack

#filesystem_get_type [dir]
#(String)-> ext4, ext2, btfs, fuse, ...
source <LIBDIR>/func/filesystem_get_type

### ISO ###

#iso_extract [iso_source] [iso_extr_dir]
source <LIBDIR>/func/iso_extract

#iso_create [chroot_path] [iso_extr_dir] [iso_aim] [iso_lable]
source <LIBDIR>/func/iso_create

### chroot ###

#chroot_initial [chroot_dir]
source <LIBDIR>/func/chroot_initial

#chroot_clean [chroot_dir]
source <LIBDIR>/func/chroot_clean

#chroot_umount [chroot_dir]
source <LIBDIR>/func/chroot_umount

#chroot_is_mounted [chroot_dir]
#(Boolean)-> true | false
source <LIBDIR>/func/chroot_is_mounted

#chroot_sh [chroot_dir] [command]
source <LIBDIR>/func/chroot_sh

####################################
### Workaround - set Project
source <LIBDIR>/proj/desinfect.17
####################################

###########################################################
################# P r o c e s s ... #######################
###########################################################

#Start LOG
tail -f "$log_file" --pid="$$" &

chroot_path="`mktemp -d`"
iso_extr_dir="`mktemp -d`"

echo "Remaster LOG `date '+%Y-%m-%d'`" > "$log_file"
echo "MODE: renew" >> "$log_file"
echo "HOST: `hostname`" >> "$log_file"
echo >> "$log_file"

echo "### S e t t i n g s ###" >> "$log_file"
echo "#CD/DVD" >> "$log_file"
echo "iso_source=\"$iso_source\"" >> "$log_file"
echo "iso_aim=\"$iso_aim\"" >> "$log_file"
echo "iso_lable=\"$iso_lable\"" >> "$log_file"
echo >> "$log_file"

echo "#Filesystem (for pxe)" >> "$log_file"
echo "squashfs_path=\"$squashfs_path\"" >> "$log_file"
echo >> "$log_file"

echo "#Network" >> "$log_file"
echo "proxy_host=\"$proxy_host\"" >> "$log_file"
echo "proxy_port=\"$proxy_port\"" >> "$log_file"
echo "domain=\"$domain\"" >> "$log_file"
echo "nameserver=\"$nameserver\"" >> "$log_file"
echo >> "$log_file"

echo "#remaster_script" >> "$log_file"
echo "project=\"$project\"" >> "$log_file"
echo >> "$log_file"

echo "log_file=\"$log_file\""
echo "log_mail_aim=\"$log_mail_aim\""
echo "log_mail_subject=\"$log_mail_subj >> "$log_file"ect\""
echo ""

echo "#Sonstiges" >> "$log_file"
echo "tools_list=\"$tools_list\"" >> "$log_file"
echo $'\n' >> "$log_file"

echo "### Enviroment ###"
echo "iso_extr_dir=\"$iso_extr_dir\"" >> "$log_file"
echo "chroot_path=\"$chroot_path\"" >> "$log_file"
#env >> "$log_file"
echo $'\n\n' >> "$log_file"

echo $'### R U N ... ###\n' >> "$log_file"

#1. Set and Check Enviroment
check_user >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

check_dependency >> "$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"

check_update >> "$log_file"

# 2. Entpacke ISO
iso_extract "$iso_source" "$iso_extr_dir" >> "$log_file"

# 3. Entpacken der Dateien des Live-Systems
filesystem_img="`find "$iso_extr_dir" -name filesystem.squashfs`"
[ -e "$filesystem_img" ] || {
echo "### ERROR ### Image \"$iso_source\" has no \"filesystem.squashfs\"" >> "$log_file"
on_exit 15 >> "$log_file"
}

filesystem_extract "$filesystem_img" "$chroot_path" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

# 4. Vorbereiten für chroot-Umgebung:

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

# 5. Setzen der Netzwerk-Einstellungen:
[ -n "$proxy_host" ] && {
proxy_enable "$chroot_path" "$proxy_host" "$proxy_port" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"
}

dns_set "$chroot_path" "$domain" "$nameserver" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

# 6. Updaten von Desinfec't:
os_update "$chroot_path" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

# 7. Installation optionaler Tools:

tools_add "$chroot_path" "$tools_list" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

#addo ClamAV to conky_info
sed -i 's/# ${color white}ClamAV/ ${color white}ClamAV/g' "$chroot_path/etc/skel/.conkyrc"

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

# 8. Manuelle Aktionen - deaktiviert

#echo "Now You Have TIME to do something MANUALY!"
#echo "enter in shell: #> chroot $chroot_path /bin/bash"
#chroot $chroot_path /bin/bash
#echo "Are You Finisch? Then Press [ENTER]"

project_mods

# 9. Umount - Chroot Umgebung auflösen

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

#Überprüfen ob alles ausgehängt wurde
[ "`chroot_is_mounted "$chroot_path"`" == "true" ] && {
echo "### ERROR ### Cant Unmount Chroot!" >> "$log_file"
on_exit 21 >> "$log_file"
}

# 10. Packen und Ersetzen der Dateien des Live-Systems
rm "$filesystem_img" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

filesystem_pack "$chroot_path" "$filesystem_img" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

# wenn iso gewünscht
[ "$iso_aim" != "" ] && {
iso_create "$chroot_path" "$iso_extr_dir" "$iso_aim" "$iso_lable" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"
}

# wenn filesystem gewünscht
[ "$squashfs_path" != "" ] && {
#wen bereits forhanden dann löschen
[ -f "$squashfs_path" ] && rm "$squashfs_path"
cp "$filesystem_img" "$squashfs_path" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"

chmod 666 "$squashfs_path"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"
}

chmod 666 "$iso_aim" "$filesystem_img" >> "$log_file"

workspace_erase "$iso_extr_dir/" "$chroot_path/" >> "$log_file"
error_level="$?"; [ "$error_level" != "0" ] && on_exit $error_level >> "$log_file"


on_exit 0

0
src/web/index.html Normal file
View File