knyk / mailbox-bundle
PhpImap\Mailbox Symfony integration.
Installs: 1 697
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=7.4
- php-imap/php-imap: ^4.0
- symfony/dependency-injection: ~3.0|~4.0|~5.0
- symfony/framework-bundle: ~3.0|~4.0|~5.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.16
- phpspec/phpspec: ^6.1
- phpstan/phpstan: ^0.12
- phpunit/phpunit: ^8.5
This package is auto-updated.
Last update: 2025-02-21 23:08:48 UTC
README
Simple php-imap integration for Symfony 3.x, 4.x and 5.x.
Installation
1. Composer
From the command line run
$ composer require knyk/mailbox-bundle
If you're using Symfony Flex you're done and you can go to the configuration section otherwise you must manually register this bundle.
2. Register bundle
If you're not using Symfony Flex you must manually register this bundle in your AppKernel by adding the bundle declaration
class AppKernel extends Kernel { public function registerBundles() { $bundles = [ ... new Knyk\MailboxBundle\MailboxBundle(), ]; ... } }
Configuration
Setup your mailbox configuration. If your are using symfony 3.x without Symfony Flex add your configuration in app/config/config.yml
.
If you're using Symfony Flex open the config/packages/knyk_mailbox.yaml
and adjust its content.
Here is the example configuration:
mailbox: connections: example_connection: mailbox: "{localhost:993/imap/ssl/novalidate-cert}INBOX" username: "email@example.com" password: "password" another_connection: mailbox: "{localhost:143}INBOX" username: "username" password: "password" attachments_dir: "%kernel.root_dir%/../var/imap/attachments" server_encoding: "UTF-8"
Usage
Connections
All connections from your configuration will be accessible by injecting service like that:
App\YourService: arguments: $mailbox: '@knyk.mailbox.connection.example_connection'
With autowiring
In your controller:
<?php namespace App\Controller; use Knyk\MailboxBundle\Factory\MailboxFactory; use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; class IndexController extends AbstractController { public function indexAction(MailboxFactory $mailboxFactory) { $exampleConnection = $mailboxFactory->create('example_connection'); $anotherConnection = $mailboxFactory->create('another_connection'); ... } ... }
With service container
In your controller:
<?php namespace App\Controller; use Symfony\Bundle\FrameworkBundle\Controller\Controller; class IndexController extends Controller { public function indexAction() { $exampleConnection = $this->get('Knyk\MailboxBundle\Factory\MailboxFactory')->create('example_connection'); $anotherConnection = $this->get('Knyk\MailboxBundle\Factory\MailboxFactory')->create('another_connection'); ... } ... }
From this point you can use any of the methods provided by the php-imap library. For example
$exampleConnection = $this->get('Knyk\MailboxBundle\Factory\MailboxFactory')->create('example_connection'); $exampleConnection->getMailboxInfo();
Testing
Bundle can be tested by runing PHPUnit and phpspec tests.
php vendor/bin/phpspec run
- to run phpspec
php vendor/bin/phpunit tests/
- to run phpunit