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 есть несколько проблем, в том числе:

  • Непревзойденные скобки
  • Дополнительные квадратные скобки снаружи (тело это объект, а не массив)
  • Идентификаторы столбца и строки должны быть числами, а не строками

Я предлагаю вам сначала проверить полезную нагрузку в таком инструменте, как почтальон.

Другие вопросы по тегам