Ceci est une ancienne révision du document !
Ceci n'est pas un arbre à palabre…
L'idée est de poser une sorte de tableau de post-it sous la forme d'un arbre virtuel partagé et accessible par le réseau WiFi uniquement local.
Une représentation d'arbre s'affiche dans le navigateur si on se connecte au SSID Paslarbre
Tous le monde peut écrire un post-it et le placer ou il veut sur le dessin, ils sont de couleur et leur édition est minimaliste.
Je pose simplement un Scrumblr qui est un logiciel libre distribué sous licence GPLv3 ayant pour objectif de fournir un tableau de post-it collaboratif en temps réel. Il s’agit de la solution logicielle qui propulse le service en ligne Framemo de Framasoft. Du point de vue utilisateur, seul un navigateur Web est nécessaire.
Dans un premier temps , le paslarbre sera laissé à lui même, chacun pourra réorganiser les postit comme il le veut, je vais voir à empêcher la suppression et garder l'historique pour l'animé plus tard.
après un sudo su
Fixer la partie réseau
echo "paslarbre">/etc/hostname && hostname paslarbre echo " 127.0.0.1i localhost www.paslarbre.local paslarbre.local paslarbre 192.168.4.1 www.paslarbre.local paslarbre.local paslarbre " > /etc/hosts cat <<EOF > /etc/network/interfaces source /etc/network/interfaces.d/* allow-hotplug eth0 iface eth0 inet dhcp auto lo iface lo inet loopback allow-hotplug wlan0 iface wlan0 inet static address 192.168.4.1 netmask 255.255.255.0 network 192.168.4.0 broadcast 192.168.4.255 EOF apt-get install dnsmasq iptables apt-get install avahi-daemon libnss-mdns echo "host=paslarbre domain=local" >> /etc/avahi/avahi-daemon.conf apt-get install npm apt-get install redis-server
Partie dnsmasq.conf
cat <<EOF > /etc/dnsmasq.conf interface=wlan0 # Use interface wlan0 listen-address=192.168.4.1 # Explicitly specify the address to listen on address=/#/192.168.4.1 # portail captif except-interface=eth0 # ne rien faire sur eth0 server=192.168.4.1 # Forward DNS requests local resolv-file=/etc/resolv.conf.portail dhcp-range=192.168.4.50,192.168.4.150,12h # Assign IP addresses with 12 hour lease time EOF
Partie /etc/resolv.conf.portail
echo "nameserver 192.168.4.1 nameserver 127.0.0.1" > /etc/resolv.conf.portail
Partie Scrumblr
sudo adduser --no-create-home --home /var/www/scrumblr --disabled-login --gecos "Scrumblr" scrumblr mkdir -p /var/www cd /var/www sudo git clone https://github.com/aliasaria/scrumblr.git sudo chown scrumblr -R /var/www/scrumblr cd /var/www/scrumblr npm install sudo su scrumblr -s /bin/bash git remote add fork https://github.com/ldidry/scrumblr/ git fetch fork git pull fork master exit
cat <<EOF [Unit] Description=Scrumblr service Documentation=https://github.com/aliasaria/scrumblr/ Requires=network.target Requires=redis-server.service After=network.target After=redis-server.service [Service] Type=simple User=scrumblr WorkingDirectory=/var/www/scrumblr ExecStart=/usr/bin/nodejs server.js --port 4242 ? [Install] WantedBy=multi-user.target EOF
On fabrique des règles pour rediriger les entrées des navigateurs sur le service 4242, plutot que d'utiliser un proxy genre ngninx, plus sophistiqué mais plus lourd
Nous gérerons donc tous les services derrière nodejs/scrumblr
cat <<EOF > /usr/local/bin/redirige_port.sh #!/bin/bash echo "1" > /proc/sys/net/ipv4/ip_forward /sbin/iptables -A PREROUTING -t nat -i eth0 -p tcp -m multiport --dport 80:443 -j REDIRECT --to-ports 4242 /sbin/iptables -A PREROUTING -t nat -i wlan0 -p tcp -m multiport --dport 80:443 -j REDIRECT --to-ports 4242 /sbin/iptables -A FORWARD -p tcp -d 192.168.4.1 --dport 4242 -j ACCEPT /sbin/iptables -A POSTROUTING -t nat -j MASQUERADE EOF chmod 755 /usr/local/bin/redirige_port.sh
On demarre le tout
/usr/local/bin/redirige_port.sh iptables-save -c > /etc/iptables-save # a rappeler par iptables-restore systemctl enable hostapd systemctl start hostapd systemctl enable dnsmasq systemctl start dnsmasq systemctl enable scrumblr systemctl start scrumblr
Apres:
Voici le paslarbre à décompresser en place /www/ :scrumblr.tgz
j'ai aussi un crontab -e avec
0 * * * * /var/www/scrumblr/bin/extrait_base.sh # sauvegade scrumblr paslarbre si necessaire
pour sauvegarder les paslarbres en cours de croissance