adobe.target.getOffer(options)
Esta função envia uma solicitação para obter uma Target oferta.
Use com adobe.target.applyOffer()
para processar a resposta ou use sua própria manipulação de sucesso. O parâmetro de opções é obrigatório e tem a seguinte estrutura:
Parâmetros de mbox. Um objeto de pares de valores-chave que tem a seguinte estrutura:
{ "param1": "value1", "param2": "value2"}
Retorno de chamada para execução quando recebemos uma resposta do servidor. A função de retorno de chamada bem-sucedida receberá um único parâmetro que represente uma variedade de objetos em oferta. Este é um exemplo de retorno de chamada:
function handleSuccess(response){......}
Veja as respostas abaixo para obter mais informações.
Retorno de chamada para execução quando recebemos um erro. Há alguns casos que são considerados errôneos:
- Código do status de HTTP diferente de 200 OK
- Não foi possível analisar a resposta. Por exemplo, nós mal construímos JSON ou HTML ao invés de JSON.
- A resposta contém a tecla "erro". Por exemplo, uma exceção foi lançada no Edge e não foi possível processar a solicitação apropriadamente. Podemos receber um erro quando uma mbox está bloqueada e não é possível recuperar o conteúdo dela, etc. A função de retorno de chamada de erro receberá dois parâmetros: status e erro. Veja um exemplo de retorno de chamada de erro:
function handleError(status, error){......}
Veja as respostas com erro abaixo para obter mais informações.
Tempo limite em milissegundos. Se não especificado, o tempo limite padrão em at.js será utilizado.
O tempo limite padrão pode ser definido no Target IU em Administração > Implementação.
Exemplos
Adicionar parâmetros com getOffer() e usando applyOffer() para manipulação bem-sucedida:
adobe.target.getOffer({
"mbox": "target-global-mbox",
"params": {
"a": 1,
"b": 2
},
"success": function(offer) {
adobe.target.applyOffer( {
"mbox": "target-global-mbox",
"offer": offer
} );
},
"error": function(status, error) {
console.log('Error', status, error);
}
});
Adicionar parâmetros e parâmetros de perfil com o getOffer() e usando applyOffer() para manipulação bem-sucedida:
adobe.target.getOffer({
"mbox": "target-global-mbox",
"params": {
"a": 1,
"b": 2,
"profile.age": 27,
"profile.gender": "male"
},
"success": function(offer) {
adobe.target.applyOffer( {
"mbox": "target-global-mbox",
"offer": offer
} );
},
"error": function(status, error) {
console.log('Error', status, error);
}
});
Usar tempo limite personalizado e manipulação personalizada de sucesso com o getOffer():
"YOUR_OWN_CUSTOM_HANDLING_FUNCTION" é um placeholder para uma função que o cliente definiria.
adobe.target.getOffer({
"mbox": "target-global-mbox",
"success": function(offer) {
YOUR_OWN_CUSTOM_HANDLING_FUNCTION(offer);
},
"error": function(status, error) {
console.log('Error', status, error);
},
"timeout": 2000
});
Respostas
O parâmetro de resposta passado para o retorno de chamada de sucesso será uma variedade de ações. Uma ação é um objeto que geralmente tem o seguinte formato:
Exemplo
{
"sessionId": "1444512212156-384616",
"tntId": "1444512212156-384616.17_35",
"offers": [{
"plugins": ["<script type=\"text/javascript\">\r\n/*mboxHighlight+ (1of2) v1 ==> Response Plugin*/\r\nwindow.ttMETA=(typeof(window.ttMETA)!='undefined')?window.ttMETA:[];window.ttMETA.push({'mbox':'target-global-mbox','campaign':'at: redirect ootb','experience':'Experience B','offer':'/at_redirect_ootb/experiences/1/pages/0/1442082890250'});window.ttMBX=function(x){var mbxList=[];for(i=0;i<ttMETA.length;i++){if(ttMETA[i].mbox==x.getName()){mbxList.push(ttMETA[i])}}return mbxList[x.getId()]}\r\n</script>"],
"actions": {
"content": [{
"passMboxSession": false,
"selector": "body",
"action": "redirect",
"url": "https://example.com/04.html",
"includeAllUrlParameters": true
}]
}
}]
}
Respostas de erro
Os parâmetros "status" e "erro" passados para o retorno de chamada de erro terão o seguinte formato:
Representa o status do erro. Este parâmetro pode ter os seguintes valores:
- timeout: Indica que o tempo limite para a solicitação foi excedido.
- parseerror: Indica que a resposta não pôde ser analisada, por exemplo, se recebermos um texto HTML ou sem formatação em vez de JSON.
- error: Indica um erro geral, como o recebimento do status HTTP diferente de 200 OK