アクセストークンを取得し、XMLファイルを使用してSOAP APIを介してSalesforce Marketing Cloudのテーブルに列を追加する単純なbashファイルがあります。問題は、変数を使用してアクセストークンをxmlファイルに自動的に入れる方法がわからないことです。私は「$token」とそのバリエーションを試しましたが、成功しませんでした。これは私のコードです。
#!/bin/sh
# Get an authorisation Token
token_output=$(curl \
-H "Content-Type: application/json" \
-d '
{
"grant_type": "client_credentials",
"client_id": "ccccccc",
"client_secret": "sssssss",
"scope": null
}' \
https://xxxxxxxx.auth.marketingcloudapis.com/v2/Token | jq '.')
token=$(jq -r '.access_token' <<< "$token_output") \
curl -XPOST \
-H "Content-type: text/xml; charset=utf-8" \
-H "SOAPAction: Update" \
-d @updateDE.xml \
https://xxxxxxxx.soap.marketingcloudapis.com/Service.asmx
これはXMLファイルです。
<?xml version="1.0" encoding="UTF-8"?>
<s:Envelope xmlns:s="http://www.w3.org/2003/05/soap-envelope" xmlns:a="http://schemas.xmlsoap.org/ws/2004/08/addressing" xmlns:u="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd">
<s:Header>
<a:Action s:mustUnderstand="1">Update</a:Action>
<a:To s:mustUnderstand="1">https://xxxxxxxx.soap.marketingcloudapis.com/Service.asmx</a:To>
<fueloauth xmlns="http://exacttarget.com">"$token"</fueloauth>
</s:Header>
<s:Body xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<UpdateRequest xmlns="http://exacttarget.com/wsdl/partnerAPI">
<Options />
<Objects xsi:type="ns1:DataExtension" xmlns:ns1="http://exacttarget.com/wsdl/partnerAPI">
<CustomerKey>0B35F2DD-6A27-448D-96D8-8CBD7598FD85</CustomerKey>
<Fields>
<Field>
<Name>New Field4</Name>
<MaxLength>200</MaxLength>
<IsRequired>true</IsRequired>
</Field>
</Fields>
</Objects>
</UpdateRequest>
</s:Body>
</s:Envelope>
よろしくお願いします。
答え1
たとえば、マーカーの代わりに既知のテキストを配置できます。TOKEN
:
...
<fueloauth xmlns="http://exacttarget.com">TOKEN</fueloauth>
...
その後、sedを使用してそのテキストを実際のマークアップに置き換えます。
sed -i 's/TOKEN/'"$token"'/g' file.xml