Публикация объекта JSON в Watson Discovery из сценариев приложений Google

Я пытаюсь взять свой календарь Google и публиковать каждый день в качестве документа для обнаружения Watson через сценарии Google. Мой код выглядит так.

    var headers={
            "User-Agent": "CreateCalendarListJson",
            "Authorization": "Basic " + Utilities.base64Encode( authdata.username+":"+authdata.password)
        };
        //headers.contentType="application/json";
        var parms={"headers":headers};
        url=newurl+"/v1/environments/"+discoveryData.environmentID+
          "/collections/"+discoveryData.collection_ID+"/documents/?version=2017-09-01";
        parms.method="POST";
        parms.file={
          'value':JSON.stringify(jsonEvent),
          'options':{
            'filename':jsonEvent.filename,
            'contentType':"application/json"
          }
        }
        console.info('discovery add document %s',JSON.stringify(parms));
        response=UrlFetchApp.fetch(url,parms);

Однако это приводит к ошибке 415 неподдерживаемый тип носителя. Хотя application/json является поддерживаемым типом, и я соответствующим образом установил contentType. Какие-либо предложения?

Переменная parms выглядит следующим образом при запуске UrlFetchApp.Fetch:

{"headers":
     {"User-Agent":"CreateCalendarListJson",
      "Authorization":"Basic ZTIyNTEwM............................tHcg=="},
      "method":"POST",
      "file":{"value":"{\"title\":\"Events 10/13/2017\",\"filename\":\"Events_10_13_2017\",\"text\":[{\"date\":\"10/13/2017\",\"summary\":\"assignment 1\"}]}",
      "options":{"filename":"Events_10_13_2017",
       "contentType":"application/json"}}}"   

person rwreed    schedule 13.10.2017    source источник


Ответы (1)


Проблема в том, что документы в Watson Discovery должны передаваться как тип multipart/form-data. Следующая функция запишет текст json (сохранит в jsonEvent.text) в качестве документа обнаружения. Поместите конечную точку API в «newurl» и сохраните имя пользователя и пароль для обнаружения в «authdata» (объект json), укажите имя файла для документа обнаружения в «имя файла»

function sendtodiscovery(url, jsonEvent, filename,authdata){
   var headers={
        "User-Agent": "CreateCalendarListJson",
        "Authorization": "Basic " + Utilities.base64Encode( authdata.username+":"+authdata.password)
    };
    var parms={"headers":headers};
    var boundary="xxxxxxxx";  
    parms.method="POST";
    var data="--"+boundary+"\r\n"
    data += "Content-Disposition: form-data; name=\"file\"; filename=\""+filename+"\"\r\n";
    data += "Content-Type: application/json\r\n\r\n";
    console.info("data=%s",data);
    console.info("event=%s",JSON.stringify(jsonEvent));
    var payload=Utilities.newBlob(data).getBytes()
    .concat(Utilities.newBlob(JSON.stringify(jsonEvent)).getBytes())
    .concat(Utilities.newBlob("\r\n--"+boundary+"--\r\n\r\n").getBytes());

    parms.contentType="multipart/form-data; boundary="+boundary;
    parms.payload=payload;
    //parms.muteHttpExceptions=true;
    console.info('discovery add document %s',JSON.stringify(parms));
    return UrlFetchApp.fetch(url,parms);
 }
person rwreed    schedule 19.10.2017