@ -0,0 +1,49 @@
|
||||
FROM python:3-slim
|
||||
|
||||
MAINTAINER n1trux
|
||||
RUN apt-get update &&\
|
||||
apt-get -y upgrade &&\
|
||||
DEBIAN_FRONTEND=noninteractive apt-get -y install \
|
||||
nano rsync openssh-server acl
|
||||
|
||||
# Clean up APT when done.
|
||||
RUN apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||
|
||||
|
||||
# private/{scripts, administrate.py}, public/{scripts, userapplications.py}, config/userapplicatonsconfig.ini
|
||||
#configs, logs, db
|
||||
COPY config/applicationsconfig.ini /app/data/applicationsconfig.ini
|
||||
|
||||
# admin scripts
|
||||
COPY private/ /app/admin/
|
||||
|
||||
# user accessible scripts
|
||||
# Make TILDE_ENV
|
||||
COPY public/ /app/user/
|
||||
#SSH config into /etc :)
|
||||
COPY config/etc /etc
|
||||
|
||||
# create user for applications
|
||||
RUN useradd -Md /app/user/ -s /app/user/userapplication.py tilde
|
||||
|
||||
# make tilde's password empty
|
||||
RUN passwd -d tilde
|
||||
RUN usermod -U tilde
|
||||
|
||||
# add admin user
|
||||
RUN useradd -Md /app/admin -s /app/admin/administrate.py admin
|
||||
# privilege separation directory
|
||||
RUN mkdir -p /var/run/sshd
|
||||
|
||||
# expose SSH port
|
||||
EXPOSE 22
|
||||
ENV TILDE_CONF="/app/data/applicationsconfig.ini"
|
||||
#COPY config/environment /app/user/.ssh/environment
|
||||
RUN mkdir /app/user/.ssh
|
||||
RUN echo TILDE_CONF=$TILDE_CONF > /app/user/.ssh/environment
|
||||
RUN touch /app/data/applications.sqlite
|
||||
RUN touch /app/data/applications.log
|
||||
# Doesnt work, @TODO why
|
||||
#RUN setfacl -R -m u:tilde:rwx /app/data/
|
||||
RUN chown -R tilde /app/data
|
||||
CMD ["/usr/sbin/sshd", "-D"]
|
@ -0,0 +1,23 @@
|
||||
[DEFAULT]
|
||||
base_path=/app/data/
|
||||
applications_db=%(base_path)sapplications.sqlite
|
||||
log_dir=/app/data/
|
||||
log_file=%(log_dir)sapplications.log
|
||||
user_creationscript=%(base_path)s/scripts/make-tilde-user.sh
|
||||
|
||||
[USERS]
|
||||
UserGroup=tilde
|
||||
userPWLock=yes
|
||||
chmodPerms=0o700
|
||||
chmodParams=-Rv
|
||||
chownParams=%(chmodParams)s
|
||||
chownGroups=%(UserGroup)s:%(UserGroup)s
|
||||
|
||||
[LOG_LEVEL]
|
||||
log_level=%(log_debug)s
|
||||
log_notset=0
|
||||
log_debug=10
|
||||
log_info=20
|
||||
log_warning=30
|
||||
log_error=40
|
||||
lo0g_critical=50
|
@ -0,0 +1 @@
|
||||
TILDE_CONF=/app/data/applicationsconfig.ini
|
@ -0,0 +1,29 @@
|
||||
MAIL_DIR /var/mail
|
||||
FAILLOG_ENAB yes
|
||||
LOG_UNKFAIL_ENAB no
|
||||
LOG_OK_LOGINS no
|
||||
SYSLOG_SU_ENAB yes
|
||||
SYSLOG_SG_ENAB yes
|
||||
FTMP_FILE /var/log/btmp
|
||||
SU_NAME su
|
||||
HUSHLOGIN_FILE .hushlogin
|
||||
ENV_SUPATH PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
||||
ENV_PATH PATH=/usr/local/bin:/usr/bin:/bin:/usr/local/games:/usr/games
|
||||
TTYGROUP tty
|
||||
TTYPERM 0600
|
||||
ERASECHAR 0177
|
||||
KILLCHAR 025
|
||||
UMASK 022
|
||||
PASS_MAX_DAYS 99999
|
||||
PASS_MIN_DAYS 0
|
||||
PASS_WARN_AGE 7
|
||||
UID_MIN 100000
|
||||
UID_MAX 165536
|
||||
GID_MIN 100000
|
||||
GID_MAX 165536
|
||||
LOGIN_RETRIES 5
|
||||
LOGIN_TIMEOUT 60
|
||||
CHFN_RESTRICT rwh
|
||||
DEFAULT_HOME yes
|
||||
USERGROUPS_ENAB yes
|
||||
ENCRYPT_METHOD SHA512
|
@ -0,0 +1,11 @@
|
||||
UseDNS no
|
||||
Protocol 2
|
||||
SyslogFacility AUTHPRIV
|
||||
PermitRootLogin no
|
||||
PermitUserEnvironment yes
|
||||
PubkeyAuthentication yes
|
||||
ChallengeResponseAuthentication no
|
||||
Subsystem sftp /usr/lib/openssh/sftp-server
|
||||
|
||||
Match User tilde
|
||||
PermitEmptyPasswords yes
|
@ -0,0 +1,11 @@
|
||||
#!/bin/bash
|
||||
cut -d: -f1 /etc/passwd | grep test > deltest.txt
|
||||
while read name; do
|
||||
userdel "$name"
|
||||
rm -rf /home/$name
|
||||
if [ "$#" -eq 1 ]; then
|
||||
sqlite3 -batch $1 "DELETE FROM applications WHERE username = '$name'"
|
||||
fi
|
||||
done < deltest.txt
|
||||
|
||||
rm -f deltest.txt
|
@ -0,0 +1,23 @@
|
||||
#!/bin/env bash
|
||||
USERNAME=$1
|
||||
REALNAME=$2
|
||||
EMAIL=$3
|
||||
PUBKEY=$4
|
||||
|
||||
adduser $USERNAME
|
||||
|
||||
# empty password
|
||||
usermod --lock $USERNAME
|
||||
|
||||
# add to tilde group
|
||||
usermod -a -G tilde $USERNAME
|
||||
|
||||
# paste ssh key
|
||||
mkdir /home/$USERNAME/.ssh
|
||||
echo $PUBKEY >/home/$USERNAME/.ssh/authorized_keys
|
||||
|
||||
# fix perms
|
||||
chmod -Rv 700 /home/$USERNAME/.ssh/
|
||||
chown -Rv $USERNAME:$USERNAME /home/$USERNAME/.ssh/
|
||||
echo "user created."
|
||||
return 0
|
@ -0,0 +1,35 @@
|
||||
#!/usr/bin/expect
|
||||
expr {srand([clock seconds])} ;# initialize RNG
|
||||
set username "testuser"
|
||||
set mail "test@testmail.com"
|
||||
set name "test Name"
|
||||
set sshkey "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC7Tob2HvgKL5yns9BQpb/EJENR3UurMdhM9oc7tQ/USw/nIiisRDp4qmwqZM3kyl1RfkGoSiEALCogM693jl/2RO2MFLW/Da9WFuXwBmV4wMbQZQiZJCvqyMBW7uPHgfCXJ2E8T707Ixwv9S9gtmwgAqg/+x12C0fF7P45MpO3Mvc+6ZPdP5qg/GCaej67KHqfVTb4/OMrvHkRTlETFYVNj4B/uwuA7NxTi8YkCSKH+BGCLYDl95uISrHOxaKbeDb6OgkgdYS9ygg2F7r3S36n8woLdSXqJNpxx2zLgO8Ow9KE0paezyeQqPPjbYu6l8y2IAkKCWTHKTAQ6DFgcvAD darksider3@prism"
|
||||
set y "y"
|
||||
set random "[expr {int(rand() * 1000)}]"
|
||||
spawn ./userapplication.py
|
||||
|
||||
expect "allowed:"
|
||||
send "$username$random\r"
|
||||
expect "full name:"
|
||||
send "$name\r"
|
||||
expect "email address:"
|
||||
send "$random$mail\r"
|
||||
expect "ssh public key:"
|
||||
send "$sshkey\r"
|
||||
expect "correct?*"
|
||||
send "$y\r"
|
||||
interact
|
||||
|
||||
spawn ./administrate.py
|
||||
|
||||
expect -glob "*-> "
|
||||
send "1\r"
|
||||
expect -glob "*->"
|
||||
send "\r"
|
||||
expect -glob "*-> "
|
||||
send "A\r"
|
||||
expect -glob "*..."
|
||||
send "\r"
|
||||
expect -glob "*-> "
|
||||
send "4\r"
|
||||
interact
|
Loading…
Reference in New Issue