How do I add linkInFromCell by REST API?
using Python SDK.
If I use add_row
it will tell me that this is not allowed.
If I use update_row, and with a random value (if value != null), it will return the following error.
"errorCode": 1110, "message": "cell.value must be null if cell.linkInFromCell is non-null."
If I use update_row, and with a value:null it will claim that value is missing.
Do anyone know how to use this API properly?
Answers
-
If I use update_row, and with a value:null it will claim the following:
"errorCode": 1012, "message": "Required object attribute(s) are missing from your request: cell.value."
I was not able to find proper way for this api to work.
-
Hi @Lilian T
A CellLink object can only be added to an existing cell, so the cell.linkInFromCell attribute is not allowed when POSTing a new row to a sheet (as you've found).
You are correct in using update_row instead of add_row. Additionally, you are correct in having value:null, see this section of the documentation: https://smartsheet-platform.github.io/api-docs/?python#update-cells
"When creating a cell link, cell.value must be null (the data is pulled from the linked cell)."
Keep in mind the following:
"A cell may not contain both a hyperlink and a cell link, so hyperlink and linkInFromCell may never both be non-null at the same time."
Did that help clarify how this feature works? Let me know if you're still receiving any errors!
Cheers,
Genevieve
Join us at Smartsheet ENGAGE 2024 🎉
October 8 - 10, Seattle, WA | Register now -
Hi @Genevieve P
Thanks a lot for getting back.
I did use the update_row and added only linkInFromCell value, however it still gave the same error as "add_row" API.
smartsheet.exceptions.ApiError: {"result": {"code": 1012, "errorCode": 1012, "message": "Required object attribute(s) are missing from your request: cell.value.", "name": "ApiError", "recommendation": "Do not retry without fixing the problem. ", "refId": "dbhpnyonitn5", "shouldRetry": false, "statusCode": 400}}
I didn't have hyberlink value set in the cell value. (in Python)
Idnew_row.cells = [ { "columnId": [columnId], "linkInFromCell":{ "columnId": [link_from_columnId], "rowId" [link_from_rowId], "sheetId": [link_from_sheetId] }, "value": None } ]
-
Hi @Lilian T
My apologies, I've looked into this further and by default the SDKs won't serialize a null property, so even though it is being set to
None
in this case,value
won't be present in the JSON body.The provision created in the SDKs is to use an
ExplicitNull.
I have an example of this for you:
def test_link_in_from_cell(self, smart_setup): smart = smart_setup['smart'] sheet = smart_setup['sheet'] row = smart.models.Row() row.to_bottom = True col_id = sheet.columns[0].id row.cells.append({ 'column_id': col_id, 'value': 'abc123' }) action = smart.Sheets.add_rows(sheet.id, [row]) added_row = action.result[0] assert isinstance(added_row, smart.models.row.Row) assert action.request_response.status_code == 200 sheet_b = smart_setup['sheet_b'] cell_link = smart.models.CellLink() cell_link.sheet_id = sheet_b.id cell_link.row_id = sheet_b.rows[0].id cell_link.column_id = sheet_b.columns[0].id cell = smart.models.Cell() cell.column_id = col_id cell.link_in_from_cell = cell_link cell.value = smart.models.ExplicitNull() row = smart.models.Row() row.id = added_row.id row.cells.append(cell) action = smart.Sheets.update_rows(sheet.id, [row]) assert action.request_response.status_code == 200 action = smart.Sheets.delete_rows(sheet.id, [added_row.id]) assert action.request_response.status_code == 200
You may want to take a look at the discussions about this on the GitHub website, such as this one: updating row with cellLink()
Let me know if this has worked for you!
Genevieve
Join us at Smartsheet ENGAGE 2024 🎉
October 8 - 10, Seattle, WA | Register now -
retry with ExplicitNull
error message changed:
smartsheet.exceptions.ApiError: {"result": {"code": 1032, "errorCode": 1032, "message": "The attribute(s) cell.linkInFromCell are not allowed for this operation.", "name": "ApiError", "recommendation": "Do not retry without fixing the problem. ", "refId": "gjtvl6uogub3", "shouldRetry": false, "statusCode": 400}}
guess it's not possible to be used as an input for add_row API?
retrying with update_row
-
from the documents (Cell Links)
seems POSTing a new row is indeed not allowed.
Creating or updating cell links via the cell.linkInFromCell attribute is a special operation. A given row or cell update operation may contain only link updates, or no link updates. Attempting to mix row/cell updates with cell link updates results in error code 1115. Additionally, a CellLink object can only be added to an existing cell, so the cell.linkInFromCell attribute is not allowed when POSTing a new row to a sheet.
-
update_rows() received the following error:
smartsheet.exceptions.ApiError: {"result": {"code": 4000, "errorCode": 4000, "message": "An unexpected error has occurred. Please contact the Support team at https://help.smartsheet.com/contact for assistance.", "name": "ApiError", "recommendation": "Do not retry without fixing the problem. ", "refId": "7tc8g7ifmdqn", "shouldRetry": false, "statusCode": 500}}
payload didn't change at all. will investigate further later why.
Categories
- All Categories
- 14 Welcome to the Community
- Smartsheet Customer Resources
- 62.1K Get Help
- 349 Global Discussions
- 199 Industry Talk
- 427 Announcements
- 4.4K Ideas & Feature Requests
- 133 Brandfolder
- 127 Just for fun
- 127 Community Job Board
- 455 Show & Tell
- 28 Member Spotlight
- 1 SmartStories
- 282 Events
- 36 Webinars
- 7.3K Forum Archives