mirror of
https://github.com/shenxn/protonmail-bridge-docker.git
synced 2026-01-25 16:30:07 +00:00
51 lines
1.3 KiB
Bash
51 lines
1.3 KiB
Bash
#!/bin/bash
|
|
|
|
set -ex
|
|
|
|
# Workaround for stale gpg-agent socket causing auth failures on restart
|
|
# Cleans up leftover sockets in the GPG home directory
|
|
if [ -d /root/.gnupg ]; then
|
|
rm -f /root/.gnupg/S.gpg-agent*
|
|
fi
|
|
|
|
# Initialize
|
|
if [[ $1 == init ]]; then
|
|
|
|
# Initialize pass
|
|
gpg --generate-key --batch /protonmail/gpgparams
|
|
pass init pass-key
|
|
|
|
# Kill the other instance as only one can be running at a time.
|
|
# This allows users to run entrypoint init inside a running conainter
|
|
# which is useful in a k8s environment.
|
|
# || true to make sure this would not fail in case there is no running instance.
|
|
pkill protonmail-bridge || true
|
|
|
|
# Login
|
|
/protonmail/proton-bridge --cli $@
|
|
|
|
else
|
|
|
|
# socat will make the conn appear to come from 127.0.0.1
|
|
# ProtonMail Bridge currently expects that.
|
|
# It also allows us to bind to the real ports :)
|
|
socat TCP-LISTEN:25,fork TCP:127.0.0.1:1025 &
|
|
socat TCP-LISTEN:143,fork TCP:127.0.0.1:1143 &
|
|
|
|
# Start protonmail
|
|
# Fake a terminal, so it does not quit because of EOF...
|
|
rm -f faketty
|
|
mkfifo faketty
|
|
|
|
# Keep faketty open
|
|
sleep infinity > faketty &
|
|
|
|
# Start bridge reading from faketty
|
|
/protonmail/proton-bridge --cli $@ < faketty &
|
|
|
|
# Wait for the bridge to exit
|
|
wait $!
|
|
exit $?
|
|
|
|
fi
|