mirror of
https://github.com/itflow-org/itflow
synced 2026-03-11 16:24:50 +00:00
Add new optional beta email parser thats based on ImapEngine instead of Webklex
This commit is contained in:
188
plugins/vendor/directorytree/imapengine/src/HasFlags.php
vendored
Normal file
188
plugins/vendor/directorytree/imapengine/src/HasFlags.php
vendored
Normal file
@@ -0,0 +1,188 @@
|
||||
<?php
|
||||
|
||||
namespace DirectoryTree\ImapEngine;
|
||||
|
||||
use BackedEnum;
|
||||
use DirectoryTree\ImapEngine\Enums\ImapFlag;
|
||||
use DirectoryTree\ImapEngine\Support\Str;
|
||||
|
||||
trait HasFlags
|
||||
{
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function markRead(): void
|
||||
{
|
||||
$this->markSeen();
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function markUnread(): void
|
||||
{
|
||||
$this->unmarkSeen();
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function markSeen(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Seen, '+');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function unmarkSeen(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Seen, '-');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function markAnswered(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Answered, '+');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function unmarkAnswered(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Answered, '-');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function markFlagged(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Flagged, '+');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function unmarkFlagged(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Flagged, '-');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function markDeleted(bool $expunge = false): void
|
||||
{
|
||||
$this->flag(ImapFlag::Deleted, '+', $expunge);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function unmarkDeleted(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Deleted, '-');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function markDraft(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Draft, '+');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function unmarkDraft(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Draft, '-');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function markRecent(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Recent, '+');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function unmarkRecent(): void
|
||||
{
|
||||
$this->flag(ImapFlag::Recent, '-');
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function isSeen(): bool
|
||||
{
|
||||
return $this->hasFlag(ImapFlag::Seen);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function isAnswered(): bool
|
||||
{
|
||||
return $this->hasFlag(ImapFlag::Answered);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function isFlagged(): bool
|
||||
{
|
||||
return $this->hasFlag(ImapFlag::Flagged);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function isDeleted(): bool
|
||||
{
|
||||
return $this->hasFlag(ImapFlag::Deleted);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function isDraft(): bool
|
||||
{
|
||||
return $this->hasFlag(ImapFlag::Draft);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function isRecent(): bool
|
||||
{
|
||||
return $this->hasFlag(ImapFlag::Recent);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
public function hasFlag(BackedEnum|string $flag): bool
|
||||
{
|
||||
return in_array(Str::enum($flag), $this->flags());
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
abstract public function flags(): array;
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
abstract public function flag(BackedEnum|string $flag, string $operation, bool $expunge = false): void;
|
||||
}
|
||||
Reference in New Issue
Block a user