Provides an "email in" solution for the Nextcloud Deck app
 
 
 
Go to file
kidhab f84b5c5f09
Add check for MIME encoded messages
As far as I understand MIME-encoded message can be broken down into parts based upon its contents. While most mail programs add the plain text part as the first part this is not true for all programs. In fact mail2deck couldn't import the body when processing certain plain text mails with attachments - because the plain text part wasn't  at position 1.1.

With this fix imap_fetchbody requests sub-part 1 of part 1 and, if it is empty/ non-existent, it requests part 1.
2022-04-11 20:19:59 +02:00
lib Modify function to be accessible in lower versions of php. 2022-02-10 16:24:29 +02:00
.gitignore add mail attachments to deck & bug fixes 2022-02-03 15:05:17 +02:00
README.md Update README.md 2022-02-17 08:08:48 +02:00
config.example.php Add setting to disable mail notifications 2022-03-04 11:28:32 +01:00
index.php Add check for MIME encoded messages 2022-04-11 20:19:59 +02:00

README.md

mail2deck

Provides an "email in" solution for the Nextcloud Deck app

🚀 A. For users

Follow the above steps to add a new card from email.

  • Deck Bot is the user who will create the cards and it will be set up by your nextcloud admin.
  • In this tutorial email address for Deck Bot will be: bot@ncserver.com

1) Assign Deck Bot to the board.

Deck Bot must be assigned and must have edit permission inside the board.

2) Mail subject & content

Let's assume you want to add a card with title "Update website logo" on board "Website" and stack "To do". You can do this in two ways.

2.1: Set stack and board in the email subject

Here's how the email subject should look like: Update website logo b-'website' s-'to do'

  • You can use single or double quotes.

  • Case-insensitive for board and stack respectively.

2.2: Set the board in the email address

At the end of the email address prefix (before @) add "+website"

Example: bot+website@ncserver.com

  • If board has multiple words e.g. "some project", you'll have to send the email to bot+some+project@ncserver.com

In this case, if you don't specify the stack in the email subject, the card will be added in the first stack (if it exists).

Note:

  • Email content will be card description
  • You can add attachments in the email and those will be integrated in the created card

⚙️ B. For NextCloud admins to setup

Requirements

This app requires php-curl, php-mbstring ,php-imap and some sort of imap server (e.g. Postfix with Courier).

NC new user

Create a new user from User Management on your NC server, which will have to function as a bot. We chose to call him deckbot, but you can call it however you want.
Note: that you have to assign deckbot on each board you want to add new cards from email.

Configure Email

Option 1 - Set up Postfix for incoming email

You can setup Posfix mail server folowing the instructions on Posfix setup, and after that add "+" delimiter (which separe the user from the board in the email address) using the command:

sudo postconf -e "recipient_delimiter = +"

Option 2 - Use an existing email server

This could be any hosted email service. The only requirement is that you can connect to it via the IMAP protocol. Please note this option may not be as flexible as a self-hosted server. For example your email service may not support the "+"delimiter for directing messages to a specific board.

Download and install

If using a self-hosted Postfix server, clone this repository into the home directory of the incoming user. If not self-hosting, you may need to create a new user on your system and adjust the commands in future steps to match that username.

su - incoming
git clone https://github.com/newroco/mail2deck.git mail2deck

Create config.php file and edit it for your needs:

cd /home/incoming/mail2deck
cp config.example.php config.php
sudo vim config.php

You can refer to https://www.php.net/manual/en/function.imap-open.php for setting the value of MAIL_SERVER_FLAGS

Add a cronjob which will run mail2deck.

sudo crontab -u incoming -e

Add the following line in the opened file: */5 * * * * /usr/bin/php /home/incoming/mail2deck/index.php >/dev/null 2>&1

Finish

Now mail2deck will add new cards every five minutes if new emails are received.