Files
espocrm/application/Espo/Core/Mail/Account/Account.php
2026-01-19 17:46:06 +01:00

168 lines
4.3 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?php
/************************************************************************
* This file is part of EspoCRM.
*
* EspoCRM Open Source CRM application.
* Copyright (C) 2014-2025 EspoCRM, Inc.
* Website: https://www.espocrm.com
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU Affero General Public License version 3.
*
* In accordance with Section 7(b) of the GNU Affero General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "EspoCRM" word.
************************************************************************/
namespace Espo\Core\Mail\Account;
use Espo\Core\Field\Date;
use Espo\Core\Field\DateTime;
use Espo\Core\Field\Link;
use Espo\Core\Field\LinkMultiple;
use Espo\Core\Mail\SmtpParams;
use Espo\Entities\Email;
interface Account
{
/**
* Update fetch-data.
*/
public function updateFetchData(FetchData $fetchData): void;
/**
* Update connected-at.
*/
public function updateConnectedAt(): void;
/**
* Relate an email with the account.
*/
public function relateEmail(Email $email): void;
/**
* Max number of emails to be fetched per iteration.
*/
public function getPortionLimit(): int;
/**
* Is available for fetching.
*/
public function isAvailableForFetching(): bool;
/**
* An email address of the account.
*/
public function getEmailAddress(): ?string;
/**
* A user fetched emails will be assigned to (through the `assignedUsers` field).
*/
public function getAssignedUser(): ?Link;
/**
* A user the account belongs to.
*/
public function getUser(): ?Link;
/**
* Users email should be related to (put into inbox).
*/
public function getUsers(): LinkMultiple;
/**
* Teams email should be related to.
*/
public function getTeams(): LinkMultiple;
/**
* Fetched emails won't be marked as read upon fetching.
*/
public function keepFetchedEmailsUnread(): bool;
/**
* Get fetch-data.
*/
public function getFetchData(): FetchData;
/**
* Fetch email since a specific date.
*/
public function getFetchSince(): ?Date;
/**
* A folder fetched emails should be put into.
*/
public function getEmailFolder(): ?Link;
/**
* A group folder fetched emails should be put into.
*/
public function getGroupEmailFolder(): ?Link;
/**
* Folders to fetch from.
*
* @return string[]
*/
public function getMonitoredFolderList(): array;
/**
* Gen an ID.
*/
public function getId(): ?string;
/**
* Get an entity type.
*/
public function getEntityType(): string;
/**
* Get IMAP params.
*/
public function getImapParams(): ?ImapParams;
/**
* @return ?class-string<object>
*/
public function getImapHandlerClassName(): ?string;
/**
* Get a SENT folder.
*/
public function getSentFolder(): ?string;
/**
* Is available for sending.
*/
public function isAvailableForSending(): bool;
/**
* Get SMTP params.
*/
public function getSmtpParams(): ?SmtpParams;
/**
* Store sent emails on IMAP.
*/
public function storeSentEmails(): bool;
/**
* Get the last connection time;
*/
public function getConnectedAt(): ?DateTime;
}