Initial Scripts Run
Signed-off-by: Georg <georg@lysergic.dev>
This commit is contained in:
parent
28cefabe61
commit
31c0d40071
1
scripts/README.md
Normal file
1
scripts/README.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
This contains scripts which are generally called manually or through cronjobs. Scripts which serve integrated purposese, i.e. init scripts, are to be found in the respective service directories.
|
1
scripts/bash/README.md
Normal file
1
scripts/bash/README.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
Contains scripts desgined to be executed through the Bourne Again Shell (#!/bin/bash).
|
46
scripts/bash/pdns_init_zone
Normal file
46
scripts/bash/pdns_init_zone
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
PDNSGROUP="pdns"
|
||||||
|
|
||||||
|
if id -nG $(id -un) | grep -qw "$PDNSGROUP"; then
|
||||||
|
|
||||||
|
if [ $# -eq 0 ] || [ $1 == "help" ] || [ $1 == "h" ] || [ $1 == "-h" ] || [ $1 == "-help" ] || [ $1 == "--help" ]; then
|
||||||
|
echo "======================================================="
|
||||||
|
echo "This script will create and secure a new zone in the Lysergic PowerDNS cluster."
|
||||||
|
echo "Please run it by specifying the desired domain name as an argument."
|
||||||
|
echo "Syntax: $ bash domain.sh example.com"
|
||||||
|
echo "Warning: No syntax check will be performed. Make sure you type the domain name exactly right or you'll cause a deep fucking mess."
|
||||||
|
echo "======================================================="
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
else
|
||||||
|
echo "You do not belong to the group $PDNSGROUP and hence are not allowed to run this program."
|
||||||
|
echo "Assign yourself to the group or contact someone who is authorized to do so."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
DOMAIN=$1
|
||||||
|
NS1="ns1.3zy.de"
|
||||||
|
NS2="ns2.3zy.de"
|
||||||
|
NS3="ns3.3zy.de"
|
||||||
|
|
||||||
|
echo "==================================================="
|
||||||
|
echo "===== CREATING ZONE FOR DOMAIN $DOMAIN ====="
|
||||||
|
echo "==================================================="
|
||||||
|
/usr/bin/pdnsutil create-zone $DOMAIN $NS1
|
||||||
|
#/usr/bin/pdnsutil add-record $DOMAIN . SOA '$NS1 system.lysergic.dev 1 010800 3600 604800 3600'
|
||||||
|
#/usr/bin/pdnsutil add-record $DOMAIN . NS $NS1
|
||||||
|
/usr/bin/pdnsutil add-record $DOMAIN . NS $NS2
|
||||||
|
/usr/bin/pdnsutil add-record $DOMAIN . NS $NS3
|
||||||
|
echo "==================================================="
|
||||||
|
echo "================= ENABLING DNSSEC ================="
|
||||||
|
echo "==================================================="
|
||||||
|
/usr/bin/pdnsutil secure-zone $DOMAIN
|
||||||
|
/usr/bin/pdnsutil set-nsec3 $DOMAIN '1 0 1 ab'
|
||||||
|
/usr/bin/pdnsutil rectify-zone $DOMAIN
|
||||||
|
echo "==================================================="
|
||||||
|
/usr/bin/pdnsutil show-zone $DOMAIN
|
||||||
|
echo "==================================================="
|
||||||
|
/usr/bin/pdnsutil list-zone $DOMAIN
|
||||||
|
echo "==================================================="
|
16
scripts/bash/restic_run
Normal file
16
scripts/bash/restic_run
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
#/usr/bin/echo Executing Restic S3 Backup for $(hostname -f)
|
||||||
|
export RESTIC_REPOSITORY="s3:https://$S3HOST/$S3BUCKET"
|
||||||
|
export RESTIC_PASSWORD_FILE="/etc/restic/.sec"
|
||||||
|
export AWS_ACCESS_KEY_ID="$S301"
|
||||||
|
export AWS_SECRET_ACCESS_KEY="$S302"
|
||||||
|
export RESTIC_CACHE_DIR="/opt/restic/cache"
|
||||||
|
EXCLUDE=".restic.excludes"
|
||||||
|
/usr/bin/restic --verbose backup --exclude-file="/etc/$EXCLUDE" /etc
|
||||||
|
echo "EXIT $?"
|
||||||
|
/usr/bin/restic --verbose backup --exclude-file="/home/$EXCLUDE" /home
|
||||||
|
echo "EXIT $?"
|
||||||
|
/usr/bin/restic --verbose backup --exclude-file="/opt/$EXCLUDE" /opt
|
||||||
|
echo "EXIT $?"
|
||||||
|
/usr/bin/restic --verbose backup --exclude-file="/srv/$EXCLUDE" /srv
|
||||||
|
echo "EXIT $?"
|
1
scripts/perl/README.md
Normal file
1
scripts/perl/README.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
Contains scripts designed to be executed through Perl interpreters (#!/bin/perl).
|
34
scripts/perl/botproc.pl
Normal file
34
scripts/perl/botproc.pl
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
#!/usr/bin/perl
|
||||||
|
|
||||||
|
# Work in progress.
|
||||||
|
# Requires botproc.ini.
|
||||||
|
|
||||||
|
use Config::Tiny;
|
||||||
|
use Net::OpenSSH;
|
||||||
|
use warnings;
|
||||||
|
use strict;
|
||||||
|
#use feature qw(say);
|
||||||
|
|
||||||
|
my $config = Config::Tiny->new;
|
||||||
|
$config = Config::Tiny->read( 'botproc.ini' );
|
||||||
|
|
||||||
|
foreach my $section (keys %{$config}) {
|
||||||
|
my $host = "$section";
|
||||||
|
my $OS = $config->{$section}->{OS};
|
||||||
|
#print 'The OS of ', $host, ' is ', $OS, "\n";
|
||||||
|
my $user = $config->{$section}->{User};
|
||||||
|
my $keyname = $config->{$section}->{Key};
|
||||||
|
my $keypath = "/home/georg/.ssh/" . $keyname;
|
||||||
|
my $port = $config->{$section}->{Port};
|
||||||
|
print 'Connecting to ', $host, ':', $port, ' as ', $user, ' using key ', $keyname, "\n";
|
||||||
|
my $ssh = Net::OpenSSH->new($host, user => $user, port => $port, key_path => $keypath);
|
||||||
|
$ssh->error and
|
||||||
|
die "FATAL: ", $ssh->error;
|
||||||
|
$ssh->system("uname -a") or
|
||||||
|
die "Remote command failed: ", $ssh->error;
|
||||||
|
my ($df, $err) = $ssh->pipe_out("df -h /") or
|
||||||
|
die "df query failed: " . $ssh->error;
|
||||||
|
print "Root Partition:\n";
|
||||||
|
while (<$df>) { print }
|
||||||
|
close $df;
|
||||||
|
}
|
1
scripts/sh/README.md
Normal file
1
scripts/sh/README.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
Contains scripts desgined to be executed through the Bourne Shell or compatible derivates (#!/bin/sh).
|
Loading…
Reference in New Issue
Block a user