Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
F
freedombone
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Iterations
Wiki
Requirements
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Test cases
Artifacts
Deploy
Releases
Package registry
Container Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Service Desk
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Issue analytics
Insights
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Context Sensitive Group
freedombone
Commits
f8b22261
Commit
f8b22261
authored
8 years ago
by
Bob Mottram
Browse files
Options
Downloads
Patches
Plain Diff
Notify dependency
parent
e833123e
No related branches found
Branches containing commit
No related tags found
No related merge requests found
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
src/freedombone-image-customise
+506
-503
506 additions, 503 deletions
src/freedombone-image-customise
src/zeronetavahi
+1
-1
1 addition, 1 deletion
src/zeronetavahi
with
507 additions
and
504 deletions
src/freedombone-image-customise
+
506
−
503
View file @
f8b22261
...
@@ -107,40 +107,40 @@ MESH_INSTALL_DIR=/var/lib
...
@@ -107,40 +107,40 @@ MESH_INSTALL_DIR=/var/lib
AMNESIC
=
'no'
AMNESIC
=
'no'
enable_eatmydata_override
()
{
enable_eatmydata_override
()
{
chroot
$rootdir
apt-get
install
--no-install-recommends
-y
eatmydata
chroot
$rootdir
apt-get
install
--no-install-recommends
-y
eatmydata
if
[
-x
$rootdir
/usr/bin/eatmydata
]
&&
\
if
[
-x
$rootdir
/usr/bin/eatmydata
]
&&
\
[
!
-f
$rootdir
/etc/apt/apt.conf.d/95debian-edu-install-dpkg-eatmydata
]
;
then
[
!
-f
$rootdir
/etc/apt/apt.conf.d/95debian-edu-install-dpkg-eatmydata
]
;
then
echo
$"info: Adding apt config to call dpkg via eatmydata"
echo
$"info: Adding apt config to call dpkg via eatmydata"
printf
"#!/bin/sh
\n
exec eatmydata dpkg
\"\$
@
\"\n
"
\
printf
"#!/bin/sh
\n
exec eatmydata dpkg
\"\$
@
\"\n
"
\
>
$rootdir
/var/tmp/dpkg-eatmydata
>
$rootdir
/var/tmp/dpkg-eatmydata
chmod
755
$rootdir
/var/tmp/dpkg-eatmydata
chmod
755
$rootdir
/var/tmp/dpkg-eatmydata
cat
>
$rootdir
/etc/apt/apt.conf.d/95debian-edu-install-dpkg-eatmydata
<<
EOF
cat
>
$rootdir
/etc/apt/apt.conf.d/95debian-edu-install-dpkg-eatmydata
<<
EOF
Dir::Bin::dpkg "/var/tmp/dpkg-eatmydata";
Dir::Bin::dpkg "/var/tmp/dpkg-eatmydata";
EOF
EOF
else
else
echo
$"error: unable to find /usr/bin/eatmydata after installing the eatmydata package"
echo
$"error: unable to find /usr/bin/eatmydata after installing the eatmydata package"
fi
fi
}
}
disable_eatmydata_override
()
{
disable_eatmydata_override
()
{
for
override
in
\
for
override
in
\
/etc/apt/apt.conf.d/95debian-edu-install-dpkg-eatmydata
\
/etc/apt/apt.conf.d/95debian-edu-install-dpkg-eatmydata
\
/var/tmp/dpkg-eatmydata
;
do
/var/tmp/dpkg-eatmydata
;
do
echo
$"info: Removing apt config to call dpkg via eatmydata"
echo
$"info: Removing apt config to call dpkg via eatmydata"
if
[
-f
$rootdir$override
]
;
then
if
[
-f
$rootdir$override
]
;
then
rm
-f
$rootdir$override
rm
-f
$rootdir$override
else
else
echo
$"warning: missing
$rootdir$override
"
echo
$"warning: missing
$rootdir$override
"
fi
fi
done
done
sync
# Flush file buffers before continuing
sync
# Flush file buffers before continuing
}
}
set_apt_sources
()
{
set_apt_sources
()
{
NEW_MIRROR
=
"
$1
"
NEW_MIRROR
=
"
$1
"
COMPONENTS
=
"main"
COMPONENTS
=
"main"
cat
<<
EOF
> etc/apt/sources.list
cat
<<
EOF
> etc/apt/sources.list
deb
$NEW_MIRROR
$SUITE
$COMPONENTS
deb
$NEW_MIRROR
$SUITE
$COMPONENTS
deb-src
$NEW_MIRROR
$SUITE
$COMPONENTS
deb-src
$NEW_MIRROR
$SUITE
$COMPONENTS
...
@@ -150,12 +150,12 @@ EOF
...
@@ -150,12 +150,12 @@ EOF
}
}
configure_networking
()
{
configure_networking
()
{
if
[[
$DEBIAN_INSTALL_ONLY
!=
"no"
]]
;
then
if
[[
$DEBIAN_INSTALL_ONLY
!=
"no"
]]
;
then
return
return
fi
fi
if
[[
$GENERIC_IMAGE
==
"no"
]]
;
then
if
[[
$GENERIC_IMAGE
==
"no"
]]
;
then
echo
"# This file describes the network interfaces available on your system
echo
"# This file describes the network interfaces available on your system
# and how to activate them. For more information, see interfaces(5).
# and how to activate them. For more information, see interfaces(5).
# The loopback network interface
# The loopback network interface
...
@@ -165,290 +165,290 @@ iface lo inet loopback
...
@@ -165,290 +165,290 @@ iface lo inet loopback
# The primary network interface
# The primary network interface
auto eth0
auto eth0
iface eth0 inet static
iface eth0 inet static
address
$BOX_IP_ADDRESS
address
$BOX_IP_ADDRESS
netmask 255.255.255.0
netmask 255.255.255.0
gateway
$ROUTER_IP_ADDRESS
gateway
$ROUTER_IP_ADDRESS
dns-nameservers
$NAMESERVER1
$NAMESERVER2
dns-nameservers
$NAMESERVER1
$NAMESERVER2
# Example to keep MAC address between reboots
# Example to keep MAC address between reboots
#hwaddress ether B5:A2:BE:3F:1A:FE
#hwaddress ether B5:A2:BE:3F:1A:FE
# The secondary network interface
# The secondary network interface
#auto eth1
#auto eth1
#iface eth1 inet dhcp
#iface eth1 inet dhcp
# WiFi Example
# WiFi Example
#auto wlan0
#auto wlan0
#iface wlan0 inet dhcp
#iface wlan0 inet dhcp
# wpa-ssid
\"
essid
\"
# wpa-ssid
\"
essid
\"
# wpa-psk
\"
password
\"
# wpa-psk
\"
password
\"
# Ethernet/RNDIS gadget (g_ether)
# Ethernet/RNDIS gadget (g_ether)
# ... or on host side, usbnet and random hwaddr
# ... or on host side, usbnet and random hwaddr
# Note on some boards, usb0 is automaticly setup with an init script
# Note on some boards, usb0 is automaticly setup with an init script
#iface usb0 inet static
#iface usb0 inet static
# address 192.168.7.2
# address 192.168.7.2
# netmask 255.255.255.0
# netmask 255.255.255.0
# network 192.168.7.0
# network 192.168.7.0
# gateway 192.168.7.1"
>
$rootdir
/etc/network/interfaces
# gateway 192.168.7.1"
>
$rootdir
/etc/network/interfaces
hexarray
=(
1 2 3 4 5 6 7 8 9 0 a b c d e f
)
hexarray
=(
1 2 3 4 5 6 7 8 9 0 a b c d e f
)
a
=
${
hexarray
[
$RANDOM
%16]
}${
hexarray
[
$RANDOM
%16]
}
a
=
${
hexarray
[
$RANDOM
%16]
}${
hexarray
[
$RANDOM
%16]
}
b
=
${
hexarray
[
$RANDOM
%16]
}${
hexarray
[
$RANDOM
%16]
}
b
=
${
hexarray
[
$RANDOM
%16]
}${
hexarray
[
$RANDOM
%16]
}
c
=
${
hexarray
[
$RANDOM
%16]
}${
hexarray
[
$RANDOM
%16]
}
c
=
${
hexarray
[
$RANDOM
%16]
}${
hexarray
[
$RANDOM
%16]
}
d
=
${
hexarray
[
$RANDOM
%16]
}${
hexarray
[
$RANDOM
%16]
}
d
=
${
hexarray
[
$RANDOM
%16]
}${
hexarray
[
$RANDOM
%16]
}
e
=
${
hexarray
[
$RANDOM
%16]
}${
hexarray
[
$RANDOM
%16]
}
e
=
${
hexarray
[
$RANDOM
%16]
}${
hexarray
[
$RANDOM
%16]
}
sed
-i
"s|#hwaddress ether.*|hwaddress ether de:
$a
:
$b
:
$c
:
$d
:
$e
|g"
\
sed
-i
"s|#hwaddress ether.*|hwaddress ether de:
$a
:
$b
:
$c
:
$d
:
$e
|g"
\
$rootdir
/etc/network/interfaces
$rootdir
/etc/network/interfaces
fi
fi
sed
-i
"s/nameserver.*/nameserver
$NAMESERVER1
/g"
$rootdir
/etc/resolv.conf
sed
-i
"s/nameserver.*/nameserver
$NAMESERVER1
/g"
$rootdir
/etc/resolv.conf
sed
-i
"/nameserver
$NAMESERVER1
/a
\n
ameserver
$NAMESERVER2
"
$rootdir
/etc/resolv.conf
sed
-i
"/nameserver
$NAMESERVER1
/a
\n
ameserver
$NAMESERVER2
"
$rootdir
/etc/resolv.conf
if
[[
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
]]
;
then
if
[[
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
]]
;
then
# change the motd to show further install instructions
# change the motd to show further install instructions
echo
$"
echo
$"
.---. . .
.---. . .
| | |
| | |
|--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
|--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
| | (.-' (.-' ( | ( )| | | | )( )| | (.-'
| | (.-' (.-' ( | ( )| | | | )( )| | (.-'
' ' --' --' -' - -' ' ' -' -' -' ' - --'
' ' --' --' -' - -' ' ' -' -' -' ' - --'
Initial base install
Initial base install
Your system is not yet installed. To complete the process run the
Your system is not yet installed. To complete the process run the
following commands, then enter your details.
following commands, then enter your details.
sudo su
sudo su
${
PROJECT_NAME
}
menuconfig
${
PROJECT_NAME
}
menuconfig
"
>
$rootdir
/etc/motd
"
>
$rootdir
/etc/motd
else
else
echo
$"
echo
$"
.---. . .
.---. . .
| | |
| | |
|--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
|--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
| | (.-' (.-' ( | ( )| | | | )( )| | (.-'
| | (.-' (.-' ( | ( )| | | | )( )| | (.-'
' ' --' --' -' - -' ' ' -' -' -' ' - --'
' ' --' --' -' - -' ' ' -' -' -' ' - --'
Freedom in the Mesh
Freedom in the Mesh
"
>
$rootdir
/etc/motd
"
>
$rootdir
/etc/motd
fi
fi
}
}
configure_ssh
()
{
configure_ssh
()
{
sed
-i
"s/Port .*/Port
${
SSH_PORT
}
/g"
$rootdir
/etc/ssh/sshd_config
sed
-i
"s/Port .*/Port
${
SSH_PORT
}
/g"
$rootdir
/etc/ssh/sshd_config
if
[[
"
$SSH_PUBKEY
"
!=
"no"
]]
;
then
if
[[
"
$SSH_PUBKEY
"
!=
"no"
]]
;
then
if
[
!
-d
$rootdir
/home/
$MY_USERNAME
/.ssh
]
;
then
if
[
!
-d
$rootdir
/home/
$MY_USERNAME
/.ssh
]
;
then
mkdir
$rootdir
/home/
$MY_USERNAME
/.ssh
mkdir
$rootdir
/home/
$MY_USERNAME
/.ssh
fi
fi
echo
"
$SSH_PUBKEY
"
>
$rootdir
/home/
$MY_USERNAME
/.ssh/authorized_keys
echo
"
$SSH_PUBKEY
"
>
$rootdir
/home/
$MY_USERNAME
/.ssh/authorized_keys
chroot
$rootdir
chown
-R
$MY_USERNAME
:
$MY_USERNAME
/home/
$MY_USERNAME
/.ssh
chroot
$rootdir
chown
-R
$MY_USERNAME
:
$MY_USERNAME
/home/
$MY_USERNAME
/.ssh
sed
-i
's|PasswordAuthentication.*|PasswordAuthentication no|g'
$rootdir
/etc/ssh/sshd_config
sed
-i
's|PasswordAuthentication.*|PasswordAuthentication no|g'
$rootdir
/etc/ssh/sshd_config
echo
$"Using ssh public key:"
echo
$"Using ssh public key:"
echo
$SSH_PUBKEY
echo
$SSH_PUBKEY
echo
$'Password ssh authentication turned off'
echo
$'Password ssh authentication turned off'
fi
fi
}
}
admin_user_sudo
()
{
admin_user_sudo
()
{
echo
"
$MY_USERNAME
ALL=(ALL) ALL"
>>
$rootdir
/etc/sudoers
echo
"
$MY_USERNAME
ALL=(ALL) ALL"
>>
$rootdir
/etc/sudoers
}
}
create_generic_image
()
{
create_generic_image
()
{
if
[[
$DEBIAN_INSTALL_ONLY
!=
"no"
]]
;
then
if
[[
$DEBIAN_INSTALL_ONLY
!=
"no"
]]
;
then
return
return
fi
fi
if
[[
$GENERIC_IMAGE
==
"no"
]]
;
then
if
[[
$GENERIC_IMAGE
==
"no"
]]
;
then
return
return
fi
fi
if
[
$CONFIG_FILENAME
]
;
then
if
[
$CONFIG_FILENAME
]
;
then
if
[[
"
$CONFIG_FILENAME
"
==
*
"mesh.cfg"
*
]]
;
then
if
[[
"
$CONFIG_FILENAME
"
==
*
"mesh.cfg"
*
]]
;
then
VARIANT
=
"mesh"
VARIANT
=
"mesh"
fi
fi
fi
fi
# Don't install any configuration. This will be a base system
# Don't install any configuration. This will be a base system
if
[[
$VARIANT
!=
"mesh"
&&
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
]]
;
then
if
[[
$VARIANT
!=
"mesh"
&&
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
]]
;
then
CONFIG_FILENAME
=
CONFIG_FILENAME
=
else
else
touch
$rootdir
/root/.initial_mesh_setup
touch
$rootdir
/root/.initial_mesh_setup
fi
fi
# Stick with the existing login for mesh clients
# Stick with the existing login for mesh clients
if
[[
$VARIANT
==
"meshclient"
||
$VARIANT
==
"meshusb"
]]
;
then
if
[[
$VARIANT
==
"meshclient"
||
$VARIANT
==
"meshusb"
]]
;
then
return
return
fi
fi
# The presence of this file indicates that the initial
# The presence of this file indicates that the initial
# setup has not yet been completed
# setup has not yet been completed
touch
$rootdir
/home/
$MY_USERNAME
/.initial_setup
touch
$rootdir
/home/
$MY_USERNAME
/.initial_setup
chroot
$rootdir
chown
$MY_USERNAME
:
$MY_USERNAME
/home/
$MY_USERNAME
/.initial_setup
chroot
$rootdir
chown
$MY_USERNAME
:
$MY_USERNAME
/home/
$MY_USERNAME
/.initial_setup
touch
$rootdir
/root/.initial_setup
touch
$rootdir
/root/.initial_setup
cat
>>
$rootdir
/home/
$MY_USERNAME
/.bashrc
<<
EOF
cat
>>
$rootdir
/home/
$MY_USERNAME
/.bashrc
<<
EOF
# initial setup of the system
# initial setup of the system
if [ -f ~/.initial_setup ]; then
if [ -f ~/.initial_setup ]; then
clear
clear
echo "
echo "
.---. . .
.---. . .
| | |
| | |
|--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
|--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
| | (.-' (.-' ( | ( )| | | | )( )| | (.-'
| | (.-' (.-' ( | ( )| | | | )( )| | (.-'
' ' --' --' -' - -' ' ' -' -' -' ' - --'
' ' --' --' -' - -' ' ' -' -' -' ' - --'
Initial setup process
Initial setup process
Please enter your password a second time.
Please enter your password a second time.
"
"
sudo su
sudo su
fi
fi
EOF
EOF
echo
'# initial setup of the system'
>>
$rootdir
/root/.bashrc
echo
'# initial setup of the system'
>>
$rootdir
/root/.bashrc
echo
'if [ -f ~/.initial_setup ]; then'
>>
$rootdir
/root/.bashrc
echo
'if [ -f ~/.initial_setup ]; then'
>>
$rootdir
/root/.bashrc
echo
' if [ -f ~/login.txt ]; then'
>>
$rootdir
/root/.bashrc
echo
' if [ -f ~/login.txt ]; then'
>>
$rootdir
/root/.bashrc
echo
' NEW_USER_PASSWORD=$(printf `cat ~/login.txt`)'
>>
$rootdir
/root/.bashrc
echo
' NEW_USER_PASSWORD=$(printf `cat ~/login.txt`)'
>>
$rootdir
/root/.bashrc
echo
' else'
>>
$rootdir
/root/.bashrc
echo
' else'
>>
$rootdir
/root/.bashrc
echo
' ENTROPY=$(cat /proc/sys/kernel/random/entropy_avail)'
>>
$rootdir
/root/.bashrc
echo
' ENTROPY=$(cat /proc/sys/kernel/random/entropy_avail)'
>>
$rootdir
/root/.bashrc
echo
' if [ $ENTROPY -lt 500 ]; then'
>>
$rootdir
/root/.bashrc
echo
' if [ $ENTROPY -lt 500 ]; then'
>>
$rootdir
/root/.bashrc
ENTROPY_MESSAGE1
=
$'Initial setup process'
ENTROPY_MESSAGE1
=
$'Initial setup process'
ENTROPY_MESSAGE2
=
$'Password Generation'
ENTROPY_MESSAGE2
=
$'Password Generation'
ENTROPY_MESSAGE3
=
$'WARNING: The entropy available on this system is too low to generate a password.
\n\n
The installation process cannot continue.'
ENTROPY_MESSAGE3
=
$'WARNING: The entropy available on this system is too low to generate a password.
\n\n
The installation process cannot continue.'
echo
" dialog --backtitle
\"
${
ENTROPY_MESSAGE1
}
\"
--title
\"
${
ENTROPY_MESSAGE2
}
\"
--msgbox
\"
${
ENTROPY_MESSAGE3
}
\"
8 50"
>>
$rootdir
/root/.bashrc
echo
" dialog --backtitle
\"
${
ENTROPY_MESSAGE1
}
\"
--title
\"
${
ENTROPY_MESSAGE2
}
\"
--msgbox
\"
${
ENTROPY_MESSAGE3
}
\"
8 50"
>>
$rootdir
/root/.bashrc
echo
' exit'
>>
$rootdir
/root/.bashrc
echo
' exit'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
-n
' NEW_USER_PASSWORD="$(openssl rand -base64 30 | cut -c1-'
>>
$rootdir
/root/.bashrc
echo
-n
' NEW_USER_PASSWORD="$(openssl rand -base64 30 | cut -c1-'
>>
$rootdir
/root/.bashrc
echo
"
${
MINIMUM_PASSWORD_LENGTH
}
)
\"
"
>>
$rootdir
/root/.bashrc
echo
"
${
MINIMUM_PASSWORD_LENGTH
}
)
\"
"
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' echo "${NEW_USER_PASSWORD}" > ~/login.txt'
>>
$rootdir
/root/.bashrc
echo
' echo "${NEW_USER_PASSWORD}" > ~/login.txt'
>>
$rootdir
/root/.bashrc
echo
' clear'
>>
$rootdir
/root/.bashrc
echo
' clear'
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
NEW_LOGIN_PASSWORD_MESSAGE1
=
$'Your new login password is:'
NEW_LOGIN_PASSWORD_MESSAGE1
=
$'Your new login password is:'
NEW_LOGIN_PASSWORD_MESSAGE2
=
$'Use it whenever you wish to ssh into this system.'
NEW_LOGIN_PASSWORD_MESSAGE2
=
$'Use it whenever you wish to ssh into this system.'
NEW_LOGIN_PASSWORD_MESSAGE3
=
$'IMPORTANT: Please take a moment to enter the above password into a
\n
password manager or write it down somewhere.'
NEW_LOGIN_PASSWORD_MESSAGE3
=
$'IMPORTANT: Please take a moment to enter the above password into a
\n
password manager or write it down somewhere.'
PRESS_KEY_MESSAGE
=
$'Press any key to continue...'
PRESS_KEY_MESSAGE
=
$'Press any key to continue...'
echo
" echo
\"
${
NEW_LOGIN_PASSWORD_MESSAGE1
}
\"
"
>>
$rootdir
/root/.bashrc
echo
" echo
\"
${
NEW_LOGIN_PASSWORD_MESSAGE1
}
\"
"
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
' toilet "${NEW_USER_PASSWORD}"'
>>
$rootdir
/root/.bashrc
echo
' toilet "${NEW_USER_PASSWORD}"'
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
' echo " ${NEW_USER_PASSWORD}"'
>>
$rootdir
/root/.bashrc
echo
' echo " ${NEW_USER_PASSWORD}"'
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
" echo
\"
${
NEW_LOGIN_PASSWORD_MESSAGE2
}
\"
"
>>
$rootdir
/root/.bashrc
echo
" echo
\"
${
NEW_LOGIN_PASSWORD_MESSAGE2
}
\"
"
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
" echo
\"
${
NEW_LOGIN_PASSWORD_MESSAGE3
}
\"
"
>>
$rootdir
/root/.bashrc
echo
" echo
\"
${
NEW_LOGIN_PASSWORD_MESSAGE3
}
\"
"
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
' echo ""'
>>
$rootdir
/root/.bashrc
echo
" read -n1 -r -p
\"
${
PRESS_KEY_MESSAGE
}
\"
key"
>>
$rootdir
/root/.bashrc
echo
" read -n1 -r -p
\"
${
PRESS_KEY_MESSAGE
}
\"
key"
>>
$rootdir
/root/.bashrc
# change the password for the admin user
# change the password for the admin user
echo
-n
" echo
\"
${
MY_USERNAME
}
:"
>>
$rootdir
/root/.bashrc
echo
-n
" echo
\"
${
MY_USERNAME
}
:"
>>
$rootdir
/root/.bashrc
echo
'$(printf `cat ~/login.txt`)"|chpasswd'
>>
$rootdir
/root/.bashrc
echo
'$(printf `cat ~/login.txt`)"|chpasswd'
>>
$rootdir
/root/.bashrc
# update before continuing
# update before continuing
echo
" cd /root/
${
PROJECT_NAME
}
"
>>
$rootdir
/root/.bashrc
echo
" cd /root/
${
PROJECT_NAME
}
"
>>
$rootdir
/root/.bashrc
echo
" git stash"
>>
$rootdir
/root/.bashrc
echo
" git stash"
>>
$rootdir
/root/.bashrc
echo
" git pull"
>>
$rootdir
/root/.bashrc
echo
" git pull"
>>
$rootdir
/root/.bashrc
echo
" make install"
>>
$rootdir
/root/.bashrc
echo
" make install"
>>
$rootdir
/root/.bashrc
if
[[
$VARIANT
!=
"mesh"
&&
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
&&
$VARIANT
!=
"usb"
]]
;
then
if
[[
$VARIANT
!=
"mesh"
&&
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
&&
$VARIANT
!=
"usb"
]]
;
then
if
[[
$ONION_ONLY
==
"no"
]]
;
then
if
[[
$ONION_ONLY
==
"no"
]]
;
then
if
[[
$MINIMAL_INSTALL
==
"no"
]]
;
then
if
[[
$MINIMAL_INSTALL
==
"no"
]]
;
then
echo
"
${
PROJECT_NAME
}
menuconfig-full"
>>
$rootdir
/root/.bashrc
echo
"
${
PROJECT_NAME
}
menuconfig-full"
>>
$rootdir
/root/.bashrc
else
else
echo
"
${
PROJECT_NAME
}
menuconfig"
>>
$rootdir
/root/.bashrc
echo
"
${
PROJECT_NAME
}
menuconfig"
>>
$rootdir
/root/.bashrc
fi
fi
else
else
echo
"
${
PROJECT_NAME
}
menuconfig-onion"
>>
$rootdir
/root/.bashrc
echo
"
${
PROJECT_NAME
}
menuconfig-onion"
>>
$rootdir
/root/.bashrc
fi
fi
else
else
echo
" echo ''"
>>
$rootdir
/root/.bashrc
echo
" echo ''"
>>
$rootdir
/root/.bashrc
fi
fi
echo
' if [ "$?" = "0" ]; then'
>>
$rootdir
/root/.bashrc
echo
' if [ "$?" = "0" ]; then'
>>
$rootdir
/root/.bashrc
echo
" if [ -f ~/
${
PROJECT_NAME
}
-completed.txt ]; then"
>>
$rootdir
/root/.bashrc
echo
" if [ -f ~/
${
PROJECT_NAME
}
-completed.txt ]; then"
>>
$rootdir
/root/.bashrc
# Remove the initial setup files
# Remove the initial setup files
echo
' rm /root/.initial_setup'
>>
$rootdir
/root/.bashrc
echo
' rm /root/.initial_setup'
>>
$rootdir
/root/.bashrc
echo
" rm /home/
${
MY_USERNAME
}
/.initial_setup"
>>
$rootdir
/root/.bashrc
echo
" rm /home/
${
MY_USERNAME
}
/.initial_setup"
>>
$rootdir
/root/.bashrc
echo
" touch /root/.remove_
${
GENERIC_IMAGE_USERNAME
}
"
>>
$rootdir
/root/.bashrc
echo
" touch /root/.remove_
${
GENERIC_IMAGE_USERNAME
}
"
>>
$rootdir
/root/.bashrc
echo
' shred -zu ~/login.txt'
>>
$rootdir
/root/.bashrc
echo
' shred -zu ~/login.txt'
>>
$rootdir
/root/.bashrc
END_MESSAGE1
=
$'Congratulations!'
END_MESSAGE1
=
$'Congratulations!'
if
[[
$VARIANT
!=
"mesh"
&&
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
&&
$VARIANT
!=
"usb"
]]
;
then
if
[[
$VARIANT
!=
"mesh"
&&
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
&&
$VARIANT
!=
"usb"
]]
;
then
END_MESSAGE2
=
$'
\n
Your system has now installed
\n\n
The onion ssh service is at $SSH_ONION_HOSTNAME
\n\n
Press any key to reboot and begin using it'
END_MESSAGE2
=
$'
\n
Your system has now installed
\n\n
The onion ssh service is at $SSH_ONION_HOSTNAME
\n\n
Press any key to reboot and begin using it'
echo
' SSH_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_ssh/hostname)'
>>
$rootdir
/root/.bashrc
echo
' SSH_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_ssh/hostname)'
>>
$rootdir
/root/.bashrc
else
else
END_MESSAGE2
=
$'
\n
Your system has now installed
\n\n
Press any key to reboot and begin using it'
END_MESSAGE2
=
$'
\n
Your system has now installed
\n\n
Press any key to reboot and begin using it'
fi
fi
echo
" dialog --title '
$END_MESSAGE1
' --msgbox
\"
$END_MESSAGE2
\"
9 50"
>>
$rootdir
/root/.bashrc
echo
" dialog --title '
$END_MESSAGE1
' --msgbox
\"
$END_MESSAGE2
\"
9 50"
>>
$rootdir
/root/.bashrc
echo
' reboot'
>>
$rootdir
/root/.bashrc
echo
' reboot'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' else'
>>
$rootdir
/root/.bashrc
echo
' else'
>>
$rootdir
/root/.bashrc
echo
' key='
>>
$rootdir
/root/.bashrc
echo
' key='
>>
$rootdir
/root/.bashrc
echo
' while [[ $key != "x" ]]; do'
>>
$rootdir
/root/.bashrc
echo
' while [[ $key != "x" ]]; do'
>>
$rootdir
/root/.bashrc
INSTALL_FAIL_MESSAGE
=
$"Install failed. Press x to continue..."
INSTALL_FAIL_MESSAGE
=
$"Install failed. Press x to continue..."
echo
" read -n1 -r -p
\"
${
INSTALL_FAIL_MESSAGE
}
\"
key"
>>
$rootdir
/root/.bashrc
echo
" read -n1 -r -p
\"
${
INSTALL_FAIL_MESSAGE
}
\"
key"
>>
$rootdir
/root/.bashrc
echo
' done'
>>
$rootdir
/root/.bashrc
echo
' done'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' exit'
>>
$rootdir
/root/.bashrc
echo
' exit'
>>
$rootdir
/root/.bashrc
echo
'else'
>>
$rootdir
/root/.bashrc
echo
'else'
>>
$rootdir
/root/.bashrc
echo
' # Remove default account after install'
>>
$rootdir
/root/.bashrc
echo
' # Remove default account after install'
>>
$rootdir
/root/.bashrc
echo
" if [ -f /root/.remove_
${
GENERIC_IMAGE_USERNAME
}
]; then"
>>
$rootdir
/root/.bashrc
echo
" if [ -f /root/.remove_
${
GENERIC_IMAGE_USERNAME
}
]; then"
>>
$rootdir
/root/.bashrc
echo
" if [ -d /home/
${
GENERIC_IMAGE_USERNAME
}
]; then"
>>
$rootdir
/root/.bashrc
echo
" if [ -d /home/
${
GENERIC_IMAGE_USERNAME
}
]; then"
>>
$rootdir
/root/.bashrc
echo
" userdel -r
${
GENERIC_IMAGE_USERNAME
}
"
>>
$rootdir
/root/.bashrc
echo
" userdel -r
${
GENERIC_IMAGE_USERNAME
}
"
>>
$rootdir
/root/.bashrc
echo
" if [ -d /home/
${
GENERIC_IMAGE_USERNAME
}
]; then"
>>
$rootdir
/root/.bashrc
echo
" if [ -d /home/
${
GENERIC_IMAGE_USERNAME
}
]; then"
>>
$rootdir
/root/.bashrc
echo
" rm -rf /home/
${
GENERIC_IMAGE_USERNAME
}
"
>>
$rootdir
/root/.bashrc
echo
" rm -rf /home/
${
GENERIC_IMAGE_USERNAME
}
"
>>
$rootdir
/root/.bashrc
echo
" rm /root/.remove_
${
GENERIC_IMAGE_USERNAME
}
"
>>
$rootdir
/root/.bashrc
echo
" rm /root/.remove_
${
GENERIC_IMAGE_USERNAME
}
"
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
' fi'
>>
$rootdir
/root/.bashrc
echo
'fi'
>>
$rootdir
/root/.bashrc
echo
'fi'
>>
$rootdir
/root/.bashrc
}
}
continue_installation
()
{
continue_installation
()
{
# If a configuration file exists then run with it
# If a configuration file exists then run with it
# otherwise the interactive installer can be used
# otherwise the interactive installer can be used
# This is equivalent to installing freedombox-setup on freedombox
# This is equivalent to installing freedombox-setup on freedombox
if
[
$CONFIG_FILENAME
]
;
then
if
[
$CONFIG_FILENAME
]
;
then
if
[
${#
CONFIG_FILENAME
}
-gt
2
]
;
then
if
[
${#
CONFIG_FILENAME
}
-gt
2
]
;
then
cp
$CONFIG_FILENAME
$rootdir
/root/
$PROJECT_NAME
.cfg
cp
$CONFIG_FILENAME
$rootdir
/root/
$PROJECT_NAME
.cfg
cat
$rootdir
/root/
$PROJECT_NAME
.cfg
cat
$rootdir
/root/
$PROJECT_NAME
.cfg
chroot
"
$rootdir
"
su
-c
"
$PROJECT_NAME
-c /root/
$PROJECT_NAME
.cfg"
- root
chroot
"
$rootdir
"
su
-c
"
$PROJECT_NAME
-c /root/
$PROJECT_NAME
.cfg"
- root
fi
fi
fi
fi
}
}
atheros_wifi
()
{
atheros_wifi
()
{
firmware_filename
=
"open-ath9k-htc-firmware_1.3-1_all.deb"
firmware_filename
=
"open-ath9k-htc-firmware_1.3-1_all.deb"
firmware_hash
=
'5fea58ffefdf0ef15b504db7fbe3bc078c03e0d927bba64085e4b6f2546102f5'
firmware_hash
=
'5fea58ffefdf0ef15b504db7fbe3bc078c03e0d927bba64085e4b6f2546102f5'
firmware_url
=
"http://us.archive.trisquel.info/trisquel/pool/main/o/open-ath9k-htc-firmware/
$firmware_filename
"
firmware_url
=
"http://us.archive.trisquel.info/trisquel/pool/main/o/open-ath9k-htc-firmware/
$firmware_filename
"
firmware_tempfile
=
"/tmp/
$firmware_filename
"
firmware_tempfile
=
"/tmp/
$firmware_filename
"
wget
"
$firmware_url
"
-O
"
$rootdir$firmware_tempfile
"
wget
"
$firmware_url
"
-O
"
$rootdir$firmware_tempfile
"
downloaded_firmware_hash
=
$(
sha256sum
"
$rootdir$firmware_tempfile
"
|
awk
-F
' '
'{print $1}'
)
downloaded_firmware_hash
=
$(
sha256sum
"
$rootdir$firmware_tempfile
"
|
awk
-F
' '
'{print $1}'
)
if
[[
"
$downloaded_firmware_hash
"
==
"
$firmware_hash
"
]]
;
then
if
[[
"
$downloaded_firmware_hash
"
==
"
$firmware_hash
"
]]
;
then
chroot
"
$rootdir
"
dpkg
-i
"
$firmware_tempfile
"
chroot
"
$rootdir
"
dpkg
-i
"
$firmware_tempfile
"
else
else
echo
'WARNING: Atheros Wifi firmware hash does not match. The driver has not been installed.'
echo
'WARNING: Atheros Wifi firmware hash does not match. The driver has not been installed.'
fi
fi
}
}
configure_wifi
()
{
configure_wifi
()
{
if
[[
$VARIANT
==
"mesh"
||
$VARIANT
==
"meshclient"
||
$VARIANT
==
"meshusb"
]]
;
then
if
[[
$VARIANT
==
"mesh"
||
$VARIANT
==
"meshclient"
||
$VARIANT
==
"meshusb"
]]
;
then
return
return
fi
fi
if
[
-f
$WIFI_NETWORKS_FILE
]
;
then
if
[
-f
$WIFI_NETWORKS_FILE
]
;
then
chroot
"
$rootdir
"
${
PROJECT_NAME
}
-wifi
-i
$WIFI_INTERFACE
--networks
$WIFI_NETWORKS_FILE
chroot
"
$rootdir
"
${
PROJECT_NAME
}
-wifi
-i
$WIFI_INTERFACE
--networks
$WIFI_NETWORKS_FILE
return
return
fi
fi
if
[[
$WIFI_TYPE
!=
'none'
]]
;
then
if
[[
$WIFI_TYPE
!=
'none'
]]
;
then
if
[
${#
WIFI_PASSPHRASE
}
-lt
2
]
;
then
if
[
${#
WIFI_PASSPHRASE
}
-lt
2
]
;
then
return
return
fi
fi
chroot
"
$rootdir
"
${
PROJECT_NAME
}
-wifi
-i
$WIFI_INTERFACE
-s
$WIFI_SSID
-t
$WIFI_TYPE
-p
$WIFI_PASSPHRASE
--hotspot
$WIFI_HOTSPOT
chroot
"
$rootdir
"
${
PROJECT_NAME
}
-wifi
-i
$WIFI_INTERFACE
-s
$WIFI_SSID
-t
$WIFI_TYPE
-p
$WIFI_PASSPHRASE
--hotspot
$WIFI_HOTSPOT
else
else
chroot
"
$rootdir
"
${
PROJECT_NAME
}
-wifi
-i
$WIFI_INTERFACE
-s
$WIFI_SSID
-t
$WIFI_TYPE
--hotspot
$WIFI_HOTSPOT
chroot
"
$rootdir
"
${
PROJECT_NAME
}
-wifi
-i
$WIFI_INTERFACE
-s
$WIFI_SSID
-t
$WIFI_TYPE
--hotspot
$WIFI_HOTSPOT
fi
fi
}
}
##############################################################################
##############################################################################
...
@@ -498,221 +498,224 @@ INSTALL_DIR=$HOME/build
...
@@ -498,221 +498,224 @@ INSTALL_DIR=$HOME/build
INSTALLING_MESH
=
INSTALLING_MESH
=
initialise_mesh
()
{
initialise_mesh
()
{
if
[[
$VARIANT
!=
"mesh"
&&
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
]]
;
then
if
[[
$VARIANT
!=
"mesh"
&&
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
]]
;
then
return
return
fi
fi
if
[[
$DEBIAN_INSTALL_ONLY
!=
"no"
]]
;
then
if
[[
$DEBIAN_INSTALL_ONLY
!=
"no"
]]
;
then
return
return
fi
fi
if
[[
$INSECURE
==
$'yes'
]]
;
then
if
[[
$INSECURE
==
$'yes'
]]
;
then
echo
'*********************************************************'
echo
'*********************************************************'
echo
$'WARNING: non-free wifi drivers are being installed.'
echo
$'WARNING: non-free wifi drivers are being installed.'
echo
$' This may compromise the security of your system.'
echo
$' This may compromise the security of your system.'
echo
'*********************************************************'
echo
'*********************************************************'
# enable non-free repo
# enable non-free repo
if
!
grep
-q
"non-free"
$rootdir
/etc/apt/sources.list
;
then
if
!
grep
-q
"non-free"
$rootdir
/etc/apt/sources.list
;
then
chroot
"
$rootdir
"
sed
-i
"s| main| main non-free|g"
/etc/apt/sources.list
chroot
"
$rootdir
"
sed
-i
"s| main| main non-free|g"
/etc/apt/sources.list
fi
fi
# enable contrib repo
# enable contrib repo
if
!
grep
-q
"contrib"
$rootdir
/etc/apt/sources.list
;
then
if
!
grep
-q
"contrib"
$rootdir
/etc/apt/sources.list
;
then
chroot
"
$rootdir
"
sed
-i
"s| main| main contrib|g"
/etc/apt/sources.list
chroot
"
$rootdir
"
sed
-i
"s| main| main contrib|g"
/etc/apt/sources.list
fi
fi
chroot
"
$rootdir
"
apt-get update
chroot
"
$rootdir
"
apt-get update
# install proprietary wifi drivers
# install proprietary wifi drivers
# see https://wiki.debian.org/iwlwifi
# see https://wiki.debian.org/iwlwifi
chroot
"
$rootdir
"
apt-get
-y
install
firmware-iwlwifi firmware-b43-installer firmware-brcm80211
chroot
"
$rootdir
"
apt-get
-y
install
firmware-iwlwifi firmware-b43-installer firmware-brcm80211
fi
fi
INSTALLING_MESH
=
1
INSTALLING_MESH
=
1
configure_firewall
configure_firewall
install_avahi
install_avahi
install_batman
install_batman
install_tomb
install_tomb
install_tox
install_tox
install_web_server
install_web_server
install_zeronet
install_zeronet
MESH_SERVICE
=
'mesh-setup.service'
MESH_SERVICE
=
'mesh-setup.service'
MESH_SETUP_DAEMON
=
$rootdir
/etc/systemd/system/
$MESH_SERVICE
MESH_SETUP_DAEMON
=
$rootdir
/etc/systemd/system/
$MESH_SERVICE
MESH_STARTUP_PARAMS
=
"
${
MY_USERNAME
}
"
MESH_STARTUP_PARAMS
=
"
${
MY_USERNAME
}
"
if
[[
$AMNESIC
!=
'no'
]]
;
then
if
[[
$AMNESIC
!=
'no'
]]
;
then
MESH_STARTUP_PARAMS
=
"
${
MY_USERNAME
}
amnesic"
MESH_STARTUP_PARAMS
=
"
${
MY_USERNAME
}
amnesic"
fi
fi
echo
'[Unit]'
>
$MESH_SETUP_DAEMON
echo
'[Unit]'
>
$MESH_SETUP_DAEMON
echo
'Description=Initial mesh router configuration'
>>
$MESH_SETUP_DAEMON
echo
'Description=Initial mesh router configuration'
>>
$MESH_SETUP_DAEMON
echo
'After=syslog.target'
>>
$MESH_SETUP_DAEMON
echo
'After=syslog.target'
>>
$MESH_SETUP_DAEMON
echo
'After=network.target'
>>
$MESH_SETUP_DAEMON
echo
'After=network.target'
>>
$MESH_SETUP_DAEMON
echo
'[Service]'
>>
$MESH_SETUP_DAEMON
echo
'[Service]'
>>
$MESH_SETUP_DAEMON
echo
'Type=simple'
>>
$MESH_SETUP_DAEMON
echo
'Type=simple'
>>
$MESH_SETUP_DAEMON
echo
'User=root'
>>
$MESH_SETUP_DAEMON
echo
'User=root'
>>
$MESH_SETUP_DAEMON
echo
'Group=root'
>>
$MESH_SETUP_DAEMON
echo
'Group=root'
>>
$MESH_SETUP_DAEMON
echo
'WorkingDirectory=/root'
>>
$MESH_SETUP_DAEMON
echo
'WorkingDirectory=/root'
>>
$MESH_SETUP_DAEMON
echo
"ExecStart=/usr/local/bin/
${
PROJECT_NAME
}
-image-mesh
${
MESH_STARTUP_PARAMS
}
> /var/log/mesh-setup.log"
>>
$MESH_SETUP_DAEMON
echo
"ExecStart=/usr/local/bin/
${
PROJECT_NAME
}
-image-mesh
${
MESH_STARTUP_PARAMS
}
> /var/log/mesh-setup.log"
>>
$MESH_SETUP_DAEMON
echo
''
>>
$MESH_SETUP_DAEMON
echo
''
>>
$MESH_SETUP_DAEMON
echo
'TimeoutSec=99999'
>>
$MESH_SETUP_DAEMON
echo
'TimeoutSec=99999'
>>
$MESH_SETUP_DAEMON
echo
''
>>
$MESH_SETUP_DAEMON
echo
''
>>
$MESH_SETUP_DAEMON
echo
'[Install]'
>>
$MESH_SETUP_DAEMON
echo
'[Install]'
>>
$MESH_SETUP_DAEMON
echo
'WantedBy=multi-user.target'
>>
$MESH_SETUP_DAEMON
echo
'WantedBy=multi-user.target'
>>
$MESH_SETUP_DAEMON
chroot
"
$rootdir
"
systemctl
enable
$MESH_SERVICE
chroot
"
$rootdir
"
systemctl
enable
$MESH_SERVICE
}
}
# User interface for USB drive installs ######################################
# User interface for USB drive installs ######################################
function
mesh_client_startup_applications
{
function
mesh_client_startup_applications
{
if
[
!
-d
$rootdir
/home/
$MY_USERNAME
/Desktop
]
;
then
if
[
!
-d
$rootdir
/home/
$MY_USERNAME
/Desktop
]
;
then
mkdir
-p
$rootdir
/home/
$MY_USERNAME
/Desktop
mkdir
-p
$rootdir
/home/
$MY_USERNAME
/Desktop
fi
fi
if
[
!
-d
$rootdir
/home/
$MY_USERNAME
/.config/autostart
]
;
then
if
[
!
-d
$rootdir
/home/
$MY_USERNAME
/.config/autostart
]
;
then
mkdir
-p
$rootdir
/home/
$MY_USERNAME
/.config/autostart
mkdir
-p
$rootdir
/home/
$MY_USERNAME
/.config/autostart
chroot
"
$rootdir
"
chown
-R
$MY_USERNAME
:
$MY_USERNAME
/home/
$MY_USERNAME
/.config
chroot
"
$rootdir
"
chown
-R
$MY_USERNAME
:
$MY_USERNAME
/home/
$MY_USERNAME
/.config
fi
fi
START_DESKTOP
=
$rootdir
/home/
$MY_USERNAME
/mesh-desktop.sh
START_DESKTOP
=
$rootdir
/home/
$MY_USERNAME
/mesh-desktop.sh
echo
'#!/bin/bash'
>
$START_DESKTOP
echo
'#!/bin/bash'
>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/volumes-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/volumes-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/computer-icon-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/computer-icon-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/home-icon-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/home-icon-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/network-icon-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/network-icon-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/trash-icon-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/trash-icon-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/volumes-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/caja/desktop/volumes-visible false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/desktop/media-handling/automount-open false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/desktop/media-handling/automount-open false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/desktop/screensaver/lock-enabled false'
>>
$START_DESKTOP
echo
'dconf write /org/mate/desktop/screensaver/lock-enabled false'
>>
$START_DESKTOP
chmod
+x
$START_DESKTOP
chmod
+x
$START_DESKTOP
START_DESKTOP2
=
$rootdir
/home/
$MY_USERNAME
/.config/autostart/mesh-start.desktop
START_DESKTOP2
=
$rootdir
/home/
$MY_USERNAME
/.config/autostart/mesh-start.desktop
echo
'[Desktop Entry]'
>
$START_DESKTOP2
echo
'[Desktop Entry]'
>
$START_DESKTOP2
echo
'Type=Application'
>>
$START_DESKTOP2
echo
'Type=Application'
>>
$START_DESKTOP2
echo
'Name=Mesh start desktop script'
>>
$START_DESKTOP2
echo
'Name=Mesh start desktop script'
>>
$START_DESKTOP2
echo
"Exec=bash -c '~/mesh-desktop.sh'"
>>
$START_DESKTOP2
echo
"Exec=bash -c '~/mesh-desktop.sh'"
>>
$START_DESKTOP2
echo
'X-GNOME-Autostart-enabled=true'
>>
$START_DESKTOP2
echo
'X-GNOME-Autostart-enabled=true'
>>
$START_DESKTOP2
chmod
+x
$START_DESKTOP2
chmod
+x
$START_DESKTOP2
}
}
function
mesh_desktop_icons
{
function
mesh_desktop_icons
{
if
[
!
-d
$rootdir
/home/
$MY_USERNAME
/Desktop
]
;
then
if
[
!
-d
$rootdir
/home/
$MY_USERNAME
/Desktop
]
;
then
mkdir
-p
$rootdir
/home/
$MY_USERNAME
/Desktop
mkdir
-p
$rootdir
/home/
$MY_USERNAME
/Desktop
fi
fi
# Terminal
# Terminal
echo
'[Desktop Entry]'
>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'[Desktop Entry]'
>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'Name=MATE Terminal'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'Name=MATE Terminal'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'Type=Application'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'Type=Application'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'Comment=Use the command line'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'Comment=Use the command line'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'TryExec=mate-terminal'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'TryExec=mate-terminal'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'Exec=mate-terminal'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'Exec=mate-terminal'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'Icon=terminal'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'Icon=terminal'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'StartupNotify=true'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
echo
'StartupNotify=true'
>>
$rootdir
/home/
$MY_USERNAME
/Desktop/terminal.desktop
chroot
"
$rootdir
"
chown
-R
$MY_USERNAME
:
$MY_USERNAME
/home/
$MY_USERNAME
/Desktop
chroot
"
$rootdir
"
chown
-R
$MY_USERNAME
:
$MY_USERNAME
/home/
$MY_USERNAME
/Desktop
}
}
function
configure_user_interface
{
function
configure_user_interface
{
if
[[
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
&&
$VARIANT
!=
"usb"
]]
;
then
if
[[
$VARIANT
!=
"meshclient"
&&
$VARIANT
!=
"meshusb"
&&
$VARIANT
!=
"usb"
]]
;
then
return
return
fi
fi
if
[
!
$DEBIAN_REPO
]
;
then
if
[
!
$DEBIAN_REPO
]
;
then
DEBIAN_REPO
=
'ftp.de.debian.org'
DEBIAN_REPO
=
'ftp.de.debian.org'
fi
fi
if
[
!
$DEBIAN_VERSION
]
;
then
if
[
!
$DEBIAN_VERSION
]
;
then
DEBIAN_VERSION
=
'jessie'
DEBIAN_VERSION
=
'jessie'
fi
fi
# install backports
# install backports
echo
"deb http://
${
DEBIAN_REPO
}
/debian/
${
DEBIAN_VERSION
}
-backports main"
>>
$rootdir
/etc/apt/sources.list
echo
"deb http://
${
DEBIAN_REPO
}
/debian/
${
DEBIAN_VERSION
}
-backports main"
>>
$rootdir
/etc/apt/sources.list
chroot
"
$rootdir
"
apt-get
-y
update
chroot
"
$rootdir
"
apt-get
-y
update
# desktop
# desktop
chroot
"
$rootdir
"
apt-get
-y
install
mate-desktop-environment
chroot
"
$rootdir
"
apt-get
-y
install
mate-desktop-environment
# tool to change desktop settings from command line
# tool to change desktop settings from command line
chroot
"
$rootdir
"
apt-get
-y
install
dconf-cli dconf-gsettings-backend dbus dbus-x11
chroot
"
$rootdir
"
apt-get
-y
install
dconf-cli dconf-gsettings-backend dbus dbus-x11
# for tomb
# for tomb
chroot
"
$rootdir
"
apt-get
-y
install
pinentry-gtk2
chroot
"
$rootdir
"
apt-get
-y
install
pinentry-gtk2
# for tox video
# for tox video
chroot
"
$rootdir
"
apt-get
-y
install
ffmpeg cheese v4l-utils
chroot
"
$rootdir
"
apt-get
-y
install
ffmpeg cheese v4l-utils
if
[[
$VARIANT
!=
"usb"
]]
;
then
# to provide notifications
# log in automatically
chroot
"
$rootdir
"
apt-get
-y
install
libnotify-bin
chroot
"
$rootdir
"
apt-get
-y
install
nodm xinit
echo
'NODM_ENABLED=true'
>
/etc/default/nodm
if
[[
$VARIANT
!=
"usb"
]]
;
then
echo
"NODM_USER=
$MY_USERNAME
"
>>
/etc/default/nodm
# log in automatically
chroot
"
$rootdir
"
apt-get
-y
install
nodm xinit
chroot
"
$rootdir
"
mkdir
/etc/systemd/system/getty@tty1.service.d
echo
'NODM_ENABLED=true'
>
/etc/default/nodm
echo
'[Service]'
>
$rootdir
/etc/systemd/system/getty@tty1.service.d/override.conf
echo
"NODM_USER=
$MY_USERNAME
"
>>
/etc/default/nodm
echo
'ExecStart='
>>
$rootdir
/etc/systemd/system/getty@tty1.service.d/override.conf
echo
'ExecStart=-/sbin/agetty --autologin fbone --noclear %I $TERM'
>>
$rootdir
/etc/systemd/system/getty@tty1.service.d/override.conf
chroot
"
$rootdir
"
mkdir
/etc/systemd/system/getty@tty1.service.d
echo
'[Service]'
>
$rootdir
/etc/systemd/system/getty@tty1.service.d/override.conf
echo
'[[ -z $DISPLAY && $XDG_VTNR -eq 1 ]] && exec startx'
>>
$rootdir
/home/
$MY_USERNAME
/.profile
echo
'ExecStart='
>>
$rootdir
/etc/systemd/system/getty@tty1.service.d/override.conf
echo
'ExecStart=-/sbin/agetty --autologin fbone --noclear %I $TERM'
>>
$rootdir
/etc/systemd/system/getty@tty1.service.d/override.conf
chroot
"
$rootdir
"
systemctl set-default multi-user.target
echo
'[[ -z $DISPLAY && $XDG_VTNR -eq 1 ]] && exec startx'
>>
$rootdir
/home/
$MY_USERNAME
/.profile
mesh_client_startup_applications
mesh_desktop_icons
chroot
"
$rootdir
"
systemctl set-default multi-user.target
# Different desktop background for amnesic
mesh_client_startup_applications
if
[[
$AMNESIC
!=
'no'
]]
;
then
mesh_desktop_icons
MESH_DESKTOP_BACKGROUND_IMAGE
=
/usr/local/share/
${
PROJECT_NAME
}
_mesh_amnesic_background.png
fi
# Different desktop background for amnesic
if
[[
$AMNESIC
!=
'no'
]]
;
then
# change the desktop background
MESH_DESKTOP_BACKGROUND_IMAGE
=
/usr/local/share/
${
PROJECT_NAME
}
_mesh_amnesic_background.png
if
[
$MESH_DESKTOP_BACKGROUND_IMAGE
]
;
then
fi
if
[
-f
$MESH_DESKTOP_BACKGROUND_IMAGE
]
;
then
if
[
-d
$rootdir
/usr/share/images/desktop-base
]
;
then
# change the desktop background
cp
$MESH_DESKTOP_BACKGROUND_IMAGE
$rootdir
/usr/share/images/desktop-base/
${
PROJECT_NAME
}
_mesh_background.png
if
[
$MESH_DESKTOP_BACKGROUND_IMAGE
]
;
then
chroot
"
$rootdir
"
rm
/usr/share/images/desktop-base/desktop-background
if
[
-f
$MESH_DESKTOP_BACKGROUND_IMAGE
]
;
then
chroot
"
$rootdir
"
ln
-s
/usr/share/images/desktop-base/
${
PROJECT_NAME
}
_mesh_background.png /usr/share/images/desktop-base/desktop-background
if
[
-d
$rootdir
/usr/share/images/desktop-base
]
;
then
fi
cp
$MESH_DESKTOP_BACKGROUND_IMAGE
$rootdir
/usr/share/images/desktop-base/
${
PROJECT_NAME
}
_mesh_background.png
fi
chroot
"
$rootdir
"
rm
/usr/share/images/desktop-base/desktop-background
fi
chroot
"
$rootdir
"
ln
-s
/usr/share/images/desktop-base/
${
PROJECT_NAME
}
_mesh_background.png /usr/share/images/desktop-base/desktop-background
else
fi
chroot
"
$rootdir
"
apt-get
-y
install
lightdm
fi
fi
fi
else
# browser
chroot
"
$rootdir
"
apt-get
-y
install
lightdm
chroot
"
$rootdir
"
apt-get
-y
install
$BROWSER
fi
# Tox user interface
# browser
enable_tox_repo
chroot
"
$rootdir
"
apt-get
-y
install
$BROWSER
mesh_tox_qtox
# copy the default qtox ini file
# Tox user interface
if
[
!
-d
${
rootdir
}
/home/
${
MY_USERNAME
}
/.config/tox
]
;
then
enable_tox_repo
mkdir
${
rootdir
}
/home/
${
MY_USERNAME
}
/.config/tox
mesh_tox_qtox
cp
/usr/local/bin/freedombone-config-qtox
${
rootdir
}
/home/
${
MY_USERNAME
}
/.config/tox/qtox.ini
# copy the default qtox ini file
chroot
"
$rootdir
"
chown
-R
${
MY_USERNAME
}
:
${
MY_USERNAME
}
/home/
${
MY_USERNAME
}
/.config
if
[
!
-d
${
rootdir
}
/home/
${
MY_USERNAME
}
/.config/tox
]
;
then
fi
mkdir
${
rootdir
}
/home/
${
MY_USERNAME
}
/.config/tox
cp
/usr/local/bin/freedombone-config-qtox
${
rootdir
}
/home/
${
MY_USERNAME
}
/.config/tox/qtox.ini
# Syncthing
chroot
"
$rootdir
"
chown
-R
${
MY_USERNAME
}
:
${
MY_USERNAME
}
/home/
${
MY_USERNAME
}
/.config
install_syncthing
fi
if
[[
$VARIANT
==
"usb"
]]
;
then
# Syncthing
# tor
install_syncthing
chroot
"
$rootdir
"
apt-get
-y
install
tor
if
[[
$VARIANT
==
"usb"
]]
;
then
# xmpp client
# tor
chroot
"
$rootdir
"
echo
"deb ftp://ftp.gajim.org/debian unstable main"
>
/etc/apt/sources.list.d/gajim.list
chroot
"
$rootdir
"
apt-get
-y
install
tor
chroot
"
$rootdir
"
apt-get update
chroot
"
$rootdir
"
apt-get
-y
install
gajim-dev-keyring
# xmpp client
chroot
"
$rootdir
"
apt-get
-y
install
git python-dev python-pip gajim-nightly
chroot
"
$rootdir
"
echo
"deb ftp://ftp.gajim.org/debian unstable main"
>
/etc/apt/sources.list.d/gajim.list
chroot
"
$rootdir
"
mkdir
/home/
$GENERIC_IMAGE_USERNAME
/.local/share/gajim/plugins
-p
chroot
"
$rootdir
"
apt-get update
chroot
"
$rootdir
"
git clone https://github.com/omemo/gajim-omemo /home/
$GENERIC_IMAGE_USERNAME
/.local/share/gajim/plugins/gajim-omemo
chroot
"
$rootdir
"
apt-get
-y
install
gajim-dev-keyring
chroot
"
$rootdir
"
pip
install
protobuf
==
2.6.1, python-axolotl
==
0.1.35
chroot
"
$rootdir
"
apt-get
-y
install
git python-dev python-pip gajim-nightly
chroot
"
$rootdir
"
chown
-R
$GENERIC_IMAGE_USERNAME
:
$GENERIC_IMAGE_USERNAME
/home/
$GENERIC_IMAGE_USERNAME
/.local
chroot
"
$rootdir
"
mkdir
/home/
$GENERIC_IMAGE_USERNAME
/.local/share/gajim/plugins
-p
chroot
"
$rootdir
"
git clone https://github.com/omemo/gajim-omemo /home/
$GENERIC_IMAGE_USERNAME
/.local/share/gajim/plugins/gajim-omemo
# IRC client
chroot
"
$rootdir
"
pip
install
protobuf
==
2.6.1, python-axolotl
==
0.1.35
chroot
"
$rootdir
"
apt-get
-y
install
hexchat profanity
chroot
"
$rootdir
"
chown
-R
$GENERIC_IMAGE_USERNAME
:
$GENERIC_IMAGE_USERNAME
/home/
$GENERIC_IMAGE_USERNAME
/.local
fi
# IRC client
chroot
"
$rootdir
"
apt-get
-y
install
hexchat profanity
fi
}
}
##############################################################################
##############################################################################
...
@@ -736,8 +739,8 @@ export LC_ALL=C LANGUAGE=C LANG=C
...
@@ -736,8 +739,8 @@ export LC_ALL=C LANGUAGE=C LANG=C
export
TMP
=
/tmp/
TMPDIR
=
/tmp/
export
TMP
=
/tmp/
TMPDIR
=
/tmp/
if
[
!
$MY_USERNAME
]
;
then
if
[
!
$MY_USERNAME
]
;
then
echo
$'No username was specified'
echo
$'No username was specified'
exit
52825
exit
52825
fi
fi
username
=
$MY_USERNAME
username
=
$MY_USERNAME
echo
$"warning: creating initial user
$username
with well known password!"
echo
$"warning: creating initial user
$username
with well known password!"
...
@@ -747,16 +750,16 @@ echo $username:$password | chroot $rootdir /usr/sbin/chpasswd
...
@@ -747,16 +750,16 @@ echo $username:$password | chroot $rootdir /usr/sbin/chpasswd
chroot
"
$rootdir
"
adduser
$username
sudo
chroot
"
$rootdir
"
adduser
$username
sudo
case
"
$MACHINE
"
in
case
"
$MACHINE
"
in
virtualbox
)
virtualbox
)
# hide irrelevant console keyboard messages.
# hide irrelevant console keyboard messages.
echo
"echo
\"
4 4 1 7
\"
> /proc/sys/kernel/printk"
\
echo
"echo
\"
4 4 1 7
\"
> /proc/sys/kernel/printk"
\
>>
/etc/init.d/rc.local
>>
/etc/init.d/rc.local
;;
;;
qemu
)
qemu
)
# hide irrelevant console keyboard messages.
# hide irrelevant console keyboard messages.
echo
"echo
\"
4 4 1 7
\"
> /proc/sys/kernel/printk"
\
echo
"echo
\"
4 4 1 7
\"
> /proc/sys/kernel/printk"
\
>>
/etc/init.d/rc.local
>>
/etc/init.d/rc.local
;;
;;
esac
esac
set_apt_sources
$BUILD_MIRROR
set_apt_sources
$BUILD_MIRROR
...
@@ -772,13 +775,13 @@ EOF
...
@@ -772,13 +775,13 @@ EOF
chmod
a+rx
$rootdir
/usr/sbin/policy-rc.d
chmod
a+rx
$rootdir
/usr/sbin/policy-rc.d
if
$use_eatmydata
;
then
if
$use_eatmydata
;
then
enable_eatmydata_override
enable_eatmydata_override
fi
fi
if
[
-n
"
$CUSTOM_SETUP
"
]
;
then
if
[
-n
"
$CUSTOM_SETUP
"
]
;
then
cp
"
$CUSTOM_SETUP
"
"
$rootdir
"
/tmp
cp
"
$CUSTOM_SETUP
"
"
$rootdir
"
/tmp
chroot
"
$rootdir
"
apt-get
install
-y
gdebi-core
chroot
"
$rootdir
"
apt-get
install
-y
gdebi-core
chroot
"
$rootdir
"
gdebi
-n
/tmp/
"
$(
basename
$CUSTOM_SETUP
)
"
chroot
"
$rootdir
"
gdebi
-n
/tmp/
"
$(
basename
$CUSTOM_SETUP
)
"
fi
fi
chroot
"
$rootdir
"
apt-get
install
-y
sudo
git dialog toilet build-essential openssh-server
chroot
"
$rootdir
"
apt-get
install
-y
sudo
git dialog toilet build-essential openssh-server
...
@@ -799,39 +802,39 @@ make install
...
@@ -799,39 +802,39 @@ make install
EOF
EOF
chroot
"
$rootdir
"
${
PROJECT_NAME
}
-image-hardware-setup
2>&1 |
\
chroot
"
$rootdir
"
${
PROJECT_NAME
}
-image-hardware-setup
2>&1 |
\
tee
$rootdir
/var/log/
${
PROJECT_NAME
}
-image-hardware-setup
.log
tee
$rootdir
/var/log/
${
PROJECT_NAME
}
-image-hardware-setup
.log
rm
$rootdir
/usr/sbin/policy-rc.d
rm
$rootdir
/usr/sbin/policy-rc.d
# Set up HRNG for systems known to have one
# Set up HRNG for systems known to have one
# Otherwise install haveged
# Otherwise install haveged
if
[[
"
$MACHINE
"
!=
"beaglebone"
]]
;
then
if
[[
"
$MACHINE
"
!=
"beaglebone"
]]
;
then
chroot
$rootdir
apt-get
-y
install
haveged
chroot
$rootdir
apt-get
-y
install
haveged
else
else
chroot
$rootdir
apt-get
-y
install
rng-tools
chroot
$rootdir
apt-get
-y
install
rng-tools
sed
-i
's|#HRNGDEVICE=/dev/hwrng|HRNGDEVICE=/dev/hwrng|g'
$rootdir
/etc/default/rng-tools
sed
-i
's|#HRNGDEVICE=/dev/hwrng|HRNGDEVICE=/dev/hwrng|g'
$rootdir
/etc/default/rng-tools
fi
fi
# copy u-boot to beginning of image
# copy u-boot to beginning of image
case
"
$MACHINE
"
in
case
"
$MACHINE
"
in
beaglebone
)
beaglebone
)
dd
if
=
$rootdir
/usr/lib/u-boot/am335x_boneblack/MLO
of
=
"
$image
"
\
dd
if
=
$rootdir
/usr/lib/u-boot/am335x_boneblack/MLO
of
=
"
$image
"
\
count
=
1
seek
=
1
conv
=
notrunc
bs
=
128k
count
=
1
seek
=
1
conv
=
notrunc
bs
=
128k
dd
if
=
$rootdir
/usr/lib/u-boot/am335x_boneblack/u-boot.img
of
=
"
$image
"
\
dd
if
=
$rootdir
/usr/lib/u-boot/am335x_boneblack/u-boot.img
of
=
"
$image
"
\
count
=
2
seek
=
1
conv
=
notrunc
bs
=
384k
count
=
2
seek
=
1
conv
=
notrunc
bs
=
384k
;;
;;
cubieboard2
)
cubieboard2
)
dd
if
=
$rootdir
/usr/lib/u-boot/Cubieboard2/u-boot-sunxi-with-spl.bin
of
=
"
$image
"
\
dd
if
=
$rootdir
/usr/lib/u-boot/Cubieboard2/u-boot-sunxi-with-spl.bin
of
=
"
$image
"
\
seek
=
8
conv
=
notrunc
bs
=
1k
seek
=
8
conv
=
notrunc
bs
=
1k
;;
;;
a20-olinuxino-lime
)
a20-olinuxino-lime
)
dd
if
=
$rootdir
/usr/lib/u-boot/A20-OLinuXino-Lime/u-boot-sunxi-with-spl.bin
\
dd
if
=
$rootdir
/usr/lib/u-boot/A20-OLinuXino-Lime/u-boot-sunxi-with-spl.bin
\
of
=
"
$image
"
seek
=
8
conv
=
notrunc
bs
=
1k
of
=
"
$image
"
seek
=
8
conv
=
notrunc
bs
=
1k
;;
;;
esac
esac
if
$use_eatmydata
;
then
if
$use_eatmydata
;
then
disable_eatmydata_override
disable_eatmydata_override
fi
fi
set_apt_sources
$MIRROR
set_apt_sources
$MIRROR
...
...
This diff is collapsed.
Click to expand it.
src/zeronetavahi
+
1
−
1
View file @
f8b22261
...
@@ -132,7 +132,7 @@ function detect_new_tox_users {
...
@@ -132,7 +132,7 @@ function detect_new_tox_users {
#
get
the
nick
of
the
user
#
get
the
nick
of
the
user
toxuser=
"$(echo "
$
line
"
|
awk
-F
'
'
'{
print
$1}')"
toxuser=
"$(echo "
$
line
"
|
awk
-F
'
'
'{
print
$1}')"
notify-send
$"$
PROJECT_NAME
mesh
"
$"$
toxuser
has
joined
the
mesh
"
--icon=
dialog-information
notify-send
$"$
toxuser
"
$"
has
joined
the
mesh
"
--icon=
dialog-information
fi
fi
fi
fi
done
<
"$
CURRENT_USERS_FILE
"
done
<
"$
CURRENT_USERS_FILE
"
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment