Projet

Général

Profil

Autoinstall OpenBSD !

  • What ?

You want to build a full automated OpenBSD in 3 minuts, here is the cookbook.
I used it to deploy various PC Engines APU routers/firewalls.

  • How ?

PXE Boot from the OpenBSD Builder

Packages

pkg_add bash colorls curl git gmake gnuwatch go jq python-3.6

PXE Interface

builder# cat /etc/hostname.em1                                                                                                                                         
172.16.16.254/24 description "PXE"

dhcpd

    filename "auto_install";
    next-server 172.16.16.254;
subnet 172.16.16.0 netmask 255.255.255.0 {
    range 172.16.16.1 172.16.16.2;
    option subnet-mask 255.255.255.0;
    option broadcast-address 172.16.16.255;
    option routers 172.16.16.254;
    }
echo "dhcpd_flags=em1">> /etc/rc.conf.local

PXE

mkdir -p /tftp/etc && chown _tftpd:_tftpd /tftp
cd /tftp
ftp http://mirrors.ircam.fr/pub/OpenBSD/6.5/amd64/pxeboot
ftp http://mirrors.ircam.fr/pub/OpenBSD/6.5/amd64/bsd.mp
ln -s pxeboot auto_install
ln -s bsd.rd bsd

 echo "
  stty com0 115200
  boot bsd
  " > /tftp/etc/boot.conf

 echo 'tftpd_flags="-4 /tftp"' >> /etc/rc.conf.local
 /etc/rc.d/dhcpd start
 /etc/rc.d/tftpd start

Copy sources

$ cd /var/www/htdocs
$ mkdir -p pub/OpenBSD/6.5/amd64/
$ cd pub/OpenBSD/6.5/amd64/
$ ftp 'ftp://ftp.nluug.nl/pub/OpenBSD/6.5/amd64/*'
signify -C -p /etc/signify/openbsd-65-base.pub -x SHA256.sig

/etc/httpd.conf

server "*" {
        listen on * port 80
        directory auto index
}

builder

#!/usr/local/bin/bash

#####################################
# Builder - v1.0
#####################################

echo "=========================================="
echo "=  OpenBSD Configuration builder - V1.1  ="
echo "=  sacha at aquilenet.fr -=o=- 20190722  ="
echo "=========================================="

BPATH="/builder"
SKEL="$BPATH/skel"
WWW="$BPATH/www"
TGZ="$BPATH/siteXX.tgz"
VERSION="$(uname -r)"
VER="$(uname -r |tr -d '.')"

ok="n"
until [ $ok == "o" ]; do

read -p "Nom  du site: " SITE
#read -p "Departement: " DEP
read -p "Code Postal: " CP
read -p "infos OSM:" OSM
read -p "pppoe user: " PPPOEU
read -p "pppoe pass: " PPPOEP

DEP=${CP:0:2}

echo "----------------------------------"
echo "Site              : $SITE"
echo "Departement       : $DEP"
echo "Code Postal       : $CP"
echo "Infos OSM         : $OSM"
echo "pppoe user        : $PPPOEU"
echo "pppoe pass        : $PPPOEP"
read -p "ok ? (o/n):" ok
done


SITEPATH="$BPATH/site/$SITE"

mkdir -p $SITEPATH/{root,etc,var/unbound/etc/,home,usr/local/bin}

cp -R $SKEL/* $SITEPATH/

#-------------------
#  myname 
#-------------------
echo "cerbere.$SITE.mydomain.fr" > $SITEPATH/etc/myname

#-------------------
#  dhcpd.conf
#-------------------
sed -e "s/DEP/$DEP/g" -e "s/SITE/$SITE/g"  $SKEL/etc/dhcpd.conf > $SITEPATH/etc/dhcpd.conf

#-------------------
#  hostname.pppoe0
#-------------------
sed -e "s/PPPOEU/$PPPOEU/g" -e "s/PPPOEP/$PPPOEP/g" $SKEL/etc/hostname.pppoe0 > $SITEPATH/etc/hostname.pppoe0

#-------------------
#  hostname.em2
#-------------------
sed -e "s/DEP/$DEP/g" $SKEL/etc/hostname.em2 > $SITEPATH/etc/hostname.em2

#-------------------
# unbound.conf
#-------------------
sed -e "s/DEP/$DEP/g" $SKEL/var/unbound/etc/unbound.conf > $SITEPATH/var/unbound/etc/unbound.conf

#-------------------
# prometheus geoash 
#-------------------

preposition=$(curl -Ls  "https://nominatim.openstreetmap.org/search/$CP $OSM?format=geojson&limit=1" |jq '.features[].geometry.coordinates| .[]')
position=$(echo $preposition | awk '{ for (i=NF; i>1; i--) printf("%s ",$i); print $1; }')
position=${position/ /,}
pregeoash=$(curl -Ls -w %{url_effective} -o /dev/null "http://geohash.org?q=$position")
geoash=${pregeoash#"http://geohash.org/"}
echo $geoash 
echo 'loc{geohash="$geoash",place="'$SITE'"} 10' > $SKEL/var/node_exporter/site_location.prom

#=====================================================================================================
# FIN

cd $SITEPATH && tar czvf  $TGZ/$SITE-site$VER.tgz .
rm -f $WWW/pub/OpenBSD/$VERSION/amd64/site.tgz
cp $TGZ/$SITE-site$VER.tgz $WWW/pub/OpenBSD/$VERSION/amd64/site$VER.tgz
builder|02:37:51|:/builder#ls -alh /builder/
total 32
drwxr-xr-x   6 root  wheel   512B Jul 22 02:37 .
drwxr-xr-x  15 root  wheel   512B Jul 21 18:24 ..
-rwxr-xr-x   1 root  wheel   1.8K Jul 22 02:32 builder.sh
lrwxr-xr-x   1 root  wheel    54B Jul 21 21:35 prometheus-build -> /home/sacha/go/src/github.com/prometheus/node_exporter
drwxr-xr-x   3 root  wheel   512B Jul 22 01:35 site
drwxr-xr-x   2 root  wheel   512B Jul 22 01:35 siteXX.tgz
drwxr-xr-x   7 root  wheel   512B Jul 22 01:30 skel
-rw-r--r--   1 root  wheel   1.2K Jul 22 01:07 test.tgz
lrwxr-xr-x   1 root  wheel     5B Jul 21 18:24 tftp -> /tftp
drwxr-xr-x   2 root  wheel   512B Jul 22 00:05 tmp
lrwxr-xr-x   1 root  wheel    16B Jul 21 18:24 www -> /var/www/htdocs/

/tmp/i/install.resp

printf '%s' 'yourpassword' | encrypt

install.conf

System hostname = cerbere
Which network interface do you wish to configure = em0
IPv4 address for em0 = dhcp
IPv6 address for em0 = none
Which network interface do you wish to configure = done
DNS domain name = SITE.mydomain.fr
DNS nameservers = none
Start sshd(8) by default = yes
Do you expect to run the X Window System = no
Change the default console to com0 = yes
Which speed should com0 use = 115200
Password for root account = $2b$10$V2wkDaLWTc0jmdPEMOW5VOPeg.nS9YbJOsj6LYZMrXdRiDCGoo6yu 
Password for user sacha = $2b$09$GWtR24VPpbZTdKyu5MZStOlyiNn2IKUy2trMI1rOJh1YjEjjNZKJa
Setup a user = sacha
Full name for user sacha = sacha
Public ssh key for user sacha = ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAgEA4y0oNSz3pvt2WVY/kBnlciuKoO8Nhxc+zsiaA7EOw+MRaysGZ6tymgMBpwuOCwMA8oBdgOzzlZOk7oIM1AUVjykrcrS3JPW1AOp0rjHJSDQKc8x2jBZTM8VIt1GoDTvfxoO6WTjaPJwwOxZlcS1zT6nW1y5IvO0Apz4MVKKNUZaZNa7x7MBfV59nXvWORddf3zJD/lHpK8WxfRVgYRJoLrNiqUe26GaDCKPge5fAmtgJMLvKGSzdsoCxtrY04tZw3fsdb/hJl7/Ov7dyX9NXJEU0dveFXZnLhYwKVhUa0CRxawCez202HInhp3LttYptwoX8jCjuRMlPL4+rhKtnDnze4Q81hU08xTV+TmNOzdPpVs0hY9wkQXyYrBlAGMjLQS0JQVL0hnI5FBB90GhwxzxzvD7HYLjipXXyOpdn/GZeSEG9ayjxc8kgXesT9Ogwo0GiXxPOjHz32NEJbDXXktMJZJuSqM6zD3KroB4qB6gLFZRnklqiedRTOMYJLYhC1MtdXqN/wpdlFQemYvCCGr44FJKLMDBYch4AiChVnr8VmnMzs+3ZE/3cP6tzDwgjotZc3uKN9nbEQt6SamlxW68P35ScODT1tED0JHep4qRxa5wQjYbLFQNwlWU1Vj7SxNDW0ahyZO5OZiuqtUjYzthhGECFqCtJwc/y2NTstFM= nobody@nowhere
Allow root ssh login = no
Which disk is the root disk = sd0
Use (W)hole disk MBR, whole disk (G)PT, (O)penBSD area or (E)dit = O 
Use (A)uto layout, (E)dit auto layout, or create (C)ustom layout = a 
Which disk do you wish to initialize = done
Location of sets = http 
HTTP proxy URL = none
HTTP Server = 172.16.16.254
Pathname to the sets = pub/OpenBSD/6.5/amd64 
Unable to connect using https. Use http instead = yes
Set name(s) = -x*
Set name(s) = -g*
Set name(s) = site65.tgz
Checksum test for site65.tgz failed. Continue anyway = yes
Unverified sets: site65.tgz. Continue without verification = yes
Set name(s) = done
Directory does not contain SHA256.sig. Continue without verification = yes
Location of sets = done
What timezone are you in = Europe/Paris
Exit to (S)hell, (H)alt or (R)eboot = R

build siteXX.tgz

exemple copier le site65.tgz dans www/pub/OpenBSD/6.5/amd64 puis ls -al > www/pub/OpenBSD/6.5/amd64/index.txt
script install: install.site https://undeadly.org/cgi?action=article;sid=20080111200305

install.site

usermod -G wheel sacha
echo 'node_exporter:\
        :tc=daemon: '>> /etc/login.conf
cap_mkdb /etc/login.conf
groupadd _node_exporter
useradd -u _node_exporter -c "Prometheus Node Exporter agent" -d /var/empty -s /sbin/nologin -L node_exporter _node_exporter

Sources

http://eradman.com/posts/autoinstall-openbsd.html
http://149.210.185.89/openbsd-autoinstall.html
http://www.openbsd.org/faq/faq4.html#site
https://man.openbsd.org/autoinstall.8