Compare commits
5 Commits
3ed5acf75e
...
1.2.1
Author | SHA1 | Date | |
---|---|---|---|
375b922537 | |||
c400020425 | |||
a76ab77757 | |||
db95b12985 | |||
8648f5a62e |
@ -5,7 +5,7 @@ UI_PATH=./ui
|
|||||||
COMPOSE_PROJECT_NAME=emails
|
COMPOSE_PROJECT_NAME=emails
|
||||||
COMPOSE_PATH_SEPARATOR=:
|
COMPOSE_PATH_SEPARATOR=:
|
||||||
COMPOSE_FILE=./docker-compose.yml:${CLI_PATH}/docker-compose.yml:${API_PATH}/docker-compose.yml:${UI_PATH}/docker-compose.yml
|
COMPOSE_FILE=./docker-compose.yml:${CLI_PATH}/docker-compose.yml:${API_PATH}/docker-compose.yml:${UI_PATH}/docker-compose.yml
|
||||||
COMPOSE_PROFILES=api,ui,cli
|
COMPOSE_PROFILES=api,ui
|
||||||
|
|
||||||
ATT_PATH=./attachments
|
ATT_PATH=./attachments
|
||||||
LOGS_PATH=./logs
|
LOGS_PATH=./logs
|
||||||
|
@ -2,4 +2,5 @@ EMAIL_HOST=imap.gmail.com
|
|||||||
EMAIL_PORT=993
|
EMAIL_PORT=993
|
||||||
EMAIL_USERNAME=@gmail.com
|
EMAIL_USERNAME=@gmail.com
|
||||||
EMAIL_PASSWORD=
|
EMAIL_PASSWORD=
|
||||||
|
EMAIL_FOLDER=
|
||||||
ATTACHMENTS_FOLDER=/attachments
|
ATTACHMENTS_FOLDER=/attachments
|
49
README.md
49
README.md
@ -6,52 +6,3 @@ Grab attachments from emails by inbox.
|
|||||||
* Choose what mailboxes to watch.
|
* Choose what mailboxes to watch.
|
||||||
* Select messages that you want to grab attachments from.
|
* Select messages that you want to grab attachments from.
|
||||||
* Download (or view in browser) (decrypted) attachments from messages.
|
* Download (or view in browser) (decrypted) attachments from messages.
|
||||||
|
|
||||||
## Requirements
|
|
||||||
|
|
||||||
* Docker with Docker Compose [https://www.docker.com/](https://www.docker.com/)
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
|
|
||||||
1. Pull from repository
|
|
||||||
```
|
|
||||||
git pull git@git.provm.cl:Incoviba/emails.git
|
|
||||||
```
|
|
||||||
Change to latest release
|
|
||||||
```
|
|
||||||
git checkout release
|
|
||||||
```
|
|
||||||
2. Check the docker-compose.yml files
|
|
||||||
1. docker-compose.yml - central proxy container
|
|
||||||
2. api/docker-compose.yml - API container and database
|
|
||||||
3. cli/docker-compose.yml - CLI container that runs cron jobs
|
|
||||||
4. ui/docker-compose.yml - UI container
|
|
||||||
3. Generate the API Key
|
|
||||||
If you have openssl (comes with most linux distros) you can run this in terminal
|
|
||||||
```
|
|
||||||
echo API_KEY=`(openssl rand -hex 128)` >> .key.env
|
|
||||||
```
|
|
||||||
4. Check Environment files
|
|
||||||
1. .env - Docker Compose and Environment settings. Check volumes and ports.
|
|
||||||
2. .key.env - API_KEY, generated before.
|
|
||||||
3. .mail.env - Email Identification.
|
|
||||||
4. api/.env - Encrypted PDF files passwords.
|
|
||||||
5. api/.db.env - Database configuration.
|
|
||||||
6. cli/.env - API_URI, for connecting to the api container from the cli container. Change it if the api is someplace else.
|
|
||||||
7. ui/.env - API_URI, same as from the cli.
|
|
||||||
5. Check if every configuration is correct before starting the application
|
|
||||||
```
|
|
||||||
docker compose config
|
|
||||||
```
|
|
||||||
If everything is fine
|
|
||||||
```
|
|
||||||
docker compose up -d
|
|
||||||
```
|
|
||||||
6. Connect to the UI
|
|
||||||
Default [http://localhost:8000](http://localhost:8000)
|
|
||||||
|
|
||||||
## Development
|
|
||||||
When development there is a container for adminer, to use it you can add it into `COMPOSE_PROFILES` or run
|
|
||||||
```
|
|
||||||
docker compose up -d adminer
|
|
||||||
```
|
|
||||||
|
@ -1,2 +0,0 @@
|
|||||||
ADMINER_DESIGN=dracula
|
|
||||||
ADMINER_PLUGINS="tables-filter table-indexes-structure table-structure struct-comments json-column edit-calendar edit-textarea dump-bz2 dump-date dump-json dump-php enum-option"
|
|
@ -1,4 +0,0 @@
|
|||||||
MYSQL_ROOT_PASSWORD=
|
|
||||||
MYSQL_DATABASE=
|
|
||||||
MYSQL_USER=
|
|
||||||
MYSQL_PASSWORD=
|
|
@ -1,2 +0,0 @@
|
|||||||
PASSWORDS_SEPARATOR=,
|
|
||||||
PASSWORDS=
|
|
@ -18,7 +18,7 @@ services:
|
|||||||
env_file:
|
env_file:
|
||||||
- ${API_PATH:-.}/.env
|
- ${API_PATH:-.}/.env
|
||||||
- ${API_PATH:-.}/.db.env
|
- ${API_PATH:-.}/.db.env
|
||||||
- ${API_PATH:-.}/.mail.env
|
- .mail.env
|
||||||
- .key.env
|
- .key.env
|
||||||
volumes:
|
volumes:
|
||||||
- ${API_PATH:-.}/:/app/api
|
- ${API_PATH:-.}/:/app/api
|
||||||
|
@ -8,11 +8,6 @@ Monolog\ErrorHandler::register($app->getContainer()->get(Psr\Log\LoggerInterface
|
|||||||
try {
|
try {
|
||||||
$app->run();
|
$app->run();
|
||||||
} catch (Error | Exception $e) {
|
} catch (Error | Exception $e) {
|
||||||
$logger = $app->getContainer()->get(Psr\Log\LoggerInterface::class);
|
$app->getContainer()->get(Psr\Log\LoggerInterface::class)->error($e);
|
||||||
if (isset($_REQUEST)) {
|
|
||||||
$logger->debug(Safe\json_encode(compact('_REQUEST')));
|
|
||||||
}
|
|
||||||
$logger->debug(Safe\json_encode(compact('_SERVER')));
|
|
||||||
$logger->error($e);
|
|
||||||
throw $e;
|
throw $e;
|
||||||
}
|
}
|
||||||
|
@ -1 +0,0 @@
|
|||||||
API_URI=http://proxy:8080
|
|
@ -8,8 +8,6 @@ Monolog\ErrorHandler::register($app->getContainer()->get(Psr\Log\LoggerInterface
|
|||||||
try {
|
try {
|
||||||
$app->run();
|
$app->run();
|
||||||
} catch (Error | Exception $e) {
|
} catch (Error | Exception $e) {
|
||||||
$logger = $app->getContainer()->get(Psr\Log\LoggerInterface::class);
|
$app->getContainer()->get(\Psr\Log\LoggerInterface::class)->error($e);
|
||||||
$logger->debug(Safe\json_encode(compact('_SERVER')));
|
|
||||||
$logger->error($e);
|
|
||||||
throw $e;
|
throw $e;
|
||||||
}
|
}
|
||||||
|
@ -1 +0,0 @@
|
|||||||
API_URI=http://proxy:8080
|
|
@ -8,11 +8,7 @@ Monolog\ErrorHandler::register($app->getContainer()->get(Psr\Log\LoggerInterface
|
|||||||
try {
|
try {
|
||||||
$app->run();
|
$app->run();
|
||||||
} catch (Error | Exception $e) {
|
} catch (Error | Exception $e) {
|
||||||
$logger = $app->getContainer()->get(Psr\Log\LoggerInterface::class);
|
$app->getContainer()->get(Psr\Log\LoggerInterface::class)->debug(json_encode(compact('_REQUEST')));
|
||||||
if (isset($_REQUEST)) {
|
$app->getContainer()->get(Psr\Log\LoggerInterface::class)->error($e);
|
||||||
$logger->debug(Safe\json_encode(compact('_REQUEST')));
|
|
||||||
}
|
|
||||||
$logger->debug(Safe\json_encode(compact('_SERVER')));
|
|
||||||
$logger->error($e);
|
|
||||||
throw $e;
|
throw $e;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user