Gli hooks in Interaction consentono di modificare il comportamento standard del motore.
Gli Target loading e Proposition post-processing ganci sono configurati, in Adobe Campaign, nello spazio delle offerte:
Il gancio Dynamic offer è configurato con il peso dell'offerta in Adobe Campaign:
Questo gancio consente di arricchire il profilo del contatto (caricato dalla query out-of-the-box) con dati aggiuntivi da un sistema esterno.
I dati raccolti devono essere inseriti nel nodo dati della chiamata (nodo Interaction). L'integratore deve avere già esteso lo schema dei dati della chiamata per definire la struttura dei dati raccolti. L’utente può accedere a questi dati nello stesso modo dei dati delle chiamate standard (a livello di regole di idoneità e personalizzazione).
Parametri di input:
Parametri restituiti:
Il parametro xmlInteraction contiene sia i dati della chiamata che il profilo del contatto caricato dalla query out-of-the-box.
Esempio:
// Call an external system to get additional data for the target
var additionalData = getUrl("https://EXTERNAL_SYSTEM?target=" + encodeURIComponent(aTargetId.join("|")));
// Enrich the context with this data
interaction.@additionalData = additionalData;
Questo gancio consente di verificare la coerenza e la compatibilità delle proposte idonee in una determinata interazione. Consente inoltre di definire una nuova funzionalità di punteggio o calcolo delle probabilità.
Esempio di utilizzo di regole di coerenza:
La post-elaborazione viene eseguita dopo l'applicazione delle regole di tipologia e l'ordinamento delle proposte idonee, e prima della fase di definizione delle priorità.
Parametri di input:
Proposta: tabella delle proposte ammissibili. Esempio della struttura di un elemento in questa tabella
{ offer_id:1234,
weight:2}
dicOffer (tipo xml): dizionario di tutti gli attributi delle offerte idonee (codice offerta, ID categoria, nome completo categoria, data di inizio, data di fine, etichetta, nome interno, ID offerta, campi offerta aggiuntivi). Ad esempio
{ "1242": <offer category-id="61242" categoryFullName="/FULL/PATH/TO/CATEGORY/" code="CODE" endDate="" id="62473" label="LABEL" name="OFR38_OE4" product-id="43" startDate=""/>,
"1243": ...}
xmlTarget (tipo xml): nodo dati profilo
xmlInteraction (tipo xml): call data node
iPropNumber (tipo intero): numero di offerte previste
Parametri restituiti:
Esempio:
var aReturnedProps = [];
if( aProposition.length > 0 )
{
var iReturnedProps = 0;
for( var iPropIdx = 0; iPropIdx < aProposition.length && iReturnedProps < iPropNumber; iPropIdx ++ )
{
// Check a consistency rule for instance
if( true )
{
aReturnedProps.push(aProposition[iPropIdx]);
iReturnedProps++;
}
}
}
return aReturnedProps;
Questo gancio consente di effettuare una chiamata a un motore esterno per selezionare un elenco di prodotti collegati a un'offerta. È configurato nell'offerta dopo le regole di idoneità e prima dell'applicazione delle regole di tipologia.
In precedenza, l'integratore dovrebbe estendere lo schema delle proposizioni PropositionRcp con le informazioni aggiuntive sul prodotto. Per specificare dove memorizzare i dati, nella scheda Storage dello spazio è disponibile un collegamento Proposition being processed
Parametri di input:
Parametri restituiti:
Viene restituito un indice di proposizioni da generare. Ciascun elemento di questa tabella è costituito dalle seguenti informazioni:
Il sistema verifica che l'ID dell'offerta sia lo stesso per i parametri di input e di ritorno.
Esempio:
var product = getUrl("https://EXTERNAL_SYSTEM?offerCode=" + encodeURIComponent(xmlOffer.@code));
if( product )
return [{offer_id: parseInt(String(xmlOffer.@id)), weight: dWeight, productId: product}];