IMAPTransporter
A classe IMAPTransporter
permite-lhe recuperar mensagens a partir de um servidor de mensagens IMAP.
Objecto IMAP Transporter
Os objetos do IMAP Transporter são instanciados com o comando IMAP New transporter. Eles oferecem as propriedades abaixo e funções:
.acceptUnsecureConnection : Boolean True if 4D is allowed to establish an unencrypted connection |
.addFlags( msgIDs : Collection ; keywords : Object ) : Object .addFlags( msgIDs : Text ; keywords : Object ) : Object .addFlags( msgIDs : Longint ; keywords : Object ) : Object adiciona sinalizadores aos msgIDs para as keywords especificadas |
.append( mailObj : Object ; destinationBox : Text ; options : Object ) : Object anexa um mailObj à destinationBox |
.authenticationMode : Text the authentication mode used to open the session on the mail server |
.checkConnection() : Object checks the connection using information stored in the transporter object |
.checkConnectionDelay : Integer o tempo máximo (em segundos) permitido antes de verificar a conexão com o servidor |
.connectionTimeOut : Integer the maximum wait time (in seconds) allowed to establish a connection to the server |
.copy( msgsIDs : Collection ; destinationBox : Text ) : Object .copy( allMsgs : Integer ; destinationBox : Text ) : Object copia as mensagens definidas por msgsIDs ou allMsgs para destinationBox no servidor IMAP |
.createBox( name : Text ) : Object cria uma caixa de correio com o name fornecido |
.delete( msgsIDs : Collection ) : Object .delete( allMsgs : Integer ) : Object define o sinalizador "deleted" para as mensagens definidas em msgsIDs ou allMsgs |
.deleteBox( name : Text ) : Object remove permanentemente a caixa de correio com o name fornecido do servidor IMAP |
.expunge() : Object remove todas as mensagens com o sinalizador "deleted" do servidor de e-mail IMAP. |
.getBoxInfo( { name : Text }) : Object retorna um objeto boxInfo correspondente à maibox atual ou à caixa de correio name |
.getBoxList( { parameters : Object } ) : Collection retorna uma coleção de caixas de correio que descreve todas as caixas de correio disponíveis |
.getDelimiter() : Text retorna o caractere usado para delimitar os níveis de hierarquia no nome da caixa de correio |
.getMail( msgNumber: Integer { ; options : Object } ) : Object .getMail( msgID: Text { ; options : Object } ) : Object retorna o objeto Email correspondente ao msgNumber ou msgID na caixa de correio designada pelo IMAP_transporter |
.getMails( ids : Collection { ; options : Object } ) : Object .getMails( startMsg : Integer ; endMsg : Integer { ; options : Object } ) : Object retorna um objeto que contém uma coleção de objetos Email |
.getMIMEAsBlob( msgNumber : Integer { ; updateSeen : Boolean } ) : Blob .getMIMEAsBlob( msgID : Text { ; updateSeen : Boolean } ) : Blob retorna um BLOB contendo o conteúdo MIME da mensagem correspondente ao msgNumber ou msgID na caixa de correio designada pelo IMAP_transporter |
.host : Text the name or the IP address of the host server |
.logFile : Text the path of the extended log file defined (if any) for the mail connection |
.move( msgsIDs : Collection ; destinationBox : Text ) : Object .move( allMsgs : Integer ; destinationBox : Text ) : Object move as mensagens definidas por msgsIDs ou allMsgs para destinationBox no servidor IMAP |
.numToID( startMsg : Integer ; endMsg : Integer ) : Collection converte os números de sequência em IDs exclusivos do IMAP para as mensagens no intervalo sequencial designado por startMsg e endMsg |
.removeFlags( msgIDs : Collection ; keywords : Object ) : Object .removeFlags( msgIDs : Text ; keywords : Object ) : Object .removeFlags( msgIDs : Longint ; keywords : Object ) : Object remove os sinalizadores dos msgIDs para as keywords especificadas |
.renameBox( currentName : Text ; newName : Text ) : Object altera o nome de uma caixa de correio no servidor IMAP |
.port : Integer the port number used for mail transactions |
.searchMails( searchCriteria : Text ) : Collection procura por mensagens que correspondam aos searchCriteria fornecidos na caixa de correio atual |
.selectBox( name : Text { ; state : Integer } ) : Object seleciona a caixa de correio name como a caixa de correio atual |
.subscribe( name : Text ) : Object permite adicionar a caixa de correio especificada ao conjunto de caixas de correio "subscritas" do servidor IMAP |
.unsubscribe( name : Text ) : Object remove uma caixa de correio de um conjunto de caixas de correio inscritas |
.port : Integer the port number used for mail transactions |
IMAP New transporter
História
Release | Mudanças |
---|---|
18 R4 | Adicionado |
IMAP New transporter( server : Object ) : 4D.IMAPTransporter
Parâmetro | Tipo | Descrição | |
---|---|---|---|
server | Object | -> | Informação de servidor de correio |
Resultados | 4D.IMAPTransporter | <- | Objeto transportador IMAP |
Descrição
O comando IMAP New transporter
configura uma nova conexão IMAP de acordo com o parâmetro server e retorna um novo objeto transporter. O objeto transporter retornado vai geralmente ser usado para receber emails.
No parâmetro server, passe um objeto contendo as propriedades abaixo:
server | Valor padrão (se omitido) |
---|---|
.acceptUnsecureConnection : Boolean True if 4D is allowed to establish an unencrypted connection | False |
.accessTokenOAuth2: Text .accessTokenOAuth2: Objeto Cadeia ou objeto token que representa as credenciais de autorização OAuth2. Usado somente com OAUTH2 authenticationMode . Se accessTokenOAuth2 for usado, mas authenticationMode for omitido, o protocolo OAuth 2 será usado (se permitido pelo servidor). Não retornado no objeto IMAP transporter. | nenhum |
.authenticationMode : Text the authentication mode used to open the session on the mail server | o modo de autenticação mais seguro disponível no servidor é usado |
.checkConnectionDelay : Integer o tempo máximo (em segundos) permitido antes de verificar a conexão com o servidor | 300 |
.connectionTimeOut : Integer the maximum wait time (in seconds) allowed to establish a connection to the server | 30 |
.host : Text the name or the IP address of the host server | mandatory |
.logFile : Text the path of the extended log file defined (if any) for the mail connection | nenhum |
senha : Texto Senha do usuário para autenticação no servidor. Não retornado no objeto IMAP transporter. | nenhum |
.port : Integer the port number used for mail transactions | 993 |
.port : Integer the port number used for mail transactions | nenhum |
Aviso: certifique-se de que o tempo limite definido seja menor que o tempo limite do servidor, caso contrário, o tempo limite do cliente será inútil.
Resultados
A função retorna um objeto transportador IMAP. Todas as propriedades retornadas são apenas leitura.
A ligação IMAP é automaticamente fechada quando o objecto transportador é destruído.
Exemplo
$server:=New object
$server.host:="imap.gmail.com" //Obrigatório
$server.port:=993
$server.user:="4d@gmail.com"
$server.password:="XXXXXXXX"
$server.logFile:="LogTest.txt" //log para salvar na pasta Logs
var $transporter : 4D.IMAPTransporter
$transporter:=IMAP New transporter($server)
$status:=$transporter.checkConnection()
If(Not($status.success))
ALERT("An error occurred: "+$status.statusText)
End if
4D.IMAPTransporter.new()
4D.IMAPTransporter.new( server : Object ) : 4D.IMAPTransporter
Parâmetro | Tipo | Descrição | |
---|---|---|---|
server | Object | -> | Informação de servidor de correio |
Resultados | 4D.IMAPTransporter | <- | Objeto transportador IMAP |
Descrição
A função 4D.IMAPTransporter.new()
cria e retorna um novo objeto do tipo 4D.IMAPTransporter
. É idêntico ao comando (atalho) [IMAP New transporter
] (#imap-new-transporter).
.acceptUnsecureConnection
História
Release | Mudanças |
---|---|
17 R4 | Adicionado |
.acceptUnsecureConnection : Boolean
Descrição
The .acceptUnsecureConnection
property contains True if 4D is allowed to establish an unencrypted connection when encrypted connection is not possible.
It contains False if unencrypted connections are unallowed, in which case an error in returned when encrypted connection is not possible.
Estão disponíveis portos seguros:
-
SMTP
- 465: SMTPS
- 587 ou 25: SMTP com atualização STARTTLS se for compat[ivel com o servidor.
-
IMAP
- 143: IMAP non-encrypted port
- 993: IMAP com atualização STARTTLS se for compatível com o servidor
-
POP3
- 110: Porta não criptografada POP3
- 995: POP3 com atualização STARTTLS se suportado pelo servidor.
.addFlags()
História
Release | Mudanças |
---|---|
20 | Suporta palavras-chave personalizadas |
18 R6 | Adicionado |
.addFlags( msgIDs : Collection ; keywords : Object ) : Object
.addFlags( msgIDs : Text ; keywords : Object ) : Object
.addFlags( msgIDs : Longint ; keywords : Object ) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
msgIDs | Collection | -> | Coleção de strings: IDs únicos de mensagens (texto) Texto: ID único de uma mensagem Longint (todos IMAP): Todas as mensagens na caixa de correio seleccionada |
keywords | Object | -> | Flags de palavras chaves a adicionar |
Resultados | Object | <- | Estado da operação addFlags |
Descrição
A função .addFlags()
adiciona sinalizadores aos msgIDs
para as keywords
especificadas.
No parâmetro msgIDs
, você pode passar qualquer um deles:
- uma colecção contendo as identificações únicas de mensagens específicas ou
- o ID único (texto) de uma mensagem ou
- a seguinte constante (longint) para todas as mensagens na caixa de correio selecionada:
Parâmetros | Valor | Comentário |
---|---|---|
IMAP all | 1 | Seleccione todas as mensagens na caixa de correio seleccionada |
O parâmetro keywords
permite que você defina os sinalizadores a serem adicionados aos msgIDs
. Pode passar qualquer uma das seguintes palavras-chave:
Propriedade | Tipo | Descrição |
---|---|---|
$draft | Parâmetros | True para adicionar o marcador "draft" na mensagem |
$seen | Parâmetros | True para adicionar o marcador "seen" na mensagem |
$flagged | Parâmetros | True para adicionar o marcador "flagged" na mensagem |
$answered | Parâmetros | True para adicionar o marcador "answered" na mensagem |
$deleted | Parâmetros | True para adicionar o marcador "deleted" na mensagem |
<custom flag> | Parâmetros | True para adicionar o marcador personalizado na mensagem |
Os nomes das bandeiras personalizadas devem respeitar esta regra: a palavra-chave deve ser um fio não sensível a maiúsculas e minúsculas, excluindo caracteres de controlo e espaço, e não pode incluir nenhum destes caracteres: ( ) { ] % * " \
- Para que uma palavra-chave seja tida em conta, tem de ser true.
- A interpretação dos marcadores de palavras-chave pode variar por cliente de correio.
Objeto devolvido
A função devolve um objecto que descreve o estado IMAP:
Propriedade | Tipo | Descrição | |
---|---|---|---|
success | Parâmetros | Verdadeiro se a operação for bem sucedida, Falso caso contrário | |
statusText | Text | Mensagem de estado devolvida pelo servidor IMAP, ou último erro devolvido na pilha de erros 4D | |
errors | Collection | pilha de erros 4D (não devolvida se for recebida uma resposta do servidor IMAP) | |
[].errcode | Number | Código de erro 4D | |
[].message | Text | Descrição do erro 4D | |
[].componentSignature | Text | Assinatura da componente interna que devolveu o erro |
Exemplo
var $options;$transporter;$boxInfo;$status : Object
$options:=New object
$options.host:="imap.gmail.com"
$options.port:=993
$options.user:="4d@gmail.com"
$options.password:="xxxxx"
// Criar transporter
$transporter:=IMAP New transporter($options)
// Selecionar mailbox
$boxInfo:=$transporter.selectBox("INBOX")
// Marcar todas as mensagens de INBOX como lidas
$flags:=New object
$flags["$seen"]:=True
$status:=$transporter.addFlags(IMAP all;$flags)
.append()
História
Release | Mudanças |
---|---|
18 R6 | Adicionado |
.append( mailObj : Object ; destinationBox : Text ; options : Object ) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
mailObj | Object | -> | Objeto Email |
destinationBox | Text | -> | Caixa de email que vai receber o objeto Email |
options | Object | -> | Objeto que contém informações do charset |
Resultados | Object | <- | Estado da operação anexada |
Descrição
A função .append()
anexa um mailObj
à destinationBox
.
No parâmetro mailObj
, passe um objeto de e-mail. Para uma descrição abrangente das propriedades de email, consulte Objeto Email. A função .append()
suporta tags de palavras-chave no atributo keywords
do objeto de e-mail.
O parâmetro opcional destinationBox
permite que você passe o nome de uma caixa de correio onde o mailObj
será anexado. Se omitido, é utilizada a caixa de correio actual.
No parâmetro opcional options
, você pode passar um objeto para definir o conjunto de caracteres e a codificação para partes específicas do e-mail. Propriedades disponiveis:
Propriedade | Tipo | Descrição |
---|---|---|
headerCharset | Text | Charset e codificação usados para as seguintes partes do e-mail: assunto, nomes de arquivos de anexo e atributos de nome de e-mail. Possíveis valores: Ver tabela de possíveis cartas abaixo |
bodyCharset | Text | Charset e codificação usados para o conteúdo html e corpo do e-mail. Possíveis valores: Ver tabela de possíveis cartas abaixo |
Charsets possíveis:
Parâmetros | Valor | Comentário |
---|---|---|
mail mode ISO2022JP | US-ASCII_ISO-2022-JP_UTF8_QP |
|
mail mode ISO88591 | ISO-8859-1 |
|
mail mode UTF8 | US-ASCII_UTF8_QP | headerCharset & bodyCharset: US-ASCII se possível, caso contrário UTF-8 & Quoted-printable (valor padrão) |
modo de correio UTF8 na base64 | US-ASCII_UTF8_B64 | headerCharset & bodyCharset: US-ASCII se possível, caso contrário UTF-8 & base64 |
Objeto devolvido
A função devolve um objecto que descreve o estado IMAP:
Propriedade | Tipo | Descrição | |
---|---|---|---|
success | Parâmetros | Verdadeiro se a operação for bem sucedida, Falso caso contrário | |
statusText | Text | Mensagem de estado devolvida pelo servidor IMAP, ou último erro devolvido na pilha de erros 4D | |
errors | Collection | pilha de erros 4D (não devolvida se for recebida uma resposta do servidor IMAP) | |
[].errcode | Number | Código de erro 4D | |
[].message | Text | Descrição do erro 4D | |
[].componentSignature | Text | Assinatura da componente interna que devolveu o erro |
Exemplo
Para guardar um e-mail na caixa de correio Drafts:
var $settings; $status; $msg; $imap: Object
$settings:=New object("host"; "domain.com"; "user"; "xxxx"; "password"; "xxxx"; "port"; 993)
$imap:=IMAP New transporter($settings)
$msg:=New object
$msg.from:="xxxx@domain.com"
$msg.subject:="Lorem Ipsum"
$msg.textBody:="Lorem ipsum dolor sit amet, consectetur adipiscing elit."
$msg.keywords:=New object
$msg.keywords["$seen"]:=True//flag the message as read
$msg.keywords["$draft"]:=True//flag the message as a draft
$status:=$imap.append($msg; "Drafts")
.authenticationMode
História
Release | Mudanças |
---|---|
17 R4 | Adicionado |
.authenticationMode : Text
Descrição
The .authenticationMode
property contains the authentication mode used to open the session on the mail server.
Por padrão, o modo mais seguro suportado pelo servidor é usado.
Valores possíveis:
Valor | Constantes | Comentário |
---|---|---|
CRAM-MD5 | IMAP authentication CRAM MD5 | Autenticação usando o protocolo CRAM-MD5 |
LOGIN | IMAP authentication login | Autenticação usando o protocolo LOGIN |
OAUTH2 | Autenticação IMAP OAUTH2 | Autenticação usando o protocolo OAuth2 |
PLAIN | IMAP authentication plain | Autenticação usando o protocolo PLAIN |
.checkConnection()
História
Release | Mudanças |
---|---|
17 R4 | Adicionado |
.checkConnection() : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
Resultados | Object | <- | Estado da ligação do objecto transportador |
Descrição
The .checkConnection()
function checks the connection using information stored in the transporter object, recreates the connection if necessary, and returns the status. Esta função permite verificar se os valores fornecidos pelo utilizador são válidos e consistentes.
Objeto devolvido
A função envia um pedido para o servidor de correio e devolve um objecto descrevendo o estado do correio. Este objeto pode conter as seguintes propriedades:
Propriedade | Tipo | Descrição | |
---|---|---|---|
success | boolean | Verdadeiro se a verificação for bem sucedida, Falso de outra forma | |
status | number | (apenas SMTP) Código de estado devolvido pelo servidor de correio (0 no caso de um problema não relacionado com o processamento de correio) | |
statusText | text | Mensagem de estado devolvida pelo servidor de correio, ou último erro devolvido na pilha de erros 4D | |
errors | collection | pilha de erros 4D (não devolvida se for recebida uma resposta do servidor de correio) | |
[ ].errCode | number | Código de erro 4D | |
[ ].message | text | Descrição do erro 4D | |
[ ].componentSignature | text | Assinatura da componente interna que devolveu o erro |
.checkConnectionDelay
História
Release | Mudanças |
---|---|
18 R4 | Adicionado |
.checkConnectionDelay : Integer
Descrição
A propriedade .checkConnectionDelay
contém o tempo máximo (em segundos) permitido antes de verificar a conexão com o servidor. Se este tempo for excedido entre duas chamadas de método, a ligação ao servidor será verificada. Por padrão, se a propriedade não tiver sido definida no objecto do servidor, o valor é 300.
Aviso: certifique-se de que o tempo limite definido seja menor que o tempo limite do servidor, caso contrário, o tempo limite do cliente será inútil.
.connectionTimeOut
História
Release | Mudanças |
---|---|
17 R5 | Adicionado |
.connectionTimeOut : Integer
Descrição
The .connectionTimeOut
property contains the maximum wait time (in seconds) allowed to establish a connection to the server. By default, if the property has not been set in the server object (used to create the transporter object with SMTP New transporter
, POP3 New transporter
, or IMAP New transporter
), the value is 30.
.copy()
História
Release | Mudanças |
---|---|
18 R5 | Adicionado |
.copy( msgsIDs : Collection ; destinationBox : Text ) : Object
.copy( allMsgs : Integer ; destinationBox : Text ) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
msgsIDs | Collection | -> | Coleção de identificadores únicos de mensagens (strings) |
allMsgs | Integer | -> | IMAP all : todas as mensagens na caixa de correio selecionada |
destinationBox | Text | -> | Caixa de correio para receber mensagens copiadas |
Resultados | Object | <- | Estado da operação anexada |
Descrição
A função .copy()
copia as mensagens definidas por msgsIDs ou allMsgs para destinationBox no servidor IMAP.
Pode passar:
- no parâmetro msgsIDs, uma colecção contendo as identificações únicas das mensagens específicas a copiar, ou
- no parâmetro allMsgs, a constante
IMAP all
(número inteiro) para copiar todas as mensagens na caixa de correio selecionada.
O parâmetro destinationBox permite-lhe passar um valor de texto com o nome da caixa de correio onde as cópias das mensagens serão colocadas.
Objeto devolvido
A função devolve um objecto que descreve o estado IMAP:
Propriedade | Tipo | Descrição | |
---|---|---|---|
success | Parâmetros | Verdadeiro se a operação for bem sucedida, Falso caso contrário | |
statusText | Text | Mensagem de estado devolvida pelo servidor IMAP, ou último erro devolvido na pilha de erros 4D | |
errors | Collection | pilha de erros 4D (não devolvida se for recebida uma resposta do servidor IMAP) | |
[].errcode | Number | Código de erro 4D | |
[].message | Text | Descrição do erro 4D | |
[].componentSignature | Text | Assinatura da componente interna que devolveu o erro |
Exemplo 1
Para copiar uma selecção de mensagens:
var $server;$boxInfo;$status : Object
var $mailIds : Collection
var $transporter : 4D.IMAPTransporter
$server:=New object
$server.host:="imap.gmail.com" //Obrigatório
$server.port:=993
$server.user:="4d@gmail.com"
$server.password:="XXXXXXXX"
$transporter:=IMAP New transporter($server)
//selecionar mailbox
$boxInfo:=$transporter.selectBox("inbox")
//obtém a coleção de mensagens com IDs únicos
$mailIds:=$transporter.searchMails("subject \"4D new feature:\"")
// copia mensagens encontradas ao mailbox "documents"
$status:=$transporter.copy($mailIds;"documents")
Exemplo 2
Para copiar todas as mensagens na caixa de correio actual:
var $server;$boxInfo;$status : Object
var $transporter : 4D.IMAPTransporter
$server:=New object
$server.host:="imap.gmail.com" //Obrigatório
$server.port:=993
$server.user:="4d@gmail.com"
$server.password:="XXXXXXXX"
$transporter:=IMAP New transporter($server)
//selecionar mailbox
$boxInfo:=$transporter.selectBox("inbox")
// copiar todas as mensagens ao "documents" mailbox
$status:=$transporter.copy(IMAP all;"documents")
.createBox()
História
Release | Mudanças |
---|---|
19 | Adicionado |
.createBox( name : Text ) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
name | Text | -> | Nome da nova caixa de correio |
Resultados | Object | <- | Estado da operação de criação da caixa de correio |
Descrição
A função .createBox()
cria uma caixa de correio com o name
fornecido. Se o carácter separador hierárquico do servidor IMAP aparecer noutro lugar no nome da caixa de correio, o servidor IMAP criará os nomes dos pais necessários para criar a caixa de correio em questão.
Por outras palavras, uma tentativa de criar "Projectos/IMAP/Doc" num servidor em que "/" é o carácter separador hierárquico criará:
- Somente a caixa de correio "Doc" se "Projects" e "IMAP" já existirem.
- Caixas de correio "IMAP" e "Doc" se apenas "Projetos" já existir.
- Caixas de correio "Projects", "IMAP" e "Doc", se elas ainda não existirem.
No parâmetro name
, passe o nome da nova caixa de correio.
Objeto devolvido
A função devolve um objecto que descreve o estado IMAP:
Propriedade | Tipo | Descrição | |
---|---|---|---|
success | Parâmetros | Verdadeiro se a operação for bem sucedida, Falso caso contrário | |
statusText | Text | Mensagem de estado devolvida pelo servidor IMAP, ou último erro devolvido na pilha de erros 4D | |
errors | Collection | pilha de erros 4D (não devolvida se for recebida uma resposta do servidor IMAP) | |
[].errcode | Number | Código de erro 4D | |
[].message | Text | Descrição do erro 4D | |
[].componentSignature | Text | Assinatura da componente interna que devolveu o erro |
Exemplo
Para criar uma nova caixa de correio "Facturas":
var $pw : text
var $options; $transporter; $status : object
$options:=New object
$pw:=Request("Please enter your password:")
If(OK=1)
$options.host:="imap.gmail.com"
$options.user:="test@gmail.com"
$options.password:=$pw
$transporter:=IMAP New transporter($options)
$status:=$transporter.createBox("Invoices")
If ($status.success)
ALERT("Mailbox creation successful!")
Else
ALERT("Error: "+$status.statusText)
End if
End if
.delete()
História
Release | Mudanças |
---|---|
18 R5 | Adicionado |
.delete( msgsIDs : Collection ) : Object
.delete( allMsgs : Integer ) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
msgsIDs | Collection | -> | Coleção de identificadores únicos de mensagens (strings) |
allMsgs | Integer | -> | IMAP all : todas as mensagens na caixa de correio selecionada |
Resultados | Object | <- | Estado da operação apagada |
Descrição
A função .delete()
define o sinalizador "deleted" para as mensagens definidas em msgsIDs
ou allMsgs
.
Pode passar:
- no parâmetro
msgsIDs
, uma coleção que contém as IDs exclusivas das mensagens específicas a serem excluídas, ou - no parâmetro
allMsgs
, a constanteIMAP all
(inteiro) para excluir todas as mensagens da caixa de correio selecionada.
A execução desta função não remove realmente as mensagens. As mensagens com o sinalizador "delete" ainda podem ser encontradas pela função .searchMails(). As mensagens sinalizadas são excluídas do servidor IMAP com a função .expunge()
ou selecionando outra caixa de correio ou quando o objeto transportador (criado com IMAP New transporter) é destruído.
Objeto devolvido
A função devolve um objecto que descreve o estado IMAP:
Propriedade | Tipo | Descrição | |
---|---|---|---|
success | Parâmetros | Verdadeiro se a operação for bem sucedida, Falso caso contrário | |
statusText | Text | Mensagem de estado devolvida pelo servidor IMAP, ou último erro devolvido na pilha de erros 4D | |
errors | Collection | pilha de erros 4D (não devolvida se for recebida uma resposta do servidor IMAP) | |
[].errcode | Number | Código de erro 4D | |
[].message | Text | Descrição do erro 4D | |
[].componentSignature | Text | Assinatura da componente interna que devolveu o erro |
Exemplo 1
Para apagar uma selecção de mensagens:
var $server;$boxInfo;$status : Object
var $mailIds : Collection
var $transporter : 4D.IMAPTransporter
$server:=New object
$server.host:="imap.gmail.com" //Obrigatório
$server.port:=993
$server.user:="4d@gmail.com"
$server.password:="XXXXXXXX"
$transporter:=IMAP New transporter($server)
//selecionar mailbox
$boxInfo:=$transporter.selectBox("Inbox")
//obter coleção das IDs únicas de mensagem
$mailIds:=$transporter.searchMails("subject \"Reports\"")
// Apagar mensagens selecionadas
$status:=$transporter.delete($mailIds)
Exemplo 2
Para apagar todas as mensagens na caixa de correio actual:
var $server;$boxInfo;$status : Objecto
var $transporter : 4D.IMAPTransporter
$server:=Novo objecto
$server.host:="imap.gmail.com" //Mandatório
$server.port:=993
$server.user:="$transporter"
$server.password:="XXXXXXXX"
$transporter:=IMAP Novo transportador($server)
//seleccionar caixa de correio
$boxInfo:= .selectBox("Junk Email")
// apagar todas as mensagens na caixa de correio actual
$status:=$transporter.delete(IMAP todos)
.deleteBox()
História
Release | Mudanças |
---|---|
19 | Adicionado |
.deleteBox( name : Text ) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
name | Text | -> | Nome da caixa de correio a apagar |
Resultados | Object | <- | Estado da operação de eliminação da caixa de correio |
Descrição
A função .deleteBox()
remove permanentemente a caixa de correio com o name
fornecido do servidor IMAP. A tentativa de apagar uma INBOX ou uma caixa de correio que não existe, gerará um erro.
No parâmetro name
, passe o nome da caixa de correio a ser excluída.
- A função não pode apagar uma caixa de correio que tenha caixas de correio para crianças se a caixa de correio dos pais tiver o atributo "\Noselect".
- Todas as mensagens na caixa de correio eliminadas serão também eliminadas.
- A capacidade de apagar uma caixa de correio depende do servidor de correio.
Objeto devolvido
A função devolve um objecto que descreve o estado IMAP:
Propriedade | Tipo | Descrição | |
---|---|---|---|
success | Parâmetros | Verdadeiro se a operação for bem sucedida, Falso caso contrário | |
statusText | Text | Mensagem de estado devolvida pelo servidor IMAP, ou último erro devolvido na pilha de erros 4D | |
errors | Collection | pilha de erros 4D (não devolvida se for recebida uma resposta do servidor IMAP) | |
[].errcode | Number | Código de erro 4D | |
[].message | Text | Descrição do erro 4D | |
[].componentSignature | Text | Assinatura da componente interna que devolveu o erro |
Exemplo
Para eliminar a caixa de correio filha "Nova Orion Industries" da hierarquia da caixa de correio "Bills":
var $pw; $name : text
var $options; $transporter; $status : object
$options:=New object
$pw:=Request("Please enter your password:")
If(OK=1)$options.host:="imap.gmail.com"
$options.user:="test@gmail.com"
$options.password:=$pw
$transporter:=IMAP New transporter($options)
// excluir caixa de correio
$name:="Bills"+$transporter.getDelimiter()+"Atlas Corp"
$status:=$transporter.subscribe($name)
If ($status.success)
ALERT("Mailbox subscription successful!")
Else
ALERT("Error: "+$status.statusText)
End if
End if
.expunge()
História
Release | Mudanças |
---|---|
18 R6 | Adicionado |
.expunge() : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
Resultados | Object | <- | Estado da operação de expurgo |
Descrição
A função .expunge()
remove todas as mensagens com o sinalizador "deleted" do servidor de e-mail IMAP. O sinalizador "deleted" pode ser definido com os métodos .delete()
ou .addFlags()
.
Objeto devolvido
A função devolve um objecto que descreve o estado IMAP:
Propriedade | Tipo | Descrição | |
---|---|---|---|
success | Parâmetros | Verdadeiro se a operação for bem sucedida, Falso caso contrário | |
statusText | Text | Mensagem de estado devolvida pelo servidor IMAP, ou último erro devolvido na pilha de erros 4D | |
errors | Collection | pilha de erros 4D (não devolvida se for recebida uma resposta do servidor IMAP) | |
[].errcode | Number | Código de erro 4D | |
[].message | Text | Descrição do erro 4D | |
[].componentSignature | Text | Assinatura da componente interna que devolveu o erro |
Exemplo
var $options;$transporter;$boxInfo;$status : Object
var $ids : Collection
$options:=New object
$options.host:="imap.gmail.com"
$options.port:=993
$options.user:="4d@gmail.com"
$options.password:="xxxxx"
// Criar transporter
$transporter:=IMAP New transporter($options)
// Selecionar mailbox
$boxInfo:=$transporter.selectBox("INBOX")
// Encontrar e apagar todas as mensagens vistas no INBOX
$ids:=$transporter.searchMails("SEEN")
$status:=$transporter.delete($ids)
// Expurga todas as mensagens marcadas como apagadas
$status:=$transporter.expunge()
.getBoxInfo()
História
Release | Mudanças |
---|---|
20 | id é retornado |
18 R5 | name é opcional |
18 R4 | Adicionado |
.getBoxInfo( { name : Text }) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
name | Text | -> | Nome da nova caixa de correio |
Resultados | Object | <- | objecto boxInfo |
Descrição
A função .getBoxInfo()
retorna um objeto boxInfo
correspondente à maibox atual ou à caixa de correio name. Essa função retorna as mesmas informações que .selectBox()
sem alterar a caixa de correio atual.
No parâmetro opcional name, passe o nome da caixa de correio a ser acessada. O nome representa uma hierarquia inequívoca da esquerda para a direita com níveis separados por um carácter delimitador específico. O delimitador pode ser encontrado com a função .getDelimiter()
.
Se o nome da caixa de correio não for selecionável ou não existir, a função gera um erro e retorna null.
Objeto devolvido
O objeto boxInfo
retornado contém as seguintes propriedades:
Propriedade | Tipo | Descrição |
---|---|---|
name | text | Nome da nova caixa de correio |
mailCount | number | Número de mensagens na caixa de email |
mailRecent | number | Número de mensagens com o marcador "recente" (indicando novas mensagens) |
id | text | Parâmetros |
Exemplo
var $transporter : 4D.IMAPTransporter
$transporter:=IMAP New transporter($server)
$info:=$transporter.getBoxInfo("INBOX")
ALERT("INBOX contains "+String($info.mailRecent)+" recent emails.")
.getBoxList()
História
Release | Mudanças |
---|---|
18 R4 | Adicionado |
19 | Adicionar parâmetro isSubscribed |
.getBoxList( { parameters : Object } ) : Collection
Parâmetro | Tipo | Descrição | |
---|---|---|---|
parameters | Object | -> | Parâmetros |
Resultados | Collection | <- | Coleção de objetos da caixa de correio |
Descrição
A função .getBoxList()
retorna uma coleção de caixas de correio que descreve todas as caixas de correio disponíveis. Esta função permite gerir localmente a lista de mensagens localizadas no servidor de correio IMAP.
No parâmetro opcional parameters
, passe um objeto que contenha valores para filtrar as caixas de correio retornadas. Pode passar:
Propriedade | Tipo | Descrição |
---|---|---|
isSubscribed | Parâmetros |
Resultados
Cada objecto da coleção devolvida contém as seguintes propriedades:
Propriedade | Tipo | Descrição |
---|---|---|
[].name | text | Nome da nova caixa de correio |
[].selectable | boolean | Indica se os direitos de acesso permitem ou não que a caixa de correio seja selecionada:
|
[].inferior | boolean | Indica se os direitos de acesso permitem ou não a criação de uma hierarquia inferior na caixa de correio:
|
[].interesting | boolean | Indica se a caixa de correio foi marcada como "interessante" pelo servidor:
|
Se a conta não contiver quaisquer caixas de correio, é devolvida uma colecção vazia.
- Se não houver uma conexão aberta,
.getBoxList()
abrirá uma conexão.- Se a conexão não tiver sido usada desde o atraso de conexão designado (consulte
IMAP New transporter
), a função.checkConnection( )
será automaticamente chamada.
Exemplo
var $transporter : 4D.IMAPTransporter
$transporter:=IMAP New transporter($server)
$boxList:=$transporter.getBoxList()
For each($box;$boxList)
If($box.interesting)
$split:=Split string($box.name;$transporter.getDelimiter())
ALERT("New emails are available in the box: "+$split[$split.length-1])
End if
End for each
.getDelimiter()
História
Release | Mudanças |
---|---|
18 R4 | Adicionado |
.getDelimiter() : Text
Parâmetro | Tipo | Descrição | |
---|---|---|---|
Resultados | Text | <- | Caractere delimitador de hierarquia |
Descrição
A função .getDelimiter()
retorna o caractere usado para delimitar os níveis de hierarquia no nome da caixa de correio.
O delimitador é um caractere a que se pode usar para:
- criar caixas de correio de nível inferior
- pesquisar hierarquias de nível mais alto ou mais baixo dentro das caixa de correio
Resultados
Carácter delimitador do nome da caixa de correio.
- Se não houver uma conexão aberta,
.getDelimiter()
abrirá uma conexão.- Se a conexão não tiver sido usada desde o atraso de conexão designado, a função
.checkConnection()
será automaticamente chamada.
Exemplo
var $transporter : 4D.IMAPTransporter
$transporter:=IMAP New transporter($server)
$boxList:=$transporter.getBoxList()
For each($box;$boxList)
If($box.interesting)
$split:=Split string($box.name;$transporter.getDelimiter())
ALERT("New emails are available in the box: "+$split[$split.length-1])
End if
End for each
.getMail()
História
Release | Mudanças |
---|---|
18 R4 | Adicionado |
.getMail( msgNumber: Integer { ; options : Object } ) : Object
.getMail( msgID: Text { ; options : Object } ) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
msgNumber | Integer | -> | Número sequencial da mensagem |
msgID | Text | -> | ID única da mensagem |
options | Object | -> | Instruções de tratamento de mensagens |
Resultados | Object | <- | Objeto email |
Descrição
A função .getMail()
retorna o objeto Email
correspondente ao msgNumber ou msgID na caixa de correio designada pelo IMAP_transporter
. Essa função permite manejar localmente os conteúdos de email.
No primeiro parâmetro, pode passar qualquer um dos dois:
- msgNumber, um valor inteiro que indica o número de sequência da mensagem a ser recuperada ou
- msgID, um valor de texto que indica a ID exclusiva da mensagem a ser recuperada.
O parâmetro options opcional permite que você passe um objeto definindo instruções adicionais para manipular a mensagem. As seguintes propriedades estão disponíveis:
Propriedade | Tipo | Descrição |
---|---|---|
updateSeen | boolean | Se Verdadeiro, a mensagem é marcada como "visto" na caixa de correio. Se falso, a mensagem não é marcada como "visto". Valor padrão: True |
withBody | boolean | Pass True para devolver o corpo da mensagem. Se falso, apenas o cabeçalho da mensagem é devolvido. Valor padrão: True |
- A fun ção gera um erro e retorna Null se msgID designar uma mensagem inexistente,
- Se nenhuma caixa de correio for selecionada com a função
.selectBox()
, será gerado um erro,- Se não houver uma conexão aberta,
.getMail()
abrirá uma conexão com a última caixa de correio especificada com.selectBox()
`.
Resultados
.getMail()
retorna um objeto [Email
] (EmailObjectClass.md#email-object) com as seguintes propriedades IMAP específicas: id, receivedAt e size.
Exemplo
Se quiser receber uma mensagem com ID = 1:
var $server : Object
var $info; $mail; $boxInfo : Variant
var $transporter : 4D.IMAPTransporter
$server:=New object
$server.host:="imap.gmail.com" //Obrigatório
$server.port:=993
$server.user:="4d@gmail.com"
$server.password:="XXXXXXXX"
//cria transporter
$transporter:=IMAP New transporter($server)
//seleciona mailbox
$boxInfo:=$transporter.selectBox("Inbox")
//obtém objeto Email com ID 1
$mail:=$transporter.getMail(1)
.getMails()
História
Release | Mudanças |
---|---|
18 R5 | Adicionado |
.getMails( ids : Collection { ; options : Object } ) : Object
.getMails( startMsg : Integer ; endMsg : Integer { ; options : Object } ) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
ids | Collection | -> | Colecção de identificação da mensagem |
startMsg | Integer | -> | Número sequencial da primeira mensagem |
endMsg | Integer | -> | Número sequencial da última mensagem |
options | Object | -> | Instruções de tratamento de mensagens |
Resultados | Object | <- | Objeto contendo:
|
Descrição
A função .getMails()
retorna um objeto que contém uma coleção de objetos Email
.
Primeira sintaxe:
.getMails( ids { ; options } ) -> result
A primeira sintaxe permite recuperar mensagens com base nas suas identificações.
No parâmetro ids, passe uma coleção de IDs para as mensagens a serem retornadas. Você pode obter as identificações com .getMail()
.
O parâmetro opcional options permite que você defina as partes das mensagens a serem retornadas. Consulte a tabela Opções abaixo para obter uma descrição das propriedades disponíveis.
Segunda sintaxe:
.getMails( startMsg ; endMsg { ; options } ) -> result
A segunda sintaxe permite recuperar mensagens com base num intervalo sequencial. Os valores passados representam a posição das mensagens na caixa de correio.
No parâmetro startMsg, passe um valor inteiro correspondente ao número da primeira mensagem em um intervalo sequencial. Se você passar um número negativo (startMsg <= 0), a primeira mensagem da caixa de correio será usada como o início da sequência.
No parâmetro endMsg, passe um valor inteiro correspondente ao número da última mensagem a ser incluída num intervalo sequencial. Se você passar um número negativo (endMsg <= 0), a última mensagem da caixa de correio será usada como o fim da sequência.
O parâmetro opcional options permite que você defina as partes das mensagens a serem retornadas.
Options
Propriedade | Tipo | Descrição |
---|---|---|
updateSeen | Parâmetros | Se Verdadeiro, as mensagens especificadas são marcadas como "vistas" na caixa de correio. Se falso, as mensagens não são marcadas como "vistas". Valor padrão: True |
withBody | Parâmetros | Pass True para devolver o corpo das mensagens especificadas. Se falso, apenas os cabeçalhos das mensagens são devolvidos. Valor padrão: True |
- Se nenhuma caixa de correio for selecionada com o comando
.selectBox()
, será gerado um erro.- Se não houver uma conexão aberta,
.getMails()
abrirá uma conexão com a última caixa de correio especificada com.selectBox()
.
Resultados
.getMails()
retorna um objeto que contém as seguintes coleções:
Propriedade | Tipo | Descrição |
---|---|---|
lista | Collection | Coleção de objetos [Email ] (EmailObjectClass.md#email-object). Se não forem encontrados objetos e-mail, uma coleção vazia é devolvida. |
notFound | Collection | Coleção de:
|
Exemplo
Se quiser recuperar os 20 e-mails mais recentes sem alterar o seu estatuto de "visto":
var $server,$boxInfo,$result : Object
var $transporter : 4D.IMAPTransporter
$server:=New object
$server.host:="imap.gmail.com" //Mandatório
$server.port:=993
$server.user:="4d@gmail.com"
$server.password:="XXXXXXXX"
//criar transportador
$transporter:=IMAP New transporter($server)
//selecionar caixa de correio
$boxInfo:=$transporter.selectBox("INBOX")
If($boxInfo.mailCount>0)
// recupera os cabeçalhos das últimas 20 mensagens sem marcá-las como lidas
$result:=$transporter.getMails($boxInfo.mailCount-20;$boxInfo.mailCount;\
New object("withBody";False;"updateSeen";False))
For each($mail;$result.list)
// ...
End for each
End if
.getMIMEAsBlob()
História
Release | Mudanças |
---|---|
18 R4 | Adicionado |
.getMIMEAsBlob( msgNumber : Integer { ; updateSeen : Boolean } ) : Blob
.getMIMEAsBlob( msgID : Text { ; updateSeen : Boolean } ) : Blob
Parâmetro | Tipo | Descrição | |
---|---|---|---|
msgNumber | Integer | -> | Número sequencial da mensagem |
msgID | Text | -> | ID única da mensagem |
updateSeen | Parâmetros | -> | Se Verdadeiro, a mensagem é marcada "visto" na caixa de correio. Se Falso, a mensagem é deixada intocada. |
Resultados | BLOB | <- | Blob da string MIME retornado do servidor mail |
Descrição
A função .getMIMEAsBlob()
retorna um BLOB contendo o conteúdo MIME da mensagem correspondente ao msgNumber ou msgID na caixa de correio designada pelo IMAP_transporter
.
No primeiro parâmetro, pode passar qualquer um dos dois:
- msgNumber, um valor inteiro que indica o número de sequência da mensagem a ser recuperada ou
- msgID, um valor de texto que indica a ID exclusiva da mensagem a ser recuperada.
O parâmetro opcional updateSeen permite que você especifique se a mensagem está marcada como "vista" na caixa de correio. Pode passar:
- True - para marcar a mensagem como "vista" (indicando que a mensagem foi lida)
- False - para deixar o status "visto" da mensagem inalterado
- A função retorna um BLOB vazio se msgNumber ou msgID* designar uma mensagem inexistente,
- Se nenhuma caixa de correio for selecionada com o comando
.selectBox()
, será gerado um erro,- Se não houver uma conexão aberta,
.getMIMEAsBlob()
abrirá uma conexão com a última caixa de correio especificada com.selectBox()
.
Resultados
.getMIMEAsBlob()
retorna um BLOB
que pode ser arquivado em um banco de dados ou convertido a um objeto Email
com o comando MAIL Convert from MIME
.
Exemplo
var $server : Objecto
var $boxInfo : Variante
var $blob : Blob
var $transporter : 4D.IMAPTransporter
$server:=Novo objecto
$server.host:="imap.gmail.com"
$server.port:=993
$server.user:=" "
$server.password:="XXXXXXXX"
//criar transportador
$transporter:=IMAP Novo transportador($server)
//seleccionar caixa de correio
$boxInfo:=$transporter.selectBox("Inbox")
//get BLOB
$blob:=$transporter.getMIMEAsBlob(1)
.host
História
Release | Mudanças |
---|---|
17 R5 | Adicionado |
.host : Text
Descrição
The .host
property contains the name or the IP address of the host server. Utilizado para transacções postais (SMTP, POP3, IMAP).
.logFile
História
Release | Mudanças |
---|---|
17 R5 | Adicionado |
.logFile : Text
Descrição
The .logFile
property contains the path of the extended log file defined (if any) for the mail connection. Pode ser relativo (à pasta atual de Logs) ou absoluto.
Unlike regular log files (enabled via the SET DATABASE PARAMETER
command), extended log files store MIME contents of all sent mails and do not have any size limit. Para mais informações sobre arquivos de registo estendidos, consultar:
- Conexões SMSTP - 4DSMTPLog.txt
- Conexões POP3 - 4DPOP3Log.txt
- Conexões IMAP - 4DIMAPLog.txt
.move()
História
Release | Mudanças |
---|---|
18 R5 | Adicionado |
.move( msgsIDs : Collection ; destinationBox : Text ) : Object
.move( allMsgs : Integer ; destinationBox : Text ) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
msgsIDs | Collection | -> | Coleção de identificadores únicos de mensagens (strings) |
allMsgs | Integer | -> | IMAP all : todas as mensagens na caixa de correio selecionada |
destinationBox | Text | -> | Caixa de correio para receber mensagens movimentadas |
Resultados | Object | <- | Estado da operação de mudança |
Descrição
A função .move()
move as mensagens definidas por msgsIDs ou allMsgs para destinationBox no servidor IMAP.
Pode passar:
- no parâmetro msgsIDs, uma coleção contendo as IDs únicas das mensagens específicas a mover, ou
- no parâmetro allMsgs, a constante
IMAP all
(número inteiro) para mover todas as mensagens na caixa de correio selecionada.
O parâmetro destinationBox permite-lhe passar um valor de texto com o nome da caixa de correio onde as cópias das mensagens serão colocadas.
Esta função só é suportada por servidores IMAP em conformidade com o RFC 8474.
Objeto devolvido
A função devolve um objecto que descreve o estado IMAP:
Propriedade | Tipo | Descrição | |
---|---|---|---|
success | Parâmetros | Verdadeiro se a operação for bem sucedida, Falso caso contrário | |
statusText | Text | Mensagem de estado devolvida pelo servidor IMAP, ou último erro devolvido na pilha de erros 4D | |
errors | Collection | pilha de erros 4D (não devolvida se for recebida uma resposta do servidor IMAP) | |
[].errcode | Number | Código de erro 4D | |
[].message | Text | Descrição do erro 4D | |
[].componentSignature | Text | Assinatura da componente interna que devolveu o erro |
Exemplo 1
Para mover uma selecção de mensagens:
var $server;$boxInfo;$status : Object
var $mailIds : Collection
var $transporter : 4D.IMAPTransporter
$server:=New object
$server.host:="imap.gmail.com" //Obrigatório
$server.port:=993
$server.user:="4d@gmail.com"
$server.password:="XXXXXXXX"
$transporter:=IMAP New transporter($server)
//selecionar mailbox
$boxInfo:=$transporter.selectBox("Inbox")
//obter coleção das IDs únicas de mensagem
$mailIds:=$transporter.searchMails("subject \"4D new feature:\"")
// mover mensagens encontradas da caixa de correio actual para a caixa de correio "documents"
$status:=$transporter.move($mailIds; "documentos")
Exemplo 2
Para mover todas as mensagens na mailbox atual:
var $server;$boxInfo;$status : Object
var $transporter : 4D.IMAPTransporter
$server:=New object
$server.host:="imap.gmail.com" //Mandatório
$server.port:=993
$server.user:="4d@gmail.com"
$server.password:="XXXXXXXX"
$transporter:=IMAP New transporter($server)
//seleccionar caixa de correio
$boxInfo:=$transporter.selectBox("inbox")
// mover todas as mensagens da caixa de correio actual para a caixa de correio "documents"
$status:=$transporter.move(IMAP all;"documents")
.numToID()
História
Release | Mudanças |
---|---|
18 R5 | Adicionado |
.numToID( startMsg : Integer ; endMsg : Integer ) : Collection
Parâmetro | Tipo | Descrição | |
---|---|---|---|
startMsg | Integer | -> | Número sequencial da primeira mensagem |
endMsg | Integer | -> | Número sequencial da última mensagem |
Resultados | Collection | <- | Colecção de identificações únicas |
Descrição
A função .numToID()
converte os números de sequência em IDs exclusivos do IMAP para as mensagens no intervalo sequencial designado por startMsg e endMsg na caixa de correio selecionada no momento.
No parâmetro startMsg, passe um valor inteiro correspondente ao número da primeira mensagem em um intervalo sequencial. Se você passar um número negativo (startMsg <= 0), a primeira mensagem da caixa de correio será usada como o início da sequência.
No parâmetro endMsg, passe um valor inteiro correspondente ao número da última mensagem a ser incluída num intervalo sequencial. Se você passar um número negativo (endMsg <= 0), a última mensagem da caixa de correio será usada como o fim da sequência.
Resultados
A função devolve uma colecção de cordas (identificações únicas).
Exemplo
var $transporter : 4D.IMAPTransporter
var $server;$boxInfo;$status : Object
var $mailIds : Collection
$server:=New object
$server.host:="imap.gmail.com" //Mandatório
$server.port:=993
$server.user:="4d@gmail.com"
$server.password:="XXXXXXXX"
$transporter:=IMAP New transporter($server)
//select mailbox
$boxInfo:=$transporter.selectBox("inbox")
//obter IDs para 5 últimas mensagens recebidas
$mailIds:=$transporter.numToID(($boxInfo.mailCount-5);$boxInfo.mailCount)
//excluir as mensagens da caixa de correio actual
$status:=$transporter.delete($mailIds)
.removeFlags()
História
Release | Mudanças |
---|---|
20 | Suporta palavras-chave personalizadas |
18 R6 | Adicionado |
.removeFlags( msgIDs : Collection ; keywords : Object ) : Object
.removeFlags( msgIDs : Text ; keywords : Object ) : Object
.removeFlags( msgIDs : Longint ; keywords : Object ) : Object
Parâmetro | Tipo | Descrição | |
---|---|---|---|
msgIDs | Collection | -> | Coleção de strings: IDs únicos de mensagens (texto) Texto: ID único de uma mensagem Longint (todos IMAP): Todas as mensagens na caixa de correio seleccionada |
keywords | Object | -> | Flags de palavras-chave a remover |
Resultados | Object | <- | Estado da operação removeFlags |
Descrição
A função .removeFlags()
remove os sinalizadores dos msgIDs
para as keywords
especificadas.
No parâmetro msgIDs
, você pode passar qualquer um deles:
- uma colecção contendo as identificações únicas de mensagens específicas ou
- o ID único (texto) de uma mensagem ou
- a seguinte constante (longint) para todas as mensagens na caixa de correio selecionada:
Parâmetros | Valor | Comentário |
---|---|---|
IMAP all | 1 | Seleccione todas as mensagens na caixa de correio seleccionada |
O parâmetro keywords
permite que você defina os sinalizadores a serem removidos dos msgIDs
. Pode passar qualquer uma das seguintes palavras-chave:
Parâmetro | Tipo | Descrição |
---|---|---|
$draft | Parâmetros | True para remover o flag "draft" na mensagem |
$seen | Parâmetros | True para remover a flag "seen" na mensagem |
$flagged | Parâmetros | True para remover a flag "flagged" na mensagem |
$answered | Parâmetros | True para remover a flag "answered" na mensagem |
$deleted | Parâmetros | True para remover a flag "deleted" na mensagem |
<custom flag> | Parâmetros | True para remover a flag personalizada na mensagem |
Consulte .addFlags() para obter mais informações sobre sinalizadores personalizados.
- Para que uma palavra-chave seja tida em conta, tem de ser true.
Objeto devolvido
A função devolve um objecto que descreve o estado IMAP:
Propriedade | Tipo | Descrição | |
---|---|---|---|
success | Parâmetros | Verdadeiro se a operação for bem sucedida, Falso caso contrário | |
statusText | Text | Mensagem de estado devolvida pelo servidor IMAP, ou último erro devolvido na pilha de erros 4D | |
errors | Collection | pilha de erros 4D (não devolvida se for recebida uma resposta do servidor IMAP) | |
[].errcode | Number | Código de erro 4D | |
[].message | Text | Descrição do erro 4D | |
[].componentSignature | Text | Assinatura da componente interna que devolveu o erro |