forked from ProjectSegfault/publapi
25 lines
1.5 KiB
Bash
25 lines
1.5 KiB
Bash
#!/bin/bash
|
|
# Path: /var/publapi/users/{{username}}.sh
|
|
# This file is generated by PublAPI. Do not edit this file.
|
|
echo "E-Mail of {{username}} is {{email}}."
|
|
pass="$(tr -dc A-Za-z0-9 </dev/urandom | head -c 64)"
|
|
useradd -Um -s /bin/bash {{username}}
|
|
chmod 711 /home/{{username}}
|
|
printf "%s\n%s" "${pass}" "${pass}" | passwd {{username}}
|
|
echo "${pass}" > /home/{{username}}/pass
|
|
chmod 600 /home/{{username}}/pass
|
|
chown {{username}}:username /home/username/pass
|
|
usermod -aG users {{username}}
|
|
mkdir /home/{{username}}/.ssh
|
|
echo "{{sshkey}}" > /home/{{username}}/.ssh/authorized_keys
|
|
chmod 700 /home/{{username}}/.ssh
|
|
chmod 600 /home/{{username}}/.ssh/authorized_keys
|
|
chown -R {{username}}:username /home/username/.ssh
|
|
sed -i 's/REPLACEME/{{username}}/g' /home/username/{meta-info.env,Caddyfile}
|
|
sed -i 's/EMAIL=/EMAIL={{email}}/' /home/{{username}}/meta-info.env
|
|
loginctl enable-linger {{username}}
|
|
setquota -u {{username}} 20G 20G 0 0 /
|
|
a=$(curl -X POST "https://auth.p.projectsegfau.lt/api/v3/core/users/" -H "accept: application/json" -H "content-type: application/json" -H "Authorization: Bearer $(</root/pass/authentiktoken)" -d '{"username":"{{username}}","name":"{{username}}","is_active":true,"groups":["57fe5750-5ac6-46ff-95bc-298cbff0b340"],"email":"{{email}}","attributes":{},"path":"users"}')
|
|
pk=$(echo $a | jq '.pk')
|
|
curl -X POST "https://auth.p.projectsegfau.lt/api/v3/core/users/${pk}/set_password" -H "accept: application/json" -H "content-type: application/json" -H "Authorization: Bearer $(</root/pass/authentiktoken)" -d "{\"password\": \"${pass}\"}"
|