Google Apps Script Basecamp POST
Я перепробовал все комбинации, которые могу придумать, чтобы сделать эту работу. Что мне нужно отправить в New Basecamp API как POST
поле, чтобы принять мои данные POST?
Мой код:
function getFilterBy() {
var url = "https://basecamp.com/****/api/v1/projects/*****.json";
var payload = {"name" : "myapp", "description" : "no desc mls"};
var opt = {
"contentType" : "application/json",
"method" : "POST",
"headers":{ "User-Agent": "myapp (user@somewhere.com)",
"Authorization" :"Basic " + Utilities.base64Encode("user" + ":" + "pass")},
"validateHttpsCertificates" :false,
"muteHttpExceptions" : true,
"payload" : payload
};
var response = UrlFetchApp.fetch(url, opt);
var text = response.getContentText();
Logger.log(text);
}
Моя ошибка:
lexical error: invalid char in json text.
description=no+desc+mls&name=Ho
(right here) ------^
Я пытался Utilities.jsonStringify
, но не повезло. Я знаю, это ошибка новичка, но я просто не могу понять это. Если есть место, где вы знаете, где я могу получить эту информацию, это было бы феноменально.
Спасибо!
ОБНОВЛЕНИЕ 1
function getFilterBy() {
var url = "https://basecamp.com/****/api/v1/projects/****.json";
var payload = {name : 'myApp Change'};
var opt = {
"contentType" : "application/json",
"method" : "POST",
"headers":{ "User-Agent": "myApp (user@ex.com)",
"Authorization" :"Basic " + Utilities.base64Encode("user" + ":" + "pass")},
"validateHttpsCertificates" :false,
"muteHttpExceptions" : true,
"payload" : Utilities.jsonStringify(payload)
};
var response = UrlFetchApp.fetch(url, opt);
var text = response.getContentText();
Logger.log(text);
}
Удаляет Err:
<body>
<div class="dialog">
<div class="innercol">
<h1>Hmm, that isn’t right</h1>
<h2>You may have typed the URL incorrectly.</h2>
<p>Check to make sure you’ve got the spelling, capitalization, etc. exactly right.</p>
</div>
</div>
<p id="back" class="back">
<a href="javascript:window.history.back();">← Back to previous page</a>
</p>
<script type="text/javascript">
if (window.history.length <= 1) document.getElementById("back").style.display = "none";
</script>
</body>
1 ответ
Вы уверены, что пытались правильно с JSON.stringify? Этот пример здесь правильно создает проект для меня в Basecamp с указанным именем / описанием проекта в полезной нагрузке POST.
Обратите внимание, я написал это быстро, чтобы не включать UserAgent - вы захотите вернуть его обратно.
function createProject() {
var user = 'USERNAME';
var password = 'PASSWORD'
var accoundId = 'ACCOUNTID#';
var url = 'https://basecamp.com/'+accoundId+'/api/v1/projects.json';
var payload = {name : 'new project', description : 'my project description'};
var opt = {
contentType : 'application/json',
method : 'post',
headers:{Authorization :"Basic " + Utilities.base64Encode(user + ':' + password)},
validateHttpsCertificates :false,
muteHttpExceptions : true,
payload : JSON.stringify(payload)
};
var response = UrlFetchApp.fetch(url, opt);
var text = response.getContentText();
Logger.log(text);
}
Чтобы обновить проект, вы должны использовать put
глагол вместо post
как задокументировано здесь
Вот рабочий образец -
function updateProject() {
var projectId = '2413370';
var url = 'https://basecamp.com/'+accoundId+'/api/v1/projects/'+projectId+'.json';
var payload = {name : 'new project', description : 'my new new project description'};
var opt = {
contentType : 'application/json',
method : 'put',
headers:{Authorization :"Basic " + Utilities.base64Encode(user + ':' + password)},
validateHttpsCertificates :false,
muteHttpExceptions : true,
payload : JSON.stringify(payload)
};
var response = UrlFetchApp.fetch(url, opt);
var text = response.getContentText();
Logger.log(text);
}