freedombone-base-email 81KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746
  1. #!/bin/bash
  2. #
  3. # .---. . .
  4. # | | |
  5. # |--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
  6. # | | (.-' (.-' ( | ( )| | | | )( )| | (.-'
  7. # ' ' --' --' -' - -' ' ' -' -' -' ' - --'
  8. #
  9. # Freedom in the Cloud
  10. #
  11. # Email functions
  12. #
  13. # License
  14. # =======
  15. #
  16. # Copyright (C) 2014-2016 Bob Mottram <bob@freedombone.net>
  17. #
  18. # This program is free software: you can redistribute it and/or modify
  19. # it under the terms of the GNU Affero General Public License as published by
  20. # the Free Software Foundation, either version 3 of the License, or
  21. # (at your option) any later version.
  22. #
  23. # This program is distributed in the hope that it will be useful,
  24. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  25. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  26. # GNU Affero General Public License for more details.
  27. #
  28. # You should have received a copy of the GNU Affero General Public License
  29. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  30. # the default email address
  31. MY_EMAIL_ADDRESS=$MY_USERNAME@$DEFAULT_DOMAIN_NAME
  32. # If you want to run a public mailing list specify its name here.
  33. # There should be no spaces in the name
  34. PUBLIC_MAILING_LIST=
  35. # Optional different domain name for the public mailing list
  36. PUBLIC_MAILING_LIST_DOMAIN_NAME=
  37. # Directory where the public mailing list data is stored
  38. PUBLIC_MAILING_LIST_DIRECTORY="/var/spool/mlmmj"
  39. # If you want to run an encrypted mailing list specify its name here.
  40. # There should be no spaces in the name
  41. PRIVATE_MAILING_LIST=
  42. GPG_KEYSERVER="hkp://keys.gnupg.net"
  43. # whether to encrypt all incoming email with your public key
  44. GPG_ENCRYPT_STORED_EMAIL="yes"
  45. # gets set to yes if gpg keys are imported from usb
  46. GPG_KEYS_IMPORTED="no"
  47. # optionally you can provide your exported GPG key pair here
  48. # Note that the private key file will be deleted after use
  49. # If these are unspecified then a new GPG key will be created
  50. MY_GPG_PUBLIC_KEY=
  51. MY_GPG_PRIVATE_KEY=
  52. # optionally specify your public key ID
  53. MY_GPG_PUBLIC_KEY_ID=
  54. EXIM_ONION_REPO="https://github.com/petterreinholdtsen/exim4-smtorp"
  55. # automatic archiving of email
  56. CLEANUP_MAILDIR_REPO="https://github.com/bashrc/cleanup-maildir"
  57. CLEANUP_MAILDIR_COMMIT='33241d2e3861f901ba17f5c77ada007e1ec06a86'
  58. # email encryption at rest
  59. GPGIT_REPO="https://gitlab.com/mikecardwell/gpgit"
  60. GPGIT_COMMIT='583dc76119f19420f8a33f606744faa7c8922738'
  61. # refresh gpg keys every few hours
  62. REFRESH_GPG_KEYS_HOURS=2
  63. function configure_email_onion {
  64. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  65. return
  66. fi
  67. if [[ $SYSTEM_TYPE == "mesh"* ]]; then
  68. return
  69. fi
  70. echo 'HiddenServiceDir /var/lib/tor/hidden_service_email/' >> /etc/tor/torrc
  71. echo 'HiddenServicePort 25 127.0.0.1:25' >> /etc/tor/torrc
  72. echo 'HiddenServicePort 587 127.0.0.1:587' >> /etc/tor/torrc
  73. echo 'HiddenServicePort 465 127.0.0.1:465' >> /etc/tor/torrc
  74. function_check onion_update
  75. onion_update
  76. function_check wait_for_onion_service
  77. wait_for_onion_service email
  78. if [[ $(onion_service_exists email) == "0" ]]; then
  79. echo $"email onion site hostname not found"
  80. exit 782352
  81. fi
  82. onion_address=$(cat /var/lib/tor/hidden_service_email/hostname)
  83. set_completion_param "email onion domain" "${onion_address}"
  84. add_email_hostname "$onion_address"
  85. mark_completed $FUNCNAME
  86. }
  87. function check_email_address_exists {
  88. read_config_param ONION_ONLY
  89. read_config_param MY_USERNAME
  90. read_config_param DEFAULT_DOMAIN_NAME
  91. read_config_param MY_EMAIL_ADDRESS
  92. read_config_param DH_KEYLENGTH
  93. if [ ! $MY_USERNAME ]; then
  94. echo $'No username for email installation'
  95. exit 73672
  96. fi
  97. if [ ! $DEFAULT_DOMAIN_NAME ]; then
  98. echo $'No default domain name for email installation'
  99. exit 57634
  100. fi
  101. my_email="$MY_EMAIL_ADDRESS"
  102. if [ ${#my_email} -lt 3 ]; then
  103. MY_EMAIL_ADDRESS=${MY_USERNAME}@${DEFAULT_DOMAIN_NAME}
  104. write_config_param "MY_EMAIL_ADDRESS" "$MY_EMAIL_ADDRESS"
  105. fi
  106. }
  107. function backup_email {
  108. echo ''
  109. }
  110. function configure_firewall_for_email {
  111. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  112. # docker does its own firewalling
  113. return
  114. fi
  115. if [[ $ONION_ONLY != "no" ]]; then
  116. return
  117. fi
  118. firewall_add Email 25 tcp
  119. firewall_add Email 587 tcp
  120. firewall_add Email 465 tcp
  121. firewall_add Imap 993 tcp
  122. }
  123. function encrypt_incoming_email {
  124. # encrypts incoming mail using your GPG public key
  125. # so even if an attacker gains access to the data at rest they still need
  126. # to know your GPG key password to be able to read anything
  127. if [ ! -d /etc/exim4 ]; then
  128. return
  129. fi
  130. # update to the next commit
  131. function_check set_repo_commit
  132. set_repo_commit $INSTALL_DIR/gpgit "gpgit commit" "$GPGIT_COMMIT" $GPGIT_REPO
  133. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  134. return
  135. fi
  136. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  137. return
  138. fi
  139. if [ ! -f /usr/bin/gpgit.pl ]; then
  140. apt-get -yq install git libmail-gnupg-perl
  141. cd $INSTALL_DIR
  142. function_check git_clone
  143. git_clone $GPGIT_REPO $INSTALL_DIR/gpgit
  144. cd $INSTALL_DIR/gpgit
  145. git checkout $GPGIT_COMMIT -b $GPGIT_COMMIT
  146. set_completion_param "gpgit commit" "$GPGIT_COMMIT"
  147. cp gpgit.pl /usr/bin
  148. fi
  149. # add a procmail rule
  150. if ! grep -q "/usr/bin/gpgit.pl" /home/$MY_USERNAME/.procmailrc; then
  151. echo '' >> /home/$MY_USERNAME/.procmailrc
  152. echo ':0 f' >> /home/$MY_USERNAME/.procmailrc
  153. echo "| /usr/bin/gpgit.pl --encrypt-mode prefer-inline --inline-flatten $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/.procmailrc
  154. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  155. echo '' >> /etc/skel/.procmailrc
  156. echo ':0 f' >> /etc/skel/.procmailrc
  157. echo -n '| /usr/bin/gpgit.pl --encrypt-mode prefer-inline --inline-flatten $USER@' >> /etc/skel/.procmailrc
  158. echo "$DEFAULT_DOMAIN_NAME" >> /etc/skel/.procmailrc
  159. fi
  160. mark_completed $FUNCNAME
  161. }
  162. function encrypt_outgoing_email {
  163. # encrypts outgoing mail using your GPG public key
  164. # so even if an attacker gains access to the data at rest they still need
  165. # to know your GPG key password to be able to read sent mail
  166. if [ ! -d /etc/exim4 ]; then
  167. return
  168. fi
  169. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  170. return
  171. fi
  172. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  173. return
  174. fi
  175. if [ ! -d /home/$MY_USERNAME/.gnupg ]; then
  176. return
  177. fi
  178. if [ ! -f /home/$MY_USERNAME/.muttrc ]; then
  179. return
  180. fi
  181. # obtain your public key ID
  182. if [ ! $MY_GPG_PUBLIC_KEY_ID ]; then
  183. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  184. if [ ! "$MY_GPG_PUBLIC_KEY_ID" ]; then
  185. return
  186. fi
  187. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  188. return
  189. fi
  190. fi
  191. if ! grep -q "pgp_encrypt_only_command" /home/$MY_USERNAME/.muttrc; then
  192. echo '' >> /home/$MY_USERNAME/.muttrc
  193. echo $'# Encrypt items in the Sent folder' >> /home/$MY_USERNAME/.muttrc
  194. echo "set pgp_encrypt_only_command=\"/usr/lib/mutt/pgpewrap gpg --batch --quiet --no-verbose --output - --encrypt --textmode --armor --always-trust --encrypt-to 0x$MY_GPG_PUBLIC_KEY_ID -- -r %r -- %f\"" >> /home/$MY_USERNAME/.muttrc
  195. else
  196. sed -i "s|set pgp_encrypt_only_command.*|set pgp_encrypt_only_command=\"/usr/lib/mutt/pgpewrap gpg --batch --quiet --no-verbose --output - --encrypt --textmode --armor --always-trust --encrypt-to 0x$MY_GPG_PUBLIC_KEY_ID -- -r %r -- %f\"|g" /home/$MY_USERNAME/.muttrc
  197. fi
  198. if ! grep -q "pgp_encrypt_sign_command" /home/$MY_USERNAME/.muttrc; then
  199. echo "set pgp_encrypt_sign_command=\"/usr/lib/mutt/pgpewrap gpg %?p?--passphrase-fd 0? --batch --quiet --no-verbose --textmode --output - --encrypt --sign %?a?-u %a? --armor --always-trust --encrypt-to 0x$MY_GPG_PUBLIC_KEY_ID -- -r %r -- %f\"" >> /home/$MY_USERNAME/.muttrc
  200. else
  201. sed -i "s|set pgp_encrypt_sign_command.*|set pgp_encrypt_sign_command=\"/usr/lib/mutt/pgpewrap gpg %?p?--passphrase-fd 0? --batch --quiet --no-verbose --textmode --output - --encrypt --sign %?a?-u %a? --armor --always-trust --encrypt-to 0x$MY_GPG_PUBLIC_KEY_ID -- -r %r -- %f\"|g" /home/$MY_USERNAME/.muttrc
  202. fi
  203. mark_completed $FUNCNAME
  204. }
  205. function encrypt_all_email {
  206. if [ ! -d /etc/exim4 ]; then
  207. return
  208. fi
  209. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  210. return
  211. fi
  212. if [ -f /usr/local/bin/${PROJECT_NAME}-encrypt-mail ]; then
  213. cp /usr/local/bin/${PROJECT_NAME}-encrypt-mail /usr/bin/encmaildir
  214. else
  215. cp /usr/bin/${PROJECT_NAME}-encrypt-mail /usr/bin/encmaildir
  216. fi
  217. chmod +x /usr/bin/encmaildir
  218. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  219. return
  220. fi
  221. if [ ! /home/$MY_USERNAME/README ]; then
  222. touch /home/$MY_USERNAME/README
  223. fi
  224. if ! grep -q $"If you have imported legacy email which is not encrypted" /home/$MY_USERNAME/README; then
  225. echo '' >> /home/$MY_USERNAME/README
  226. echo '' >> /home/$MY_USERNAME/README
  227. echo $'# Encrypting legacy email' >> /home/$MY_USERNAME/README
  228. echo $'If you have imported legacy email which is not encrypted' >> /home/$MY_USERNAME/README
  229. echo $'then it can be encrypted with the command:' >> /home/$MY_USERNAME/README
  230. echo '' >> /home/$MY_USERNAME/README
  231. echo ' encmaildir' >> /home/$MY_USERNAME/README
  232. echo '' >> /home/$MY_USERNAME/README
  233. echo $'But be warned that depending upon how much email you have' >> /home/$MY_USERNAME/README
  234. echo $'this could take a seriously LONG time on the Beaglebone' >> /home/$MY_USERNAME/README
  235. echo $'and may be better done on a faster machine.' >> /home/$MY_USERNAME/README
  236. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  237. chmod 600 /home/$MY_USERNAME/README
  238. fi
  239. mark_completed $FUNCNAME
  240. }
  241. function email_client {
  242. if [ ! -d /etc/exim4 ]; then
  243. return
  244. fi
  245. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  246. return
  247. fi
  248. apt-get -yq install mutt-patched lynx abook urlview
  249. if [ ! -f /etc/Muttrc ]; then
  250. echo $"ERROR: Mutt does not appear to have installed. $CHECK_MESSAGE"
  251. exit 49
  252. fi
  253. if [ ! -d /home/$MY_USERNAME/.mutt ]; then
  254. mkdir /home/$MY_USERNAME/.mutt
  255. fi
  256. echo "text/html; lynx -dump -width=78 -nolist %s | sed ‘s/^ //’; copiousoutput; needsterminal; nametemplate=%s.html" > /home/$MY_USERNAME/.mutt/mailcap
  257. cp /home/$MY_USERNAME/.mutt/mailcap /etc/skel/.mutt
  258. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.mutt
  259. chown -R root:root /etc/skel/.mutt
  260. echo 'set mbox_type=Maildir' >> /etc/Muttrc
  261. echo 'set folder="~/Maildir"' >> /etc/Muttrc
  262. echo 'set mask="!^\\.[^.]"' >> /etc/Muttrc
  263. echo 'set mbox="~/Maildir"' >> /etc/Muttrc
  264. echo 'set record="+Sent"' >> /etc/Muttrc
  265. echo 'set postponed="+Drafts"' >> /etc/Muttrc
  266. echo 'set trash="+Trash"' >> /etc/Muttrc
  267. echo 'set spoolfile="~/Maildir"' >> /etc/Muttrc
  268. echo 'auto_view text/x-vcard text/html text/enriched' >> /etc/Muttrc
  269. echo 'set header_cache="+.cache"' >> /etc/Muttrc
  270. echo 'set markers=no' >> /etc/Muttrc
  271. echo '' >> /etc/Muttrc
  272. echo '# ctrl-u to view long URLs' >> /etc/Muttrc
  273. echo 'macro pager \cu <pipe-entry>"urlview"<enter> "Follow links with urlview"' >> /etc/Muttrc
  274. echo '' >> /etc/Muttrc
  275. echo 'macro index S "<tag-prefix><decode-save>=.learn-spam<enter>" "move to learn-spam"' >> /etc/Muttrc
  276. echo 'macro pager S "<decode-save>=.learn-spam<enter>" "move to learn-spam"' >> /etc/Muttrc
  277. echo 'macro index H "<tag-prefix><decode-copy>=.learn-ham<enter>" "copy to learn-ham"' >> /etc/Muttrc
  278. echo 'macro pager H "<decode-copy>=.learn-ham<enter>" "copy to learn-ham"' >> /etc/Muttrc
  279. echo '' >> /etc/Muttrc
  280. echo '# set up the sidebar' >> /etc/Muttrc
  281. echo 'set sidebar_width=22' >> /etc/Muttrc
  282. echo 'set sidebar_visible=yes' >> /etc/Muttrc
  283. echo "set sidebar_delim='|'" >> /etc/Muttrc
  284. echo 'set sidebar_sort=yes' >> /etc/Muttrc
  285. echo '' >> /etc/Muttrc
  286. echo 'set rfc2047_parameters' >> /etc/Muttrc
  287. echo '' >> /etc/Muttrc
  288. echo '# Show inbox and sent items' >> /etc/Muttrc
  289. echo 'mailboxes = =admin =Sent =maybe-spam =spam' >> /etc/Muttrc
  290. echo '' >> /etc/Muttrc
  291. echo '# Alter these colours as needed for maximum bling' >> /etc/Muttrc
  292. echo 'color sidebar_new yellow default' >> /etc/Muttrc
  293. echo 'color normal white default' >> /etc/Muttrc
  294. echo 'color hdrdefault brightcyan default' >> /etc/Muttrc
  295. echo 'color signature green default' >> /etc/Muttrc
  296. echo 'color attachment brightyellow default' >> /etc/Muttrc
  297. echo 'color quoted green default' >> /etc/Muttrc
  298. echo 'color quoted1 white default' >> /etc/Muttrc
  299. echo 'color tilde blue default' >> /etc/Muttrc
  300. echo '' >> /etc/Muttrc
  301. echo '# ctrl-n, ctrl-p to select next, prev folder' >> /etc/Muttrc
  302. echo '# ctrl-o to open selected folder' >> /etc/Muttrc
  303. echo 'bind index \Cp sidebar-prev' >> /etc/Muttrc
  304. echo 'bind index \Cn sidebar-next' >> /etc/Muttrc
  305. echo 'bind index \Co sidebar-open' >> /etc/Muttrc
  306. echo 'bind pager \Cp sidebar-prev' >> /etc/Muttrc
  307. echo 'bind pager \Cn sidebar-next' >> /etc/Muttrc
  308. echo 'bind pager \Co sidebar-open' >> /etc/Muttrc
  309. echo '' >> /etc/Muttrc
  310. echo '# ctrl-b toggles sidebar visibility' >> /etc/Muttrc
  311. echo "macro index,pager \Cb '<enter-command>toggle sidebar_visible<enter><redraw-screen>' 'toggle sidebar'" >> /etc/Muttrc
  312. echo '' >> /etc/Muttrc
  313. echo '# esc-m Mark new messages as read' >> /etc/Muttrc
  314. echo 'macro index <esc>m "T~N<enter>;WNT~O<enter>;WO\CT~T<enter>" "mark all messages read"' >> /etc/Muttrc
  315. echo '' >> /etc/Muttrc
  316. echo '# Collapsing threads' >> /etc/Muttrc
  317. echo 'macro index [ "<collapse-thread>" "collapse/uncollapse thread"' >> /etc/Muttrc
  318. echo 'macro index ] "<collapse-all>" "collapse/uncollapse all threads"' >> /etc/Muttrc
  319. echo '' >> /etc/Muttrc
  320. echo '# threads containing new messages' >> /etc/Muttrc
  321. echo 'uncolor index "~(~N)"' >> /etc/Muttrc
  322. echo 'color index brightblue default "~(~N)"' >> /etc/Muttrc
  323. echo '' >> /etc/Muttrc
  324. echo '# new messages themselves' >> /etc/Muttrc
  325. echo 'uncolor index "~N"' >> /etc/Muttrc
  326. echo 'color index brightyellow default "~N"' >> /etc/Muttrc
  327. echo '' >> /etc/Muttrc
  328. echo '# GPG/PGP integration' >> /etc/Muttrc
  329. echo '# this set the number of seconds to keep in memory the passphrase used to encrypt/sign' >> /etc/Muttrc
  330. echo 'set pgp_timeout=1800' >> /etc/Muttrc
  331. echo '' >> /etc/Muttrc
  332. echo '# automatically sign and encrypt with PGP/MIME' >> /etc/Muttrc
  333. echo 'set pgp_autosign # autosign all outgoing mails' >> /etc/Muttrc
  334. echo 'set pgp_autoencrypt # Try to encrypt automatically' >> /etc/Muttrc
  335. echo 'set pgp_replyencrypt # autocrypt replies to crypted' >> /etc/Muttrc
  336. echo 'set pgp_replysign # autosign replies to signed' >> /etc/Muttrc
  337. echo 'set pgp_auto_decode=yes # decode attachments' >> /etc/Muttrc
  338. echo 'set fcc_clear=no # Keep encrypted copy of sent encrypted mail' >> /etc/Muttrc
  339. echo 'unset smime_is_default' >> /etc/Muttrc
  340. echo '' >> /etc/Muttrc
  341. echo 'set alias_file=~/.mutt-alias' >> /etc/Muttrc
  342. echo 'source ~/.mutt-alias' >> /etc/Muttrc
  343. echo 'set query_command= "abook --mutt-query \"%s\""' >> /etc/Muttrc
  344. echo 'macro index,pager A "<pipe-message>abook --add-email-quiet<return>" "add the sender address to abook"' >> /etc/Muttrc
  345. echo '' >> /etc/Muttrc
  346. echo '# Optional relay of SMTP via ISP' >> /etc/Muttrc
  347. echo '#set smtp_url="smtps://username:password@isp_mail_domain:465/"' >> /etc/Muttrc
  348. # For viewing long URLs
  349. echo 'REGEXP (((http|https|ftp|gopher)|mailto)[.:][^ >"\t]*|www\.[-a-z0-9.]+)[^ .,;\t>">\):]' > /home/$MY_USERNAME/.urlview
  350. echo 'COMMAND lynx -dump -width=78 -nolist %s' >> /home/$MY_USERNAME/.urlview
  351. cp -f /etc/Muttrc /home/$MY_USERNAME/.muttrc
  352. cp -f /etc/Muttrc /etc/skel/.muttrc
  353. cp -f /home/$MY_USERNAME/.urlview /etc/skel/.urlview
  354. touch /home/$MY_USERNAME/.mutt-alias
  355. cp /home/$MY_USERNAME/.mutt-alias /etc/skel/.mutt-alias
  356. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.muttrc
  357. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.mutt-alias
  358. # default user on generic images
  359. if [ -d /home/${GENERIC_IMAGE_USERNAME} ]; then
  360. cp -f /etc/Muttrc /home/${GENERIC_IMAGE_USERNAME}/.muttrc
  361. chown ${GENERIC_IMAGE_USERNAME}:${GENERIC_IMAGE_USERNAME} /home/${GENERIC_IMAGE_USERNAME}/.muttrc
  362. touch /home/${GENERIC_IMAGE_USERNAME}/.mutt-alias
  363. chown ${GENERIC_IMAGE_USERNAME}:${GENERIC_IMAGE_USERNAME} /home/${GENERIC_IMAGE_USERNAME}/.mutt-alias
  364. fi
  365. mark_completed $FUNCNAME
  366. }
  367. function email_archiving {
  368. if [ ! -d /etc/exim4 ]; then
  369. return
  370. fi
  371. # ensure that the mail archive script is up to date
  372. if [ -f /usr/local/bin/${PROJECT_NAME}-archive-mail ]; then
  373. cp /usr/local/bin/${PROJECT_NAME}-archive-mail /etc/cron.daily/archivemail
  374. else
  375. if [ -f /usr/bin/${PROJECT_NAME}-archive-mail ]; then
  376. cp /usr/bin/${PROJECT_NAME}-archive-mail /etc/cron.daily/archivemail
  377. else
  378. echo "/usr/bin/${PROJECT_NAME}-archive-mail was not found. ${PROJECT_NAME} might not have fully installed."
  379. exit 62379
  380. fi
  381. fi
  382. chmod +x /etc/cron.daily/archivemail
  383. # update to the next commit
  384. function_check set_repo_commit
  385. set_repo_commit $INSTALL_DIR/cleanup-maildir "cleanup-maildir commit" "$CLEANUP_MAILDIR_COMMIT" $CLEANUP_MAILDIR_REPO
  386. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  387. return
  388. fi
  389. if [ ! -d $INSTALL_DIR ]; then
  390. mkdir $INSTALL_DIR
  391. fi
  392. cd $INSTALL_DIR
  393. function_check git_clone
  394. git_clone $CLEANUP_MAILDIR_REPO $INSTALL_DIR/cleanup-maildir
  395. cd $INSTALL_DIR/cleanup-maildir
  396. git checkout $CLEANUP_MAILDIR_COMMIT -b $CLEANUP_MAILDIR_COMMIT
  397. set_completion_param "cleanup-maildir commit" "$CLEANUP_MAILDIR_COMMIT"
  398. cp $INSTALL_DIR/cleanup-maildir/cleanup-maildir /usr/bin
  399. mark_completed $FUNCNAME
  400. }
  401. # Ensure that the from field is correct when sending email from Mutt
  402. function email_from_address {
  403. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  404. return
  405. fi
  406. if [ ! -f /home/$MY_USERNAME/.muttrc ]; then
  407. return
  408. fi
  409. if grep -q "set from=" /home/$MY_USERNAME/.muttrc; then
  410. sed -i "s|set from=.*|set from='$MY_NAME <$MY_EMAIL_ADDRESS>'|g" /home/$MY_USERNAME/.muttrc
  411. else
  412. echo "set from='$MY_NAME <$MY_EMAIL_ADDRESS>'" >> /home/$MY_USERNAME/.muttrc
  413. fi
  414. mark_completed $FUNCNAME
  415. }
  416. function create_public_mailing_list {
  417. if [ ! -d /etc/exim4 ]; then
  418. return
  419. fi
  420. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  421. return
  422. fi
  423. if [ ! $PUBLIC_MAILING_LIST ]; then
  424. return
  425. fi
  426. # does the mailing list have a separate domain name?
  427. if [ ! $PUBLIC_MAILING_LIST_DOMAIN_NAME ]; then
  428. PUBLIC_MAILING_LIST_DOMAIN_NAME=$DEFAULT_DOMAIN_NAME
  429. fi
  430. PUBLIC_MAILING_LIST_USER="mlmmj"
  431. apt-get -yq install mlmmj
  432. adduser --system $PUBLIC_MAILING_LIST_USER
  433. addgroup $PUBLIC_MAILING_LIST_USER
  434. adduser $PUBLIC_MAILING_LIST_USER $PUBLIC_MAILING_LIST_USER
  435. echo ''
  436. echo $"Creating the $PUBLIC_MAILING_LIST mailing list"
  437. echo ''
  438. # create the list
  439. mlmmj-make-ml -a -L "$PUBLIC_MAILING_LIST" -c $PUBLIC_MAILING_LIST_USER
  440. echo 'SYSTEM_ALIASES_PIPE_TRANSPORT = address_pipe' > /etc/exim4/conf.d/main/000_localmacros
  441. echo "SYSTEM_ALIASES_USER = $PUBLIC_MAILING_LIST_USER" >> /etc/exim4/conf.d/main/000_localmacros
  442. echo "SYSTEM_ALIASES_GROUP = $PUBLIC_MAILING_LIST_USER" >> /etc/exim4/conf.d/main/000_localmacros
  443. # router
  444. echo 'mlmmj_router:' > /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  445. echo ' debug_print = "R: mlmmj_router for $local_part@$domain"' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  446. echo ' driver = accept' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  447. echo ' domains = +mlmmj_domains' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  448. echo ' #require_files = MLMMJ_HOME/${lc::$local_part}' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  449. echo ' # Use this instead, if you dont want to give Exim rx rights to mlmmj spool.' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  450. echo ' # Exim will then spawn a new process running under the UID of "mlmmj".' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  451. echo ' require_files = mlmmj:MLMMJ_HOME/${lc::$local_part}' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  452. echo ' local_part_suffix = +*' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  453. echo ' local_part_suffix_optional' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  454. echo ' headers_remove = Delivered-To' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  455. echo ' headers_add = Delivered-To: $local_part$local_part_suffix@$domain' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  456. echo ' transport = mlmmj_transport' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  457. # transport
  458. echo 'mlmmj_transport:' > /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  459. echo ' debug_print = "T: mlmmj_transport for $local_part@$domain"' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  460. echo ' driver = pipe' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  461. echo ' return_path_add' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  462. echo ' user = mlmmj' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  463. echo ' group = mlmmj' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  464. echo ' home_directory = MLMMJ_HOME' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  465. echo ' current_directory = MLMMJ_HOME' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  466. echo ' command = /usr/bin/mlmmj-receive -F -L MLMMJ_HOME/${lc:$local_part}' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  467. if ! grep -q "MLMMJ_HOME=/var/spool/mlmmj" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  468. sed -i '/MAIN CONFIGURATION SETTINGS/a\MLMMJ_HOME=/var/spool/mlmmj' /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  469. fi
  470. if ! grep -q "domainlist mlmmj_domains =" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  471. sed -i "/MLMMJ_HOME/a\domainlist mlmmj_domains = $PUBLIC_MAILING_LIST_DOMAIN_NAME" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  472. fi
  473. if ! grep -q "delay_warning_condition =" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  474. sed -i '/domainlist mlmmj_domains =/a\delay_warning_condition = ${if match_domain{$domain}{+mlmmj_domains}{no}{yes}}' /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  475. fi
  476. if ! grep -q ": +mlmmj_domains" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  477. sed -i 's/domainlist relay_to_domains = MAIN_RELAY_TO_DOMAINS/domainlist relay_to_domains = MAIN_RELAY_TO_DOMAINS : +mlmmj_domains/g' /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  478. fi
  479. if ! grep -q "! +mlmmj_domains" /etc/exim4/conf.d/router/200_exim4-config_primary; then
  480. sed -i 's/domains = ! +local_domains/domains = ! +mlmmj_domains : ! +local_domains/g' /etc/exim4/conf.d/router/200_exim4-config_primary
  481. fi
  482. update-exim4.conf.template -r
  483. update-exim4.conf
  484. systemctl restart exim4
  485. if ! grep -q $"$PUBLIC_MAILING_LIST mailing list" /home/$MY_USERNAME/README; then
  486. echo '' >> /home/$MY_USERNAME/README
  487. echo '' >> /home/$MY_USERNAME/README
  488. echo $"$PUBLIC_MAILING_LIST mailing list" >> /home/$MY_USERNAME/README
  489. echo '=================================' >> /home/$MY_USERNAME/README
  490. echo $"To subscribe to the $PUBLIC_MAILING_LIST mailing list send a" >> /home/$MY_USERNAME/README
  491. echo $"cleartext email to $PUBLIC_MAILING_LIST+subscribe@$DEFAULT_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  492. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  493. chmod 600 /home/$MY_USERNAME/README
  494. fi
  495. ${PROJECT_NAME}-addlist -u $MY_USERNAME -l "$PUBLIC_MAILING_LIST" -s "$PUBLIC_MAILING_LIST"
  496. mark_completed $FUNCNAME
  497. }
  498. function create_private_mailing_list {
  499. if [ ! -d /etc/exim4 ]; then
  500. return
  501. fi
  502. # This installation doesn't work, results in ruby errors
  503. # There is currently no schleuder package for Debian jessie
  504. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  505. return
  506. fi
  507. if [ ! $PRIVATE_MAILING_LIST ]; then
  508. return
  509. fi
  510. if [[ $PRIVATE_MAILING_LIST == $MY_USERNAME ]]; then
  511. echo $'The name of the private mailing list should not be the same as your username'
  512. exit 10
  513. fi
  514. if [ ! $MY_GPG_PUBLIC_KEY ]; then
  515. echo $'To create a private mailing list you need to specify a file'
  516. echo $'containing your exported GPG key within MY_GPG_PUBLIC_KEY at'
  517. echo $'the top of the script'
  518. exit 11
  519. fi
  520. apt-get -yq install ruby ruby-dev ruby-gpgme libgpgme11-dev libmagic-dev
  521. gem install schleuder
  522. schleuder-fix-gem-dependencies
  523. schleuder-init-setup --gem
  524. # NOTE: this is version number sensitive and so might need changing
  525. ln -s /var/lib/gems/2.1.0/gems/schleuder-2.2.4 /var/lib/schleuder
  526. sed -i 's/#smtp_port: 25/smtp_port: 465/g' /etc/schleuder/schleuder.conf
  527. sed -i 's/#superadminaddr: root@localhost/superadminaddr: root@localhost' /etc/schleuder/schleuder.conf
  528. schleuder-newlist $PRIVATE_MAILING_LIST@$DEFAULT_DOMAIN_NAME -realname "$PRIVATE_MAILING_LIST" -adminaddress $MY_EMAIL_ADDRESS -initmember $MY_EMAIL_ADDRESS -initmemberkey $MY_GPG_PUBLIC_KEY -nointeractive
  529. ${PROJECT_NAME}-addemail -u $MY_USERNAME -e $PRIVATE_MAILING_LIST@$DEFAULT_DOMAIN_NAME -l $PRIVATE_MAILING_LIST
  530. echo 'schleuder:' > /etc/exim4/conf.d/router/550_exim4-config_schleuder
  531. echo ' debug_print = "R: schleuder for $local_part@$domain"' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  532. echo ' driver = accept' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  533. echo ' local_part_suffix_optional' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  534. echo ' local_part_suffix = +* : -bounce : -sendkey' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  535. echo ' domains = +local_domains' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  536. echo ' user = schleuder' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  537. echo ' group = schleuder' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  538. echo ' require_files = schleuder:+/var/lib/schleuder/$domain/${local_part}' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  539. echo ' transport = schleuder_transport' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  540. echo 'schleuder_transport:' > /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  541. echo ' debug_print = "T: schleuder_transport for $local_part@$domain"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  542. echo ' driver = pipe' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  543. echo ' home_directory = "/var/lib/schleuder/$domain/$local_part"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  544. echo ' command = "/usr/bin/schleuder $local_part@$domain"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  545. chown -R schleuder:schleuder /var/lib/schleuder
  546. update-exim4.conf.template -r
  547. update-exim4.conf
  548. systemctl restart exim4
  549. chmod 600 /etc/shadow
  550. chmod 600 /etc/gshadow
  551. useradd -d /var/schleuderlists -s /bin/false schleuder
  552. adduser Debian-exim schleuder
  553. usermod -a -G mail schleuder
  554. chmod 0000 /etc/shadow
  555. chmod 0000 /etc/gshadow
  556. #exim -d -bt $PRIVATE_MAILING_LIST@$DEFAULT_DOMAIN_NAME
  557. mark_completed $FUNCNAME
  558. }
  559. function split_gpg_key_into_fragments {
  560. # split the gpg key into fragments if social key management is enabled
  561. if [[ $ENABLE_SOCIAL_KEY_MANAGEMENT == "yes" ]]; then
  562. echo 'Splitting GPG key. You may need to enter your passphrase.'
  563. ${PROJECT_NAME}-splitkey -u $MY_USERNAME -e $MY_EMAIL_ADDRESS --fullname "$MY_NAME"
  564. if [ ! -d /home/$MY_USERNAME/.gnupg_fragments ]; then
  565. echo 'Yhe GPG key could not be split'
  566. exit 86548
  567. fi
  568. fi
  569. }
  570. function import_email {
  571. if [ ! -d /etc/exim4 ]; then
  572. return
  573. fi
  574. EMAIL_COMPLETE_MSG=$"
  575. *** ${PROJECT_NAME} mailbox installation is complete ***
  576. Now on your internet router forward ports
  577. 25, 587, 465, 993 and 2222 to the ${PROJECT_NAME}
  578. "
  579. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  580. if [[ $SYSTEM_TYPE == "mail"* ]]; then
  581. function_check backup_to_friends_servers
  582. backup_to_friends_servers
  583. function_check install_tripwire
  584. install_tripwire
  585. function_check split_gpg_key_into_fragments
  586. split_gpg_key_into_fragments
  587. clear
  588. echo ''
  589. echo "$EMAIL_COMPLETE_MSG"
  590. if [ -d $USB_MOUNT ]; then
  591. umount $USB_MOUNT
  592. rm -rf $USB_MOUNT
  593. echo $' You can now remove the USB drive'
  594. fi
  595. exit 0
  596. fi
  597. return
  598. fi
  599. mark_completed $FUNCNAME
  600. if [[ $SYSTEM_TYPE == "mail"* ]]; then
  601. function_check backup_to_friends_servers
  602. backup_to_friends_servers
  603. function_check install_tripwire
  604. install_tripwire
  605. function_check split_gpg_key_into_fragments
  606. split_gpg_key_into_fragments
  607. # unmount any attached usb drive
  608. clear
  609. echo ''
  610. echo "$EMAIL_COMPLETE_MSG"
  611. echo ''
  612. if [ -d $USB_MOUNT ]; then
  613. umount $USB_MOUNT
  614. rm -rf $USB_MOUNT
  615. echo $' You can now remove the USB drive'
  616. fi
  617. exit 0
  618. fi
  619. }
  620. function remove_email {
  621. echo ''
  622. }
  623. function install_email_with_tor {
  624. apt-get -yq remove postfix
  625. apt-get -yq install exim4 sasl2-bin swaks libnet-ssleay-perl procmail xinetd
  626. if [ ! -d /etc/exim4 ]; then
  627. echo $"ERROR: Exim does not appear to have installed. $CHECK_MESSAGE"
  628. exit 48
  629. fi
  630. onion_service_name='email'
  631. if [ ! -d /var/lib/tor ]; then
  632. echo $"No Tor installation found. ${onion_service_name} onion site cannot be configured."
  633. exit 877367
  634. fi
  635. if ! grep -q "hidden_service_${onion_service_name}" /etc/tor/torrc; then
  636. echo "HiddenServiceDir /var/lib/tor/hidden_service_${onion_service_name}/" >> /etc/tor/torrc
  637. echo 'HiddenServicePort 25 127.0.0.1:25' >> /etc/tor/torrc
  638. echo 'HiddenServicePort 587 127.0.0.1:587' >> /etc/tor/torrc
  639. echo 'HiddenServicePort 465 127.0.0.1:465' >> /etc/tor/torrc
  640. echo 'HiddenServicePort 993 127.0.0.1:993' >> /etc/tor/torrc
  641. echo $"Added onion site for ${onion_service_name}"
  642. fi
  643. onion_update
  644. function_check wait_for_onion_service
  645. wait_for_onion_service ${onion_service_name}
  646. if [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; then
  647. echo $"${onion_service_name} onion site hostname not found"
  648. exit 76362
  649. fi
  650. EMAIL_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_${onion_service_name}/hostname)
  651. if [[ $ONION_ONLY != "no" ]]; then
  652. function_check set_hostname
  653. set_hostname ${EMAIL_ONION_HOSTNAME}
  654. MY_EMAIL_ADDRESS=${MY_USERNAME}@${DEFAULT_DOMAIN_NAME}
  655. fi
  656. set_completion_param "email onion domain" "${EMAIL_ONION_HOSTNAME}"
  657. # see https://github.com/petterreinholdtsen/exim4-smtorp
  658. echo '# tor stuff first' > /etc/exim4/conf.d/router/100_exim4-smtorp
  659. echo '#' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  660. echo '# if were submitting mail *from* a .tor/.onion address,' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  661. echo '# make sure any header lines that may give us away is' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  662. echo '# stripped out, and add a new, cryptic Message-ID.' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  663. echo '# In address_data we store the name we should HELO as.' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  664. echo 'tor_to_any:' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  665. echo ' debug_print = "R: manualroute from .onion to $local_part@$domain"' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  666. echo ' driver = manualroute' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  667. echo ' domains = ! +local_domains' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  668. echo ' condition = ${if match {$sender_address_domain}{\N.*\.(onion|tor)$\N}}' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  669. echo ' address_data = $sender_address_domain' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  670. echo ' transport = remote_smtp_onion' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  671. echo ' self = send' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  672. echo ' route_list = * localhost' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  673. echo ' headers_remove = Received:Message-ID:X-Mailer:User-Agent' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  674. echo ' headers_add = Message-ID: <${lc:${sha1:$message_id}}@$sender_address_domain>' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  675. echo '' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  676. echo '# this catches the case where were submitting mail' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  677. echo '# from a regular email address where we dont need to' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  678. echo '# rewrite any headers' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  679. echo 'any_to_tor:' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  680. echo ' debug_print = "R: manualroute for $local_part@$domain"' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  681. echo ' driver = manualroute' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  682. echo ' domains = ! +local_domains' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  683. echo ' transport = remote_smtp_onion' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  684. echo ' self = send' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  685. echo ' route_list = *.onion localhost ; *.tor localhost' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  686. echo ' address_data = $smtp_active_hostname' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  687. echo 'remote_smtp_onion:' > /etc/exim4/conf.d/transport/100_exim4-smtorp
  688. echo ' debug_print = "T: remote_smtp_onion for $local_part@$original_domain"' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  689. echo ' driver = smtp' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  690. echo '' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  691. echo ' # set helo_data to where we want to connect to,' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  692. echo ' # for the proxy program tor-smtp' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  693. echo ' helo_data = "$address_data $original_domain"' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  694. echo '' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  695. echo ' # wherever we configured our script at' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  696. echo ' port = 12668' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  697. echo '' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  698. echo ' # cannot use TLS otherwise it will EHLO again!!' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  699. echo ' hosts_avoid_tls = *' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  700. if [ ! -d $INSTALL_DIR ]; then
  701. mkdir -p $INSTALL_DIR
  702. fi
  703. cd $INSTALL_DIR
  704. function_check git_clone
  705. git_clone $EXIM_ONION_REPO $INSTALL_DIR/exim4-smtorp
  706. cd $INSTALL_DIR/exim4-smtorp/tor-smtp
  707. make
  708. if [ ! -f $INSTALL_DIR/exim4-smtorp/tor-smtp/tor-smtp ]; then
  709. echo $'Unable to make tor smtp transport'
  710. exit 52629
  711. fi
  712. if [ ! -d /usr/lib/exim4-smtorp ]; then
  713. mkdir /usr/lib/exim4-smtorp
  714. fi
  715. cp $INSTALL_DIR/exim4-smtorp/tor-smtp/tor-smtp /usr/lib/exim4-smtorp/tor-smtp
  716. if [ ! -f /usr/lib/exim4-smtorp/tor-smtp ]; then
  717. echo $'Unable to copy tor-smtp'
  718. exit 83503
  719. fi
  720. cp $INSTALL_DIR/exim4-smtorp/xinetd /etc/xinetd.d/tor-smtp
  721. if [ ! -f /etc/xinetd.d/tor-smtp ]; then
  722. echo $'Unable to copy to xinetd.d'
  723. exit 835954
  724. fi
  725. systemctl restart xinetd
  726. # configure for Maildir format
  727. sed -i 's/MAIL_DIR/#MAIL_DIR/g' /etc/login.defs
  728. sed -i 's|#MAIL_FILE.*|MAIL_FILE Maildir/|g' /etc/login.defs
  729. if ! grep -q "export MAIL" /etc/profile; then
  730. echo 'export MAIL=~/Maildir' >> /etc/profile
  731. fi
  732. sed -i 's|pam_mail.so standard|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/login
  733. sed -i 's|pam_mail.so standard noenv|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/sshd
  734. sed -i 's|pam_mail.so nopen|pam_mail.so dir=~/Maildir nopen|g' /etc/pam.d/su
  735. echo "dc_eximconfig_configtype='internet'" > /etc/exim4/update-exim4.conf.conf
  736. if [[ $ONION_ONLY == "no" ]]; then
  737. # both ICANN and onion domains
  738. echo "dc_other_hostnames='${DEFAULT_DOMAIN_NAME};mail.${DEFAULT_DOMAIN_NAME};${EMAIL_ONION_HOSTNAME}'" >> /etc/exim4/update-exim4.conf.conf
  739. else
  740. echo "dc_other_hostnames='${EMAIL_ONION_HOSTNAME}'" >> /etc/exim4/update-exim4.conf.conf
  741. fi
  742. echo "dc_local_interfaces=''" >> /etc/exim4/update-exim4.conf.conf
  743. echo "dc_readhost=''" >> /etc/exim4/update-exim4.conf.conf
  744. echo "dc_relay_domains=''" >> /etc/exim4/update-exim4.conf.conf
  745. echo "dc_minimaldns='false'" >> /etc/exim4/update-exim4.conf.conf
  746. IPv4_address=$(get_ipv4_address)
  747. IPv4_address_base=$(echo "$IPv4_address" | awk -F '.' '{print $1"."$2"."$3}')
  748. RELAY_NETS="${IPv4_address_base}.0/24"
  749. if [ $LOCAL_NETWORK_STATIC_IP_ADDRESS ]; then
  750. RELAY_NETS=$(echo $LOCAL_NETWORK_STATIC_IP_ADDRESS | awk -F '.' '{print $1 "." $2 "." $3 ".0/24"}')
  751. fi
  752. echo "dc_relay_nets='$RELAY_NETS'" >> /etc/exim4/update-exim4.conf.conf
  753. echo "dc_smarthost=''" >> /etc/exim4/update-exim4.conf.conf
  754. echo "CFILEMODE='644'" >> /etc/exim4/update-exim4.conf.conf
  755. echo "dc_use_split_config='false'" >> /etc/exim4/update-exim4.conf.conf
  756. echo "dc_hide_mailname=''" >> /etc/exim4/update-exim4.conf.conf
  757. echo "dc_mailname_in_oh='true'" >> /etc/exim4/update-exim4.conf.conf
  758. echo "dc_localdelivery='maildir_home'" >> /etc/exim4/update-exim4.conf.conf
  759. echo "dc_main_log_selector=-all" >> /etc/exim4/update-exim4.conf.conf
  760. update-exim4.conf
  761. sed -i "s/START=no/START=yes/g" /etc/default/saslauthd
  762. systemctl start saslauthd
  763. # make a tls certificate for email
  764. if [ ! -f /etc/ssl/certs/exim.dhparam ]; then
  765. ${PROJECT_NAME}-addcert -h exim --dhkey $DH_KEYLENGTH
  766. check_certificates exim
  767. fi
  768. cp /etc/ssl/private/exim.key /etc/exim4
  769. cp /etc/ssl/certs/exim.crt /etc/exim4
  770. cp /etc/ssl/certs/exim.dhparam /etc/exim4
  771. chown root:Debian-exim /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  772. chmod 640 /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  773. sed -i '/login_saslauthd_server/,/.endif/ s/# *//' /etc/exim4/exim4.conf.template
  774. if ! grep -q "MAIN_TLS_ENABLE = true" /etc/exim4/exim4.conf.template; then
  775. sed -i "/.ifdef MAIN_HARDCODE_PRIMARY_HOSTNAME/i\MAIN_HARDCODE_PRIMARY_HOSTNAME =\nMAIN_TLS_ENABLE = true" /etc/exim4/exim4.conf.template
  776. else
  777. sed -i "s|MAIN_HARDCODE_PRIMARY_HOSTNAME =.*|MAIN_HARDCODE_PRIMARY_HOSTNAME =|g" /etc/exim4/exim4.conf.template
  778. fi
  779. sed -i "s|SMTPLISTENEROPTIONS=''|SMTPLISTENEROPTIONS='-oX 465:25:587 -oP /var/run/exim4/exim.pid'|g" /etc/default/exim4
  780. if ! grep -q "tls_on_connect_ports=465" /etc/exim4/exim4.conf.template; then
  781. sed -i '/SSL configuration for exim/i\tls_on_connect_ports=465' /etc/exim4/exim4.conf.template
  782. fi
  783. if ! grep -q "# don't send system passwords" /etc/exim4/exim4.conf.template; then
  784. sed -i "s|don't send system passwords.*|# don't send system passwords unencrypted|g" /etc/exim4/exim4.conf.template
  785. fi
  786. adduser $MY_USERNAME sasl
  787. addgroup Debian-exim sasl
  788. systemctl restart exim4
  789. if [ ! -d /etc/skel/log ]; then
  790. mkdir -m 700 /etc/skel/log
  791. fi
  792. if [ ! -d /etc/skel/Maildir ]; then
  793. mkdir -m 700 /etc/skel/.mutt
  794. mkdir -m 700 /etc/skel/Maildir
  795. mkdir -m 700 /etc/skel/Maildir/new
  796. mkdir -m 700 /etc/skel/Maildir/cur
  797. mkdir -m 700 /etc/skel/Maildir/Sent
  798. mkdir -m 700 /etc/skel/Maildir/Sent/tmp
  799. mkdir -m 700 /etc/skel/Maildir/Sent/cur
  800. mkdir -m 700 /etc/skel/Maildir/Sent/new
  801. mkdir -m 700 /etc/skel/Maildir/.learn-spam
  802. mkdir -m 700 /etc/skel/Maildir/.learn-spam/cur
  803. mkdir -m 700 /etc/skel/Maildir/.learn-spam/new
  804. mkdir -m 700 /etc/skel/Maildir/.learn-spam/tmp
  805. mkdir -m 700 /etc/skel/Maildir/.learn-ham
  806. mkdir -m 700 /etc/skel/Maildir/.learn-ham/cur
  807. mkdir -m 700 /etc/skel/Maildir/.learn-ham/new
  808. mkdir -m 700 /etc/skel/Maildir/.learn-ham/tmp
  809. ln -s /etc/skel/Maildir/.learn-spam /etc/skel/Maildir/spam
  810. ln -s /etc/skel/Maildir/.learn-ham /etc/skel/Maildir/ham
  811. fi
  812. if [ ! -d /home/$MY_USERNAME/Maildir ]; then
  813. mkdir -m 700 /home/$MY_USERNAME/.mutt
  814. mkdir -m 700 /home/$MY_USERNAME/Maildir
  815. mkdir -m 700 /home/$MY_USERNAME/Maildir/cur
  816. mkdir -m 700 /home/$MY_USERNAME/Maildir/tmp
  817. mkdir -m 700 /home/$MY_USERNAME/Maildir/new
  818. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent
  819. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/cur
  820. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/tmp
  821. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/new
  822. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam
  823. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/cur
  824. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/new
  825. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/tmp
  826. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham
  827. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/cur
  828. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/new
  829. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/tmp
  830. ln -s /home/$MY_USERNAME/Maildir/.learn-spam /home/$MY_USERNAME/Maildir/spam
  831. ln -s /home/$MY_USERNAME/Maildir/.learn-ham /home/$MY_USERNAME/Maildir/ham
  832. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir
  833. fi
  834. if [ -f /usr/sbin/exim ]; then
  835. chmod u+s /usr/sbin/exim
  836. fi
  837. if [ -f /usr/sbin/exim4 ]; then
  838. chmod u+s /usr/sbin/exim4
  839. fi
  840. function_check configure_firewall_for_email
  841. configure_firewall_for_email
  842. dpkg-reconfigure --frontend noninteractive exim4-config
  843. }
  844. function install_email_basic {
  845. apt-get -yq remove postfix
  846. apt-get -yq install exim4 sasl2-bin swaks libnet-ssleay-perl procmail
  847. if [ ! -d /etc/exim4 ]; then
  848. echo $"ERROR: Exim does not appear to have installed. $CHECK_MESSAGE"
  849. exit 48
  850. fi
  851. # configure for Maildir format
  852. sed -i 's/MAIL_DIR/#MAIL_DIR/g' /etc/login.defs
  853. sed -i 's|#MAIL_FILE.*|MAIL_FILE Maildir/|g' /etc/login.defs
  854. if ! grep -q "export MAIL" /etc/profile; then
  855. echo 'export MAIL=~/Maildir' >> /etc/profile
  856. fi
  857. sed -i 's|pam_mail.so standard|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/login
  858. sed -i 's|pam_mail.so standard noenv|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/sshd
  859. sed -i 's|pam_mail.so nopen|pam_mail.so dir=~/Maildir nopen|g' /etc/pam.d/su
  860. echo "dc_eximconfig_configtype='internet'" > /etc/exim4/update-exim4.conf.conf
  861. echo "dc_other_hostnames='${DEFAULT_DOMAIN_NAME};mail.${DEFAULT_DOMAIN_NAME}'" >> /etc/exim4/update-exim4.conf.conf
  862. echo "dc_local_interfaces=''" >> /etc/exim4/update-exim4.conf.conf
  863. echo "dc_readhost=''" >> /etc/exim4/update-exim4.conf.conf
  864. echo "dc_relay_domains=''" >> /etc/exim4/update-exim4.conf.conf
  865. echo "dc_minimaldns='false'" >> /etc/exim4/update-exim4.conf.conf
  866. IPv4_address=$(get_ipv4_address)
  867. IPv4_address_base=$(echo "$IPv4_address" | awk -F '.' '{print $1"."$2"."$3}')
  868. RELAY_NETS="${IPv4_address_base}.0/24"
  869. if [ $LOCAL_NETWORK_STATIC_IP_ADDRESS ]; then
  870. RELAY_NETS=$(echo $LOCAL_NETWORK_STATIC_IP_ADDRESS | awk -F '.' '{print $1 "." $2 "." $3 ".0/24"}')
  871. fi
  872. echo "dc_relay_nets='$RELAY_NETS'" >> /etc/exim4/update-exim4.conf.conf
  873. echo "dc_smarthost=''" >> /etc/exim4/update-exim4.conf.conf
  874. echo "CFILEMODE='644'" >> /etc/exim4/update-exim4.conf.conf
  875. echo "dc_use_split_config='false'" >> /etc/exim4/update-exim4.conf.conf
  876. echo "dc_hide_mailname=''" >> /etc/exim4/update-exim4.conf.conf
  877. echo "dc_mailname_in_oh='true'" >> /etc/exim4/update-exim4.conf.conf
  878. echo "dc_localdelivery='maildir_home'" >> /etc/exim4/update-exim4.conf.conf
  879. echo "dc_main_log_selector=-all" >> /etc/exim4/update-exim4.conf.conf
  880. update-exim4.conf
  881. sed -i "s/START=no/START=yes/g" /etc/default/saslauthd
  882. systemctl start saslauthd
  883. # make a tls certificate for email
  884. if [ ! -f /etc/ssl/certs/exim.dhparam ]; then
  885. ${PROJECT_NAME}-addcert -h exim --dhkey $DH_KEYLENGTH
  886. check_certificates exim
  887. fi
  888. cp /etc/ssl/private/exim.key /etc/exim4
  889. cp /etc/ssl/certs/exim.crt /etc/exim4
  890. cp /etc/ssl/certs/exim.dhparam /etc/exim4
  891. chown root:Debian-exim /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  892. chmod 640 /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  893. if [ ! -d /etc/skel/log ]; then
  894. mkdir -m 700 /etc/skel/log
  895. fi
  896. if [ ! -d /etc/skel/Maildir ]; then
  897. mkdir -m 700 /etc/skel/.mutt
  898. mkdir -m 700 /etc/skel/Maildir
  899. mkdir -m 700 /etc/skel/Maildir/new
  900. mkdir -m 700 /etc/skel/Maildir/cur
  901. mkdir -m 700 /etc/skel/Maildir/Sent
  902. mkdir -m 700 /etc/skel/Maildir/Sent/tmp
  903. mkdir -m 700 /etc/skel/Maildir/Sent/cur
  904. mkdir -m 700 /etc/skel/Maildir/Sent/new
  905. mkdir -m 700 /etc/skel/Maildir/.learn-spam
  906. mkdir -m 700 /etc/skel/Maildir/.learn-spam/cur
  907. mkdir -m 700 /etc/skel/Maildir/.learn-spam/new
  908. mkdir -m 700 /etc/skel/Maildir/.learn-spam/tmp
  909. mkdir -m 700 /etc/skel/Maildir/.learn-ham
  910. mkdir -m 700 /etc/skel/Maildir/.learn-ham/cur
  911. mkdir -m 700 /etc/skel/Maildir/.learn-ham/new
  912. mkdir -m 700 /etc/skel/Maildir/.learn-ham/tmp
  913. ln -s /etc/skel/Maildir/.learn-spam /etc/skel/Maildir/spam
  914. ln -s /etc/skel/Maildir/.learn-ham /etc/skel/Maildir/ham
  915. fi
  916. if [ ! -d /home/$MY_USERNAME/Maildir ]; then
  917. mkdir -m 700 /home/$MY_USERNAME/.mutt
  918. mkdir -m 700 /home/$MY_USERNAME/Maildir
  919. mkdir -m 700 /home/$MY_USERNAME/Maildir/cur
  920. mkdir -m 700 /home/$MY_USERNAME/Maildir/tmp
  921. mkdir -m 700 /home/$MY_USERNAME/Maildir/new
  922. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent
  923. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/cur
  924. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/tmp
  925. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/new
  926. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam
  927. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/cur
  928. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/new
  929. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/tmp
  930. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham
  931. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/cur
  932. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/new
  933. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/tmp
  934. ln -s /home/$MY_USERNAME/Maildir/.learn-spam /home/$MY_USERNAME/Maildir/spam
  935. ln -s /home/$MY_USERNAME/Maildir/.learn-ham /home/$MY_USERNAME/Maildir/ham
  936. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir
  937. fi
  938. function_check configure_firewall_for_email
  939. configure_firewall_for_email
  940. if [ -f /usr/sbin/exim ]; then
  941. chmod u+s /usr/sbin/exim
  942. fi
  943. if [ -f /usr/sbin/exim4 ]; then
  944. chmod u+s /usr/sbin/exim4
  945. fi
  946. dpkg-reconfigure --frontend noninteractive exim4-config
  947. systemctl restart exim4
  948. }
  949. function email_change_relay {
  950. curr_ip_address="$1"
  951. email_relay_base=$(echo "$curr_ip_address" | awk -F '.' '{print $1"."$2"."$3}')
  952. RELAY_NETS="${email_relay_base}.0/24"
  953. sed -i "s|dc_relay_nets=.*|dc_relay_nets='$RELAY_NETS'|g" /etc/exim4/update-exim4.conf.conf
  954. dpkg-reconfigure --frontend noninteractive exim4-config
  955. }
  956. function create_procmail {
  957. if [ ! -d /etc/exim4 ]; then
  958. return
  959. fi
  960. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  961. return
  962. fi
  963. if [ ! -f /home/$MY_USERNAME/.procmailrc ]; then
  964. echo 'MAILDIR=$HOME/Maildir' > /home/$MY_USERNAME/.procmailrc
  965. echo 'DEFAULT=$MAILDIR/' >> /home/$MY_USERNAME/.procmailrc
  966. echo 'LOGFILE=$HOME/log/procmail.log' >> /home/$MY_USERNAME/.procmailrc
  967. echo 'LOGABSTRACT=all' >> /home/$MY_USERNAME/.procmailrc
  968. echo '' >> /home/$MY_USERNAME/.procmailrc
  969. echo $"# Tripwire reports which have no violations don't need to be logged" >> /home/$MY_USERNAME/.procmailrc
  970. echo ':0 BD:' >> /home/$MY_USERNAME/.procmailrc
  971. TRIPWIRE_VIOLATIONS_STR=$'Total violations found: 0'
  972. echo " * .*$TRIPWIRE_VIOLATIONS_STR" >> /home/$MY_USERNAME/.procmailrc
  973. echo '/dev/null' >> /home/$MY_USERNAME/.procmailrc
  974. echo '' >> /home/$MY_USERNAME/.procmailrc
  975. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  976. fi
  977. mkdir -p /home/$MY_USERNAME/Maildir/admin/new
  978. mkdir -p /home/$MY_USERNAME/Maildir/admin/cur
  979. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir/admin
  980. if [ ! -f /etc/skel/.procmailrc ]; then
  981. cp /home/$MY_USERNAME/.procmailrc /etc/skel/.procmailrc
  982. chown root:root /etc/skel/.procmailrc
  983. fi
  984. if [ -f /usr/bin/procmail ]; then
  985. chmod 6755 /usr/bin/procmail
  986. fi
  987. mark_completed $FUNCNAME
  988. }
  989. function handle_admin_emails {
  990. # keep emails for root in a separate folder
  991. if [ -d /home/$MY_USERNAME/Maildir/admin ]; then
  992. return
  993. fi
  994. ${PROJECT_NAME}-addemail -u $MY_USERNAME -e "root@$DEFAULT_DOMAIN_NAME" -g admin --public no
  995. }
  996. function spam_filtering {
  997. if [ ! -d /etc/exim4 ]; then
  998. return
  999. fi
  1000. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  1001. return
  1002. fi
  1003. apt-get -yq install exim4-daemon-heavy
  1004. apt-get -yq install spamassassin
  1005. if [ ! -f /etc/default/spamassassin ]; then
  1006. echo 'Spamassassin was not installed'
  1007. exit 72570
  1008. fi
  1009. sa-update -v
  1010. sed -i 's/ENABLED=0/ENABLED=1/g' /etc/default/spamassassin
  1011. sed -i 's/# spamd_address = 127.0.0.1 783/spamd_address = 127.0.0.1 783/g' /etc/exim4/exim4.conf.template
  1012. # This configuration is based on https://wiki.debian.org/DebianSpamAssassin
  1013. sed -i 's/local_parts = postmaster/local_parts = postmaster:abuse/g' /etc/exim4/conf.d/acl/30_exim4-config_check_rcpt
  1014. sed -i '/domains = +local_domains : +relay_to_domains/a\ set acl_m0 = rfcnames' /etc/exim4/conf.d/acl/30_exim4-config_check_rcpt
  1015. sed -i 's/accept/accept condition = ${if eq{$acl_m0}{rfcnames} {1}{0}}/g' /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1016. echo 'warn message = X-Spam-Score: $spam_score ($spam_bar)' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1017. echo ' spam = nobody:true' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1018. echo 'warn message = X-Spam-Flag: YES' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1019. echo ' spam = nobody' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1020. echo 'warn message = X-Spam-Report: $spam_report' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1021. echo ' spam = nobody' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1022. echo '# reject spam at high scores (> 12)' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1023. echo 'deny message = This message scored $spam_score spam points.' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1024. echo ' spam = nobody:true' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1025. echo ' condition = ${if >{$spam_score_int}{120}{1}{0}}' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  1026. # procmail configuration
  1027. echo '# get spamassassin to check emails' >> /home/$MY_USERNAME/.procmailrc
  1028. echo ':0fw: .spamassassin.lock' >> /home/$MY_USERNAME/.procmailrc
  1029. echo ' * < 256000' >> /home/$MY_USERNAME/.procmailrc
  1030. echo '| spamc' >> /home/$MY_USERNAME/.procmailrc
  1031. echo '# strong spam are discarded' >> /home/$MY_USERNAME/.procmailrc
  1032. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  1033. echo ' * ^X-Spam-Level: \*\*\*\*\*\*' >> /home/$MY_USERNAME/.procmailrc
  1034. echo '/dev/null' >> /home/$MY_USERNAME/.procmailrc
  1035. echo '# weak spam are kept just in case - clear this out every now and then' >> /home/$MY_USERNAME/.procmailrc
  1036. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  1037. echo ' * ^X-Spam-Level: \*\*\*\*\*' >> /home/$MY_USERNAME/.procmailrc
  1038. echo 'maybe-spam/' >> /home/$MY_USERNAME/.procmailrc
  1039. echo '# otherwise, marginal spam goes here for revision' >> /home/$MY_USERNAME/.procmailrc
  1040. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  1041. echo ' * ^X-Spam-Level: \*\*' >> /home/$MY_USERNAME/.procmailrc
  1042. echo 'spam/' >> /home/$MY_USERNAME/.procmailrc
  1043. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  1044. echo '# get spamassassin to check emails' >> /etc/skel/.procmailrc
  1045. echo ':0fw: .spamassassin.lock' >> /etc/skel/.procmailrc
  1046. echo ' * < 256000' >> /etc/skel/.procmailrc
  1047. echo '| spamc' >> /etc/skel/.procmailrc
  1048. echo '# strong spam are discarded' >> /etc/skel/.procmailrc
  1049. echo ':0' >> /etc/skel/.procmailrc
  1050. echo ' * ^X-Spam-Level: \*\*\*\*\*\*' >> /etc/skel/.procmailrc
  1051. echo '/dev/null' >> /etc/skel/.procmailrc
  1052. echo '# weak spam are kept just in case - clear this out every now and then' >> /etc/skel/.procmailrc
  1053. echo ':0' >> /etc/skel/.procmailrc
  1054. echo ' * ^X-Spam-Level: \*\*\*\*\*' >> /etc/skel/.procmailrc
  1055. echo 'maybe-spam/' >> /etc/skel/.procmailrc
  1056. echo '# otherwise, marginal spam goes here for revision' >> /etc/skel/.procmailrc
  1057. echo ':0' >> /etc/skel/.procmailrc
  1058. echo ' * ^X-Spam-Level: \*\*' >> /etc/skel/.procmailrc
  1059. echo 'spam/' >> /etc/skel/.procmailrc
  1060. # filtering scripts
  1061. echo '#!/bin/bash' > /usr/bin/filterspam
  1062. echo 'for d in /home/*/ ; do' >> /usr/bin/filterspam
  1063. echo ' USERNAME=$(echo "$d" | awk -F '"'"'/'"'"' '"'"'{print $3}'"'"')' >> /usr/bin/filterspam
  1064. echo ' if [[ $USERNAME != "git" && $USERNAME != "go" && $USERNAME != "gogs" && $USERNAME != "mirrors" && $USERNAME != "sync" && $USERNAME != "tahoelafs" ]]; then' >> /usr/bin/filterspam
  1065. echo ' MAILDIR=/home/$USERNAME/Maildir/.learn-spam' >> /usr/bin/filterspam
  1066. echo ' if [ ! -d "$MAILDIR" ]; then' >> /usr/bin/filterspam
  1067. echo ' exit' >> /usr/bin/filterspam
  1068. echo ' fi' >> /usr/bin/filterspam
  1069. echo ' for f in `ls $MAILDIR/cur`' >> /usr/bin/filterspam
  1070. echo ' do' >> /usr/bin/filterspam
  1071. echo ' spamc -L spam < "$MAILDIR/cur/$f" > /dev/null' >> /usr/bin/filterspam
  1072. echo ' rm "$MAILDIR/cur/$f"' >> /usr/bin/filterspam
  1073. echo ' done' >> /usr/bin/filterspam
  1074. echo ' for f in `ls $MAILDIR/new`' >> /usr/bin/filterspam
  1075. echo ' do' >> /usr/bin/filterspam
  1076. echo ' spamc -L spam < "$MAILDIR/new/$f" > /dev/null' >> /usr/bin/filterspam
  1077. echo ' rm "$MAILDIR/new/$f"' >> /usr/bin/filterspam
  1078. echo ' done' >> /usr/bin/filterspam
  1079. echo ' fi' >> /usr/bin/filterspam
  1080. echo 'done' >> /usr/bin/filterspam
  1081. echo 'exit 0' >> /usr/bin/filterspam
  1082. echo '#!/bin/bash' > /usr/bin/filterham
  1083. echo 'for d in /home/*/ ; do' >> /usr/bin/filterham
  1084. echo ' USERNAME=$(echo "$d" | awk -F '"'"'/'"'"' '"'"'{print $3}'"'"')' >> /usr/bin/filterham
  1085. echo ' if [[ $USERNAME != "git" && $USERNAME != "go" && $USERNAME != "gogs" && $USERNAME != "mirrors" && $USERNAME != "sync" && $USERNAME != "tahoelafs" ]]; then' >> /usr/bin/filterham
  1086. echo ' MAILDIR=/home/$USERNAME/Maildir/.learn-ham' >> /usr/bin/filterham
  1087. echo ' if [ ! -d "$MAILDIR" ]; then' >> /usr/bin/filterham
  1088. echo ' exit' >> /usr/bin/filterham
  1089. echo ' fi' >> /usr/bin/filterham
  1090. echo ' for f in `ls $MAILDIR/cur`' >> /usr/bin/filterham
  1091. echo ' do' >> /usr/bin/filterham
  1092. echo ' spamc -L ham < "$MAILDIR/cur/$f" > /dev/null' >> /usr/bin/filterham
  1093. echo ' rm "$MAILDIR/cur/$f"' >> /usr/bin/filterham
  1094. echo ' done' >> /usr/bin/filterham
  1095. echo ' for f in `ls $MAILDIR/new`' >> /usr/bin/filterham
  1096. echo ' do' >> /usr/bin/filterham
  1097. echo ' spamc -L ham < "$MAILDIR/new/$f" > /dev/null' >> /usr/bin/filterham
  1098. echo ' rm "$MAILDIR/new/$f"' >> /usr/bin/filterham
  1099. echo ' done' >> /usr/bin/filterham
  1100. echo ' fi' >> /usr/bin/filterham
  1101. echo 'done' >> /usr/bin/filterham
  1102. echo 'exit 0' >> /usr/bin/filterham
  1103. function_check cron_add_mins
  1104. cron_add_mins 3 '/usr/bin/timeout 120 /usr/bin/filterspam'
  1105. cron_add_mins 3 '/usr/bin/timeout 120 /usr/bin/filterham'
  1106. chmod 655 /usr/bin/filterspam /usr/bin/filterham
  1107. sed -i 's/# use_bayes 1/use_bayes 1/g' /etc/mail/spamassassin/local.cf
  1108. sed -i 's/# bayes_auto_learn 1/bayes_auto_learn 1/g' /etc/mail/spamassassin/local.cf
  1109. # user preferences
  1110. if [ ! -d /home/$MY_USERNAME/.spamassassin ]; then
  1111. mkdir /home/$MY_USERNAME/.spamassassin
  1112. echo $'# How many points before a mail is considered spam.' > /home/$MY_USERNAME/.spamassassin/user_prefs
  1113. echo '# required_score 5' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1114. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1115. echo $'# Whitelist and blacklist addresses are now file-glob-style patterns, so' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1116. echo $'# "friend@somewhere.com", "*@isp.com", or "*.domain.net" will all work.' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1117. echo '# whitelist_from someone@somewhere.com' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1118. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1119. echo $'# Add your own customised scores for some tests below. The default scores are' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1120. echo $'# read from the installed spamassassin rules files, but you can override them' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1121. echo $'# here. To see the list of tests and their default scores, go to' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1122. echo '# http://spamassassin.apache.org/tests.html .' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1123. echo '#' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1124. echo '# score SYMBOLIC_TEST_NAME n.nn' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1125. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1126. echo $'# Speakers of Asian languages, like Chinese, Japanese and Korean, will almost' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1127. echo $'# definitely want to uncomment the following lines. They will switch off some' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1128. echo $'# rules that detect 8-bit characters, which commonly trigger on mails using CJK' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1129. echo $'# character sets, or that assume a western-style charset is in use. ' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1130. echo '# ' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1131. echo '# score HTML_COMMENT_8BITS 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1132. echo '# score UPPERCASE_25_50 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1133. echo '# score UPPERCASE_50_75 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1134. echo '# score UPPERCASE_75_100 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1135. echo '# score OBSCURED_EMAIL 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1136. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1137. echo $'# Speakers of any language that uses non-English, accented characters may wish' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1138. echo $'# to uncomment the following lines. They turn off rules that fire on' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1139. echo $'# misformatted messages generated by common mail apps in contravention of the' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1140. echo $'# email RFCs.' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1141. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1142. echo '# score SUBJ_ILLEGAL_CHARS 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  1143. fi
  1144. # this must be accessible by root
  1145. chown -R $MY_USERNAME:root /home/$MY_USERNAME/.spamassassin
  1146. # script to keep spamassassin running
  1147. # There is a systemd script from the debian package, but it doesn't restart on failure
  1148. # and also doesn't ensure start after networking is up. If that is eventually fixed
  1149. # then this script and the cron job which runs it can be removed.
  1150. script_name=/usr/bin/run-spamassassin
  1151. echo '#!/bin/bash' > $script_name
  1152. echo 'current_state=$(systemctl status spamassassin)' >> $script_name
  1153. echo 'if [[ "$current_state" != *"(running)"* ]]; then' >> $script_name
  1154. echo ' systemctl restart spamassassin' >> $script_name
  1155. echo 'fi' >> $script_name
  1156. echo 'exit 0' >> $script_name
  1157. chmod +x $script_name
  1158. systemctl start spamassassin
  1159. systemctl restart exim4
  1160. systemctl restart cron
  1161. function_check cron_add_mins
  1162. cron_add_mins 10 "$script_name 2> /dev/null"
  1163. mark_completed $FUNCNAME
  1164. }
  1165. function configure_imap {
  1166. if [ ! -d /etc/exim4 ]; then
  1167. return
  1168. fi
  1169. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  1170. return
  1171. fi
  1172. dpkg -P dovecot-imapd
  1173. dpkg -P dovecot-core
  1174. apt-get -yq install dovecot-imapd
  1175. if [ ! -d /etc/dovecot ]; then
  1176. echo $"ERROR: Dovecot does not appear to have installed. $CHECK_MESSAGE"
  1177. exit 48
  1178. fi
  1179. if [[ $ONION_ONLY == 'no' ]]; then
  1180. # obtain a cert for the default domain
  1181. if [[ "$(cert_exists ${DEFAULT_DOMAIN_NAME} pem)" == "0" ]]; then
  1182. echo $'Obtaining certificate for the main domain'
  1183. create_site_certificate ${DEFAULT_DOMAIN_NAME} 'yes'
  1184. fi
  1185. fi
  1186. if [[ "$(cert_exists ${DEFAULT_DOMAIN_NAME} pem)" == "0" ]]; then
  1187. if [[ "$(cert_exists dovecot)" == "0" ]]; then
  1188. ${PROJECT_NAME}-addcert -h dovecot --dhkey $DH_KEYLENGTH
  1189. check_certificates dovecot
  1190. fi
  1191. fi
  1192. chmod 600 /etc/shadow
  1193. chmod 600 /etc/gshadow
  1194. groupadd default
  1195. usermod -g default dovecot
  1196. chmod 0000 /etc/shadow
  1197. chmod 0000 /etc/gshadow
  1198. chown root:default /etc/ssl/certs/dovecot.*
  1199. chown root:default /etc/ssl/private/dovecot.*
  1200. chown root:default /etc/ssl/certs/${DEFAULT_DOMAIN_NAME}.*
  1201. chown root:default /etc/ssl/private/${DEFAULT_DOMAIN_NAME}.*
  1202. if [ ! -f /etc/dovecot/conf.d/10-ssl.conf ]; then
  1203. echo $'Unable to find /etc/dovecot/conf.d/10-ssl.conf'
  1204. exit 83629
  1205. fi
  1206. sed -i 's|#ssl =.*|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  1207. sed -i 's|ssl =.*|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  1208. if [[ "$(cert_exists ${DEFAULT_DOMAIN_NAME} pem)" == "1" ]]; then
  1209. sed -i "s|#ssl_cert =.*|ssl_cert = </etc/ssl/certs/${DEFAULT_DOMAIN_NAME}.pem|g" /etc/dovecot/conf.d/10-ssl.conf
  1210. sed -i "s|ssl_cert =.*|ssl_cert = </etc/ssl/certs/${DEFAULT_DOMAIN_NAME}.pem|g" /etc/dovecot/conf.d/10-ssl.conf
  1211. else
  1212. sed -i "s|#ssl_cert =.*|ssl_cert = </etc/ssl/certs/${DEFAULT_DOMAIN_NAME}.crt|g" /etc/dovecot/conf.d/10-ssl.conf
  1213. sed -i "s|ssl_cert =.*|ssl_cert = </etc/ssl/certs/${DEFAULT_DOMAIN_NAME}.crt|g" /etc/dovecot/conf.d/10-ssl.conf
  1214. fi
  1215. sed -i "s|#ssl_key =.*|ssl_key = </etc/ssl/private/${DEFAULT_DOMAIN_NAME}.key|g" /etc/dovecot/conf.d/10-ssl.conf
  1216. sed -i "s|ssl_key =.*|ssl_key = </etc/ssl/private/${DEFAULT_DOMAIN_NAME}.key|g" /etc/dovecot/conf.d/10-ssl.conf
  1217. if [[ "$(cert_exists ${DEFAULT_DOMAIN_NAME})" == "1" ]]; then
  1218. sed -i "s|#ssl_dh_parameters_length.*|ssl_dh_parameters_length = ${DH_KEYLENGTH}|g" /etc/dovecot/conf.d/10-ssl.conf
  1219. fi
  1220. sed -i 's/#ssl_prefer_server_ciphers.*/ssl_prefer_server_ciphers = yes/g' /etc/dovecot/conf.d/10-ssl.conf
  1221. sed -i "s|#ssl_protocols =.*|ssl_protocols = '$SSL_PROTOCOLS'|g" /etc/dovecot/conf.d/10-ssl.conf
  1222. sed -i "s|ssl_protocols =.*|ssl_protocols = '$SSL_PROTOCOLS'|g" /etc/dovecot/conf.d/10-ssl.conf
  1223. echo "ssl_cipher_list = '$SSL_CIPHERS'" >> /etc/dovecot/conf.d/10-ssl.conf
  1224. if [ ! -f /etc/dovecot/conf.d/10-master.conf ]; then
  1225. echo $'Unable to find /etc/dovecot/conf.d/10-master.conf'
  1226. exit 49259
  1227. fi
  1228. sed -i 's/#process_limit =.*/process_limit = 100/g' /etc/dovecot/conf.d/10-master.conf
  1229. if [ ! -f /etc/dovecot/conf.d/10-logging.conf ]; then
  1230. echo $'Unable to find /etc/dovecot/conf.d/10-logging.conf'
  1231. exit 48936
  1232. fi
  1233. sed -i 's/#auth_verbose.*/auth_verbose = yes/g' /etc/dovecot/conf.d/10-logging.conf
  1234. if [ ! -f /etc/dovecot/dovecot.conf ]; then
  1235. echo $'Unable to find /etc/dovecot/dovecot.conf'
  1236. exit 43890
  1237. fi
  1238. sed -i 's/#listen =.*/listen = */g' /etc/dovecot/dovecot.conf
  1239. if [ ! -f /etc/dovecot/conf.d/10-auth.conf ]; then
  1240. echo $'Unable to find /etc/dovecot/conf.d/10-auth.conf'
  1241. exit 843256
  1242. fi
  1243. sed -i 's/#disable_plaintext_auth =.*/disable_plaintext_auth = no/g' /etc/dovecot/conf.d/10-auth.conf
  1244. sed -i 's/auth_mechanisms =.*/auth_mechanisms = plain login/g' /etc/dovecot/conf.d/10-auth.conf
  1245. if [ ! -f /etc/dovecot/conf.d/10-mail.conf ]; then
  1246. echo $'Unable to find /etc/dovecot/conf.d/10-mail.conf'
  1247. exit 42036
  1248. fi
  1249. sed -i 's|mail_location =.*|mail_location = maildir:~/Maildir:LAYOUT=fs|g' /etc/dovecot/conf.d/10-mail.conf
  1250. # This long notify interval makes the system more suited for use with
  1251. # battery powered mobile devices
  1252. sed -i 's|#imap_idle_notify_interval =.*|imap_idle_notify_interval = 29|g' /etc/dovecot/conf.d/20-imap.conf
  1253. if [ -f /var/lib/dovecot/ssl-parameters.dat ]; then
  1254. rm /var/lib/dovecot/ssl-parameters.dat
  1255. fi
  1256. if [ -f /etc/systemd/system/sockets.target.wants/dovecot.socket ]; then
  1257. rm /etc/systemd/system/sockets.target.wants/dovecot.socket
  1258. fi
  1259. # Separate logging, otherwise syslog is used
  1260. if ! grep "# logging" /etc/dovecot/dovecot.conf; then
  1261. echo '' >> /etc/dovecot/dovecot.conf
  1262. echo '# logging' >> /etc/dovecot/dovecot.conf
  1263. echo 'log_path = /var/log/dovecot.log' >> /etc/dovecot/dovecot.conf
  1264. echo 'info_log_path = /var/log/dovecot-info.log' >> /etc/dovecot/dovecot.conf
  1265. echo 'debug_log_path = /var/log/dovecot-debug.log' >> /etc/dovecot/dovecot.conf
  1266. fi
  1267. systemctl restart dovecot
  1268. mark_completed $FUNCNAME
  1269. }
  1270. function configure_imap_client_certs {
  1271. if [ ! -d /etc/exim4 ]; then
  1272. return
  1273. fi
  1274. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  1275. return
  1276. fi
  1277. # http://strange.systems/certificate-based-auth-with-dovecot-sendmail/
  1278. sed -i 's|#default_process_limit =.*|default_process_limit = 100|g' /etc/dovecot/conf.d/10-master.conf
  1279. sed -i 's/disable_plaintext_auth =.*/disable_plaintext_auth = yes/g' /etc/dovecot/conf.d/10-auth.conf
  1280. sed -i 's|#auth_ssl_require_client_cert =.*|auth_ssl_require_client_cert = yes|g' /etc/dovecot/conf.d/10-auth.conf
  1281. sed -i 's|#auth_ssl_username_from_cert =.*|auth_ssl_username_from_cert = yes|g' /etc/dovecot/conf.d/10-auth.conf
  1282. sed -i "s|#ssl_ca =.*|ssl_ca = /etc/ssl/certs/ca-$DEFAULT_DOMAIN_NAME.crt|g" /etc/dovecot/conf.d/10-ssl.conf
  1283. sed -i 's|#ssl_cert_username_field =.*|ssl_cert_username_field = commonName|g' /etc/dovecot/conf.d/10-ssl.conf
  1284. sed -i 's|#ssl_verify_client_cert =.*|ssl_verify_client_cert = yes|g' /etc/dovecot/conf.d/10-ssl.conf
  1285. if ! grep -q "passdb {" /etc/dovecot/conf.d/10-auth.conf; then
  1286. echo '' >> /etc/dovecot/conf.d/10-auth.conf
  1287. echo 'passdb {' >> /etc/dovecot/conf.d/10-auth.conf
  1288. echo ' driver = passwd-file' >> /etc/dovecot/conf.d/10-auth.conf
  1289. echo ' args = /etc/dovecot/passwd-file' >> /etc/dovecot/conf.d/10-auth.conf
  1290. echo ' deny = no' >> /etc/dovecot/conf.d/10-auth.conf
  1291. echo ' master = no' >> /etc/dovecot/conf.d/10-auth.conf
  1292. echo ' pass = no' >> /etc/dovecot/conf.d/10-auth.conf
  1293. echo '}' >> /etc/dovecot/conf.d/10-auth.conf
  1294. fi
  1295. if [[ $ONION_ONLY == "no" ]]; then
  1296. # make a CA cert
  1297. if [ ! -f /etc/ssl/private/ca-$DEFAULT_DOMAIN_NAME.key ]; then
  1298. if [[ $LETSENCRYPT_ENABLED != "yes" ]]; then
  1299. ${PROJECT_NAME}-addcert -h $DEFAULT_DOMAIN_NAME --ca "" --dhkey $DH_KEYLENGTH
  1300. else
  1301. ${PROJECT_NAME}-addcert -e $DEFAULT_DOMAIN_NAME -s $LETSENCRYPT_SERVER --ca "" --dhkey $DH_KEYLENGTH --email $MY_EMAIL_ADDRESS
  1302. fi
  1303. fi
  1304. fi
  1305. # CA configuration
  1306. echo '[ ca ]' > /etc/ssl/dovecot-ca.cnf
  1307. echo "default_ca = dovecot-ca" >> /etc/ssl/dovecot-ca.cnf
  1308. echo '' >> /etc/ssl/dovecot-ca.cnf
  1309. echo '[ crl_ext ]' >> /etc/ssl/dovecot-ca.cnf
  1310. echo 'authorityKeyIdentifier=keyid:always' >> /etc/ssl/dovecot-ca.cnf
  1311. echo '' >> /etc/ssl/dovecot-ca.cnf
  1312. echo '[ dovecot-ca ]' >> /etc/ssl/dovecot-ca.cnf
  1313. echo 'new_certs_dir = .' >> /etc/ssl/dovecot-ca.cnf
  1314. echo 'unique_subject = no' >> /etc/ssl/dovecot-ca.cnf
  1315. echo "certificate = /etc/ssl/certs/ca-$DEFAULT_DOMAIN_NAME.crt" >> /etc/ssl/dovecot-ca.cnf
  1316. echo 'database = ssldb' >> /etc/ssl/dovecot-ca.cnf
  1317. echo "private_key = /etc/ssl/private/ca-$DEFAULT_DOMAIN_NAME.key" >> /etc/ssl/dovecot-ca.cnf
  1318. echo 'serial = sslserial' >> /etc/ssl/dovecot-ca.cnf
  1319. echo 'default_days = 3650' >> /etc/ssl/dovecot-ca.cnf
  1320. echo 'default_md = sha256' >> /etc/ssl/dovecot-ca.cnf
  1321. echo 'default_bits = 4096' >> /etc/ssl/dovecot-ca.cnf
  1322. echo 'policy = dovecot-ca_policy' >> /etc/ssl/dovecot-ca.cnf
  1323. echo 'x509_extensions = dovecot-ca_extensions' >> /etc/ssl/dovecot-ca.cnf
  1324. echo '' >> /etc/ssl/dovecot-ca.cnf
  1325. echo '[ dovecot-ca_policy ]' >> /etc/ssl/dovecot-ca.cnf
  1326. echo 'commonName = supplied' >> /etc/ssl/dovecot-ca.cnf
  1327. echo 'stateOrProvinceName = supplied' >> /etc/ssl/dovecot-ca.cnf
  1328. echo 'countryName = supplied' >> /etc/ssl/dovecot-ca.cnf
  1329. echo 'emailAddress = optional' >> /etc/ssl/dovecot-ca.cnf
  1330. echo 'organizationName = supplied' >> /etc/ssl/dovecot-ca.cnf
  1331. echo 'organizationalUnitName = optional' >> /etc/ssl/dovecot-ca.cnf
  1332. echo '' >> /etc/ssl/dovecot-ca.cnf
  1333. echo '[ dovecot-ca_extensions ]' >> /etc/ssl/dovecot-ca.cnf
  1334. echo 'basicConstraints = CA:false' >> /etc/ssl/dovecot-ca.cnf
  1335. echo 'subjectKeyIdentifier = hash' >> /etc/ssl/dovecot-ca.cnf
  1336. echo 'authorityKeyIdentifier = keyid:always' >> /etc/ssl/dovecot-ca.cnf
  1337. echo 'keyUsage = digitalSignature,keyEncipherment' >> /etc/ssl/dovecot-ca.cnf
  1338. echo 'extendedKeyUsage = clientAuth' >> /etc/ssl/dovecot-ca.cnf
  1339. if [ -f /etc/ssl/ssldb ]; then
  1340. rm /etc/ssl/ssldb
  1341. fi
  1342. if [ -f /etc/ssl/sslserial ]; then
  1343. rm /etc/ssl/sslserial
  1344. fi
  1345. touch /etc/ssl/ssldb
  1346. echo 0001 > /etc/ssl/sslserial
  1347. #${PROJECT_NAME}-clientcert -u $MY_USERNAME
  1348. systemctl restart dovecot
  1349. mark_completed $FUNCNAME
  1350. }
  1351. function create_gpg_subkey {
  1352. if [ ! -d /etc/exim4 ]; then
  1353. return
  1354. fi
  1355. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  1356. return
  1357. fi
  1358. apt-get -yq install gnupg
  1359. GPG_KEY_USAGE=$1
  1360. if [[ $GPG_KEY_USAGE != "sign" && $GPG_KEY_USAGE != "auth" && $GPG_KEY_USAGE != "encrypt" ]]; then
  1361. echo $"Unknown subkey usage: $GPG_KEY_USAGE"
  1362. echo $'Available types: sign|auth|encrypt'
  1363. exit 14783
  1364. fi
  1365. KEYGRIP=$(gpg --fingerprint --fingerprint $MY_EMAIL_ADDRESS | grep fingerprint | tail -1 | cut -d= -f2 | sed -e 's/ //g')
  1366. # Generate a GPG subkey
  1367. # Here a 2048bit length is used to be compatible with yubikey
  1368. echo 'Key-Type: 1' > /home/$MY_USERNAME/gpg-genkey.conf
  1369. echo "Key-Grip: $KEYGRIP" > /home/$MY_USERNAME/gpg-genkey.conf
  1370. echo 'Subkey-Type: 1' >> /home/$MY_USERNAME/gpg-genkey.conf
  1371. echo 'Subkey-Length: 2048' >> /home/$MY_USERNAME/gpg-genkey.conf
  1372. echo "subkey-Usage: $GPG_KEY_USAGE" > /home/$MY_USERNAME/gpg-genkey.conf
  1373. echo "Name-Real: $MY_NAME" >> /home/$MY_USERNAME/gpg-genkey.conf
  1374. echo "Name-Email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  1375. echo "Name-Comment: $GPG_KEY_USAGE" >> /home/$MY_USERNAME/gpg-genkey.conf
  1376. echo 'Expire-Date: 0' >> /home/$MY_USERNAME/gpg-genkey.conf
  1377. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/gpg-genkey.conf
  1378. su -c "gpg --batch --gen-key /home/$MY_USERNAME/gpg-genkey.conf" - $MY_USERNAME
  1379. shred -zu /home/$MY_USERNAME/gpg-genkey.conf
  1380. MY_GPG_SUBKEY_ID=$(su -c "gpg --list-keys $MY_EMAIL_ADDRESS | grep 'pub '" - $MY_USERNAME | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  1381. mark_completed $FUNCNAME
  1382. }
  1383. function gpg_key_exists {
  1384. key_owner_username=$1
  1385. key_search_text=$2
  1386. if [[ $key_owner_username != "root" ]]; then
  1387. KEY_EXISTS=$(su -c "gpg --list-keys \"${key_search_text}\"" - $key_owner_username)
  1388. else
  1389. KEY_EXISTS=$(gpg --list-keys "${key_search_text}")
  1390. fi
  1391. if [ ! "$KEY_EXISTS" ]; then
  1392. echo "no"
  1393. return
  1394. fi
  1395. if [ "$KEY_EXISTS" == *"error"* ]; then
  1396. echo "no"
  1397. return
  1398. fi
  1399. echo "yes"
  1400. }
  1401. function gpg_pubkey_from_email {
  1402. key_owner_username=$1
  1403. key_email_address=$2
  1404. key_id=
  1405. if [[ $key_owner_username != "root" ]]; then
  1406. key_id=$(su -c "gpg --list-keys $key_email_address | grep 'pub '" - $key_owner_username | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  1407. else
  1408. key_id=$(gpg --list-keys $key_email_address | grep 'pub ' | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  1409. fi
  1410. echo $key_id
  1411. }
  1412. function configure_gpg {
  1413. if [ ! -d /etc/exim4 ]; then
  1414. return
  1415. fi
  1416. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  1417. return
  1418. fi
  1419. apt-get -yq install gnupg
  1420. check_email_address_exists
  1421. gpg_dir=/home/$MY_USERNAME/.gnupg
  1422. # if gpg keys directory was previously imported from usb
  1423. if [[ $GPG_KEYS_IMPORTED == "yes" && -d $gpg_dir ]]; then
  1424. echo $'GPG keys were imported'
  1425. sed -i "s|keyserver hkp://keys.gnupg.net|keyserver $GPG_KEYSERVER|g" $gpg_dir/gpg.conf
  1426. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  1427. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  1428. echo $'GPG public key ID could not be obtained'
  1429. fi
  1430. chown -R $MY_USERNAME:$MY_USERNAME $gpg_dir
  1431. chmod 700 $gpg_dir
  1432. chmod 600 $gpg_dir/*
  1433. mark_completed $FUNCNAME
  1434. return
  1435. fi
  1436. if [ ! -d $gpg_dir ]; then
  1437. mkdir $gpg_dir
  1438. echo "keyserver $GPG_KEYSERVER" >> $gpg_dir/gpg.conf
  1439. echo 'keyserver-options auto-key-retrieve' >> $gpg_dir/gpg.conf
  1440. fi
  1441. sed -i "s|keyserver hkp://keys.gnupg.net|keyserver $GPG_KEYSERVER|g" $gpg_dir/gpg.conf
  1442. if ! grep -q "# default preferences" $gpg_dir/gpg.conf; then
  1443. echo '' >> $gpg_dir/gpg.conf
  1444. echo '# default preferences' >> $gpg_dir/gpg.conf
  1445. echo 'personal-digest-preferences SHA256' >> $gpg_dir/gpg.conf
  1446. echo 'cert-digest-algo SHA256' >> $gpg_dir/gpg.conf
  1447. echo 'default-preference-list SHA512 SHA384 SHA256 SHA224 AES256 AES192 AES CAST5 ZLIB BZIP2 ZIP Uncompressed' >> $gpg_dir/gpg.conf
  1448. fi
  1449. chown -R $MY_USERNAME:$MY_USERNAME $gpg_dir
  1450. chmod 700 $gpg_dir
  1451. chmod 600 $gpg_dir/*
  1452. if [[ $MY_GPG_PUBLIC_KEY && $MY_GPG_PRIVATE_KEY ]]; then
  1453. echo $'Importing GPG keys from file'
  1454. echo $"Public key: $MY_GPG_PUBLIC_KEY"
  1455. echo $"Private key: $MY_GPG_PRIVATE_KEY"
  1456. # use your existing GPG keys which were exported
  1457. if [ ! -f $MY_GPG_PUBLIC_KEY ]; then
  1458. echo $"GPG public key file $MY_GPG_PUBLIC_KEY was not found"
  1459. exit 2483
  1460. fi
  1461. if [ ! -f $MY_GPG_PRIVATE_KEY ]; then
  1462. echo $"GPG private key file $MY_GPG_PRIVATE_KEY was not found"
  1463. exit 5383
  1464. fi
  1465. su -c "gpg --import $MY_GPG_PUBLIC_KEY" - $MY_USERNAME
  1466. su -c "gpg --allow-secret-key-import --import $MY_GPG_PRIVATE_KEY" - $MY_USERNAME
  1467. KEY_EXISTS=$(gpg_key_exists "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  1468. if [[ $KEY_EXISTS == "no" ]]; then
  1469. echo $"The GPG key for $MY_EMAIL_ADDRESS could not be imported"
  1470. exit 13821
  1471. fi
  1472. # for security ensure that the private key file doesn't linger around
  1473. shred -zu $MY_GPG_PRIVATE_KEY
  1474. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  1475. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  1476. echo $'GPG public key ID could not be obtained'
  1477. fi
  1478. else
  1479. # Generate a GPG key
  1480. echo 'Key-Type: 1' > /home/$MY_USERNAME/gpg-genkey.conf
  1481. echo 'Key-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  1482. echo 'Subkey-Type: 1' >> /home/$MY_USERNAME/gpg-genkey.conf
  1483. echo 'Subkey-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  1484. echo "Name-Real: $MY_NAME" >> /home/$MY_USERNAME/gpg-genkey.conf
  1485. echo "Name-Email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  1486. echo 'Expire-Date: 0' >> /home/$MY_USERNAME/gpg-genkey.conf
  1487. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/gpg-genkey.conf
  1488. echo $'Generating a new GPG key'
  1489. su -c "gpg --batch --gen-key /home/$MY_USERNAME/gpg-genkey.conf" - $MY_USERNAME
  1490. KEY_EXISTS=$(gpg_key_exists "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  1491. if [[ $KEY_EXISTS == "no" ]]; then
  1492. echo $"A GPG key for $MY_EMAIL_ADDRESS could not be created"
  1493. exit 6362
  1494. fi
  1495. shred -zu /home/$MY_USERNAME/gpg-genkey.conf
  1496. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  1497. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  1498. echo $'GPG public key ID could not be obtained'
  1499. fi
  1500. MY_GPG_PUBLIC_KEY=/tmp/public_key.gpg
  1501. su -c "gpg --output $MY_GPG_PUBLIC_KEY --armor --export $MY_GPG_PUBLIC_KEY_ID" - $MY_USERNAME
  1502. if grep -q "install_email" $COMPLETION_FILE; then
  1503. if ! grep -q $"Change your GPG password" /home/$MY_USERNAME/README; then
  1504. echo '' >> /home/$MY_USERNAME/README
  1505. echo '' >> /home/$MY_USERNAME/README
  1506. echo $'# Change your GPG password' >> /home/$MY_USERNAME/README
  1507. echo $"It's very important to add a password to your GPG key so that" >> /home/$MY_USERNAME/README
  1508. echo $"if anyone does get access to your email they still won't be able" >> /home/$MY_USERNAME/README
  1509. echo $'to read them without knowning the GPG password.' >> /home/$MY_USERNAME/README
  1510. echo $'You can change the it with:' >> /home/$MY_USERNAME/README
  1511. echo '' >> /home/$MY_USERNAME/README
  1512. echo " gpg --edit-key $MY_GPG_PUBLIC_KEY_ID" >> /home/$MY_USERNAME/README
  1513. echo ' passwd' >> /home/$MY_USERNAME/README
  1514. echo ' save' >> /home/$MY_USERNAME/README
  1515. echo ' quit' >> /home/$MY_USERNAME/README
  1516. fi
  1517. if ! grep -q $"Publish your GPG public key" /home/$MY_USERNAME/README; then
  1518. echo '' >> /home/$MY_USERNAME/README
  1519. echo '' >> /home/$MY_USERNAME/README
  1520. echo $'# Publish your GPG public key' >> /home/$MY_USERNAME/README
  1521. echo $'So that others can send emails to you securely you should' >> /home/$MY_USERNAME/README
  1522. echo $'publish your GPG public key with the command:' >> /home/$MY_USERNAME/README
  1523. echo '' >> /home/$MY_USERNAME/README
  1524. echo " gpg --send-keys $MY_GPG_PUBLIC_KEY_ID" >> /home/$MY_USERNAME/README
  1525. fi
  1526. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  1527. chmod 600 /home/$MY_USERNAME/README
  1528. fi
  1529. fi
  1530. mark_completed $FUNCNAME
  1531. }
  1532. function refresh_gpg_keys {
  1533. REFRESH_GPG_KEYS_SCRIPT=/usr/bin/update-gpg-keys
  1534. echo '#!/bin/bash' > $REFRESH_GPG_KEYS_SCRIPT
  1535. echo "if [ -f /usr/local/bin/${PROJECT_NAME}-sec ]; then" >> $REFRESH_GPG_KEYS_SCRIPT
  1536. echo " /usr/bin/timeout 600 /usr/local/bin/${PROJECT_NAME}-sec --refresh yes" >> $REFRESH_GPG_KEYS_SCRIPT
  1537. echo 'else' >> $REFRESH_GPG_KEYS_SCRIPT
  1538. echo " /usr/bin/timeout 600 /usr/bin/${PROJECT_NAME}-sec --refresh yes" >> $REFRESH_GPG_KEYS_SCRIPT
  1539. echo 'fi' >> $REFRESH_GPG_KEYS_SCRIPT
  1540. echo 'exit 0' >> $REFRESH_GPG_KEYS_SCRIPT
  1541. chmod +x $REFRESH_GPG_KEYS_SCRIPT
  1542. if grep -q "${PROJECT_NAME}-sec" /etc/crontab; then
  1543. sed -i "/${PROJECT_NAME}-sec /d" /etc/crontab
  1544. fi
  1545. if ! grep -q "$REFRESH_GPG_KEYS_SCRIPT" /etc/crontab; then
  1546. GPG_REFRESH_TIME=$(( RANDOM % 60 ))
  1547. echo "$GPG_REFRESH_TIME */$REFRESH_GPG_KEYS_HOURS * * * root cronic $REFRESH_GPG_KEYS_SCRIPT" >> /etc/crontab
  1548. systemctl restart cron
  1549. else
  1550. sed -i "s|root $REFRESH_GPG_KEYS_SCRIPT.*|root cronic $REFRESH_GPG_KEYS_SCRIPT|g" /etc/crontab
  1551. fi
  1552. }
  1553. function install_email {
  1554. if [[ $SYSTEM_TYPE == "mesh"* ]]; then
  1555. return
  1556. fi
  1557. if [[ $(is_completed $FUNCNAME) == "1" ]]; then
  1558. return
  1559. fi
  1560. check_email_address_exists
  1561. install_email_basic
  1562. configure_email_onion
  1563. #install_email_with_tor
  1564. mark_completed $FUNCNAME
  1565. }
  1566. # NOTE: deliberately no exit 0