freedombone-base-email 68KB

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