v7

Metodi SOAP in JavaScript

Ultimo aggiornamento: 2023-08-31
  • Creato per:
  • Developer

Questo è il JavaScript eseguito sul server Adobe Campaign.

Metodi statici

I metodi SOAP statici sono accessibili richiamando un metodo sull'oggetto che rappresenta lo schema. Gli schemi sono proprietà degli oggetti 'namespace'. Questi spazi dei nomi sono variabili globali, pertanto, ad esempio, le variabili xtk o nms rappresentano gli spazi dei nomi corrispondenti

Nell'esempio seguente viene richiamato il metodo PostEvent statico dello schema xtk:workflow:

xtk.workflow.PostEvent("WKF1", "signal", "", $recipient-id='123', false)

Metodi non statici

Per utilizzare metodi SOAP non statici, è necessario innanzitutto recuperare un’entità utilizzando i metodi "get" o "create" negli schemi corrispondenti.

Nell'esempio seguente viene richiamato il metodo ExecuteQuery dello schema "xtk:queryDef":

var query = xtk.queryDef.create(
  <queryDef schema="xtk:workflow" operation="select">
    <select>
      <node expr="@internalName"/>
    </select>
  </queryDef>
)

var res = query.ExecuteQuery()

for each (var w in res.workflow)
  logInfo(w.@internalName)

Esempi

  • Eseguire una query sulla tabella dei destinatari con un’operazione "get":

    var query = xtk.queryDef.create(
      <queryDef schema="nms:recipient" operation="get">
        <select>
          <node expr="@firstName"/>
          <node expr="@lastName"/>
          <node expr="@email"/>
        </select>
        <where>
          <condition expr="@email = 'peter.martinez@adobe.com'"/>
        </where>
      </queryDef>)
    
    var recipient = query.ExecuteQuery()
    
    logInfo(recipient.@firstName)
    logInfo(recipient.@lastName)
    
  • Eseguire una query sulla tabella dei destinatari con un'operazione di selezione:

    var query = xtk.queryDef.create(
      <queryDef schema="nms:recipient" operation="select">
        <select>
          <node expr="@email"/>
          <node expr="@lastName"/>
          <node expr="@firstName"/>
        </select>
        <where>
          <condition expr="@age > 25"/>
        </where>
      </queryDef>)
    
    var res = query.ExecuteQuery()
    
    for each (var recipient in res.recipient)
    {
      logInfo(recipient.@email)
      logInfo(recipient.@firstName)
      logInfo(recipient.@lastName)
    }
    
  • Scrittura dei dati nella tabella dei destinatari:

    xtk.session.Write(<recipient _operation="insert" lastName="Martinez" firstName="Peter" xtkschema="nms:recipient"/>);
    

In questa pagina