PHP library for generating importable Gmail filters in XML
Find a file
2019-04-19 07:32:37 +01:00
bin Use class names for service names 2019-04-18 21:27:51 +01:00
examples Copy examples from example repo 2018-08-07 09:18:07 +01:00
src Add return type 2019-04-19 00:36:36 +01:00
tests Update test names 2019-04-19 07:32:09 +01:00
.gitignore Don't ignore XML files within fixtures 2019-04-19 00:39:31 +01:00
.php_cs.dist Use travis 2018-03-20 20:29:21 +00:00
.travis.yml Add Composer flags 2019-04-01 12:43:14 +01:00
CHANGELOG.md Update CHANGELOG 2019-04-19 07:32:37 +01:00
composer.json Add lint script 2019-04-18 21:12:34 +01:00
LICENSE Create LICENSE 2017-12-30 11:11:40 +00:00
phpunit.xml.dist Initial setup 2017-11-03 11:18:08 +00:00
README.md Update text 2018-09-05 22:44:44 +01:00
services.yml Use class names for service names 2019-04-18 21:27:51 +01:00

Gmail Filter Builder

Build Status

This library allows you to define Gmail filters in PHP, and then generate XML that you can import into Gmail's filter settings

Inspired by https://github.com/antifuchs/gmail-britta.

Installation and Basic Usage

Step 1: Require the Library

composer require opdavies/gmail-filter-builder

Step 2: Create Your Filters File

Create a filters.php file that returns an array of Filter objects.

For example:

<?php

require_once __DIR__.'/vendor/autoload.php';

return [
    // Add your filters.
];

Step 3: Generate the XML

Run ./vendor/bin/generate-filters to generate the XML for the filters and export it into a file.

Options

  • --input-file - specify the name of the file containing the filters (defaults to filters.php).
  • --output-file - specify the name of the output file (defaults to filters.xml).

Step 4: Import the Filters

Log in to your Gmail account and import your filters using the generated XML file.

Available Methods

Conditions

Conditions that a message must satisfy for the filter to be applied:

  • has - can be used to check for various properties, such as attachments, stars or labels. Can also be used as an alternative to some of the following methods previously - e.g. from:john@example.com - and can be useful for more advanced queries.
  • hasNot - the opposite of the above.
  • from - if the message is from a certain name or email address.
  • to - if the message is to a certain name or email address.
  • subject - if the message has a certain subject.
  • hasAttachment - if the message has an attachment.
  • fromList - if the message is from a mailing list.
  • excludeChats - exclude chats from the results (false by default).

Actions

Actions you can apply to messages that match the conditions:

  • label - add a label to the message.
  • archive - archive the message (skip the inbox).
  • labelAndArchive - both add a label and archive the message.
  • spam - mark the message as spam.
  • neverSpam - never mark the message as spam.
  • trash - delete the message.
  • read - mark the message as read.
  • star - star the message.
  • forward - forward the message to another email address.
  • important - mark the message as important.
  • notImportant - mark the message as not important.
  • categorise - apply a smart label to the message.

Loading Filters from Partials

If you want to split your filters into different partials, return an array of filters within each one and add return Opdavies\GmailFilterBuilder\Service\Partials::load() to filters.php to load and combine them.

This defaults to a directory called filters, but you can specify an alternative directory name as an argument.

Loading Addresses from a Separate File

If you want to filter based on the to address and not include your addresses within the filters repository, you can include them from within a different file using Addresses::load():

$myAddresses = Addresses::load('my-addresses.php');

return [
    Filter::create()
        ->from('foo@example.com')
        ->to($myAddresses)
        ->trash(),
];

In this example, the addresses are returned as an array from ~/.gmail-filters/my-addresses.php and then used as a condition in the filter.

Filter Examples

// If an email is from a certain address, add a label.
Filter::create()
    ->from('john@example.com')
    ->label('Something');

References