Smartsheet API обновить строки ошибок 1004. Вы не авторизованы
Я пытаюсь использовать powershell и API для обновления ячейки, но получаю сообщение об ошибке: 1004 У вас нет прав на выполнение этого действия. Я исключил удостоверения личности.,,
У меня есть 30-дневная пробная версия. Нужно ли мне покупать какой-то уровень поддержки, прежде чем я смогу использовать API для обновления или как? Лист находится на моем счете, и я владелец. Является ли роль "Записывать листы" в "Владелец"?
Я использую PowerShell 5.1, чтобы сделать http-запрос - вот мой сценарий. Сначала он получает правильный идентификатор листа, затем помещает интересующие меня строки и столбцы в хэши, а затем пытается обновить лист, но, хотя я являюсь владельцем, я не авторизован.
# access account of jjj.mmm@ddd.com
$apiKey = "3ccfgk..."
$url = "https://api.smartsheet.com/2.0/sheets/"
$get_headers = @{"Authorization" = "Bearer " + $apiKey}
$put_headers = @{"Authorization" = "Bearer " + $apiKey, "Content-Type: application/json" }
# get all the sheets
$response = Invoke-RestMethod -Uri $url -Headers $get_headers
$rd = $response.data
$json = ConvertTo-Json $rd
# find the Forecast sheet
$sheet_id = $rd | Where {$_.name -eq "Forecast Intermediary Sheet"} | Select -ExpandProperty id
"Sheet ID: $sheet_id"
#get the Forecast sheet
$surl = "$url$sheet_id"
$surl
$response = Invoke-RestMethod -Uri $surl -Headers $get_headers
$response | Format-List
# iterate over the rows and get the active ones
$active_rows = @{}
foreach ($row in $response.rows) {
if ($row.rowNumber -ge 14) {
if ($row.cells[2].value -Match "Active") {
$active_rows.Add($row.cells[2].value, $row.id)
}
}
}
# get the col_ids by date
$date_cols = @{}
foreach ($c in $response.columns) {
if ($c.title -as [datetime]) {
$d = $c.title -replace "/20", "/"
$ds = [datetime]::parseexact($d, 'mm/dd/yy', $null)
$date_cols.Add($ds.Tostring("yyyy-mm-dd"), $c.id)
}
}
"UPDATE:"
$rowid = $active_rows["SSL PS Active"]
$colid = $date_cols["2017-11-01"]
"row: $rowid, col: $colid"
$json = '[{ "id": "'+$rowid+'", "cells": [{"columnId": "'+$colid+'","value": "23"} }]'
"JSON: $json"
$purl = "$surl/rows"
"PUT URL: $purl"
$r = Invoke-RestMethod -Method "PUT" -uri $purl -Headers $put_headers -Body $json
$r
Ниже приведен вывод сценария. Кажется, ошибка указывает на то, что она синтаксически верна, но у ВЛАДЕЛЬЦА недостаточно прав.
Sheet ID: 5724...
https://api.smartsheet.com/2.0/sheets/5724....
UPDATE:
row: 5668..., col: 5118...
JSON: [{ "id": "5668...", "cells": [{"columnId": "5118...","value": "23"} }]
PUT URL: https://api.smartsheet.com/2.0/sheets/5724.../rows
Invoke-RestMethod : {
"errorCode" : 1004,
"message" : "You are not authorized to perform this action.",
"refId" : "14a7o8lu9sfyj"
}
At \\winfiles\jmoore\powershell\ss_api.ps1:58 char:6
+ $r = Invoke-RestMethod -Method "PUT" -uri $purl -Headers $put_headers ...
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidOperation: (System.Net.HttpWebRequest:HttpWebRequest) [Invoke-RestMethod],
WebException
+ FullyQualifiedErrorId : WebCmdletWebResponseException,Microsoft.PowerShell.Commands.InvokeRestMethodComand
Вот метаданные моего листа
Sheet ID: 5724...
https://api.smartsheet.com/2.0/sheets/5724....
id : 5724...
name : Forecast Intermediary Sheet
version : 2
totalRowCount : 37
accessLevel : OWNER
effectiveAttachmentOptions : {GOOGLE_DRIVE, DROPBOX, ONEDRIVE, EGNYTE...}
ganttEnabled : False
dependenciesEnabled : False
resourceManagementEnabled : False
cellImageUploadEnabled : True
userSettings : @{criticalPathEnabled=False; displaySummaryTasks=True}
permalink : https://app.smartsheet.com/b/home?lx=LCTEj6F0xWNKWWxFUuLH0w
createdAt : 2017-11-22T22:34:51Z
modifiedAt : 2017-11-22T22:34:51Z
columns : {@{id=6985...; index=0; title=Column1; type=TEXT_NUMBER; primary=True;
validation=False; width=64}, @{id=1356...; index=1; title=Column2;
type=PICKLIST; options=System.Object[]; validation=False; width=64},
@{id=5859...; index=2; title=Column3; type=TEXT_NUMBER; validation=False;
....
2 ответа
Вы должны иметь возможность совершать вызовы API с помощью токена доступа API, принадлежащего пробной учетной записи Smartsheet, и вы, безусловно, можете обновить свой лист с помощью принадлежащего вам токена доступа API.
Я подозреваю, что 1004
Ответ об ошибке вызван тем, что содержимое $put_headers
неправильно отформатирован. то есть Smartsheet не может точно проанализировать заголовки, которые вы пытаетесь указать в $put_headers
чтобы определить заголовок авторизации и прочитать его значение. Когда Smartsheet не видит заголовок Authorization во входящем API-запросе, он отвечает 1004 You are not authorized to perform this action.
ответ об ошибке.
Чтобы устранить эту проблему, я бы предложил вам использовать такой инструмент, как Fiddler, для проверки исходящего запроса "Обновить строки", обращая особое внимание на то, какие заголовки присутствуют в запросе. Затем, если вы обнаружите, что заголовок Authorization отсутствует в запросе, вам необходимо выяснить, как указать несколько заголовков запроса в PowerShell, и соответственно обновить код, как вы устанавливаете значение. $put_headers
,
Обновление (добавление кода PowerShell):
Я не эксперт по PowerShell, но вы можете попробовать заменить эту строку:
$put_headers = @{"Authorization" = "Bearer " + $apiKey, "Content-Type: application/json"}
Вместо этих строк:
$put_headers = @{}
$put_headers.Add("Authorization", "Bearer " + $apiKey)
$put_headers.Add("Content-Type", "application/json")
Спасибо @ Ким-Брандл
Или, если вы хотите построить заголовки в одной команде, вам нужно использовать синтаксис, подобный этому:$put_headers = @{"Authorization" = "Bearer " + $apiKey; "Content-Type" = "application/json" }
Также обратите внимание, что у вашего json есть несколько проблем, в том числе:
- Непревзойденные скобки
- Дополнительные квадратные скобки снаружи (тело это объект, а не массив)
- Идентификаторы столбца и строки должны быть числами, а не строками
Я предлагаю вам сначала проверить полезную нагрузку в таком инструменте, как почтальон.