Select to view content in your preferred language

Error code 500 on appending data with REST API to ArcGIS Online table

4990
15
Jump to solution
03-05-2024 09:25 AM
Labels (1)
mikaël
Frequent Contributor

I have this process that runs daily, where I get some values from an external source, I transform & store them in a local DB. I then match existing values on AGOL to this local table to make sure the objectids are the same (just to make sure everything is in sync) and add new objectids sequentially locally from the last existing one on AGOL. Then I append (with python) this data to my AGOL table (upload_format = 'geojson', upsert = True, edits = the results from a query on my local DB).

This was running fine, every day, until last week, when I started getting an Exception: Unknown Error (Error Code: 500). The sync and changeTracking parameters are deactivated and I've tried deleting and recreating the table (multiple times)...

What to do?

Please help!

EDIT march 11th

Working with ESRI staff on this, will update with developments. Also noticed that I only have this problem with tables, appending to layers is working correctly.

0 Kudos
1 Solution

Accepted Solutions
mikaël
Frequent Contributor

Well, I think I got it.

My usual workflow was getting data from a local (PostgreSQL/PostGIS) DB and transforming that into a geojson and appending to a layer/table with the upload_format='geojson' parameter. For some reason, it stopped working and I created this post.

When I tried again last time (my last post), I was creating a manual dictionary, transforming that into a featureCollection and using the upload_format='featureCollection' and edits=fc parameters, where fc was my feature collection (from_featureset(from_dict(data))).

Upon further testing today for another project, I was looking yet again at the reference, and noticed that under the edits parameters description, it's written: "Only feature collection json is supported". But I was not sending a feature collection json, I was sending the feature collection object. So I modified the parameter to edits=fc.properties and it was successful!!

The edits parameters description also states: "Append supports all format through the upload_id or item_id". But when I was sending my geojson, I was never using those parameters. So I don't know if it changed at some point. So anyway, I'll try again with a geojson with the upload_id or item_id, and if it still fails, I'll just change my DB query to return a feature collection json instead.

There you go! 🎉

View solution in original post

15 Replies
JeffSilberberg
Frequent Contributor

If it was running fine until last week, I would open a support ticket since AGOL was updated last week and this may be a behavior change or a new bug. 

0 Kudos
mikaël
Frequent Contributor

Well that was exactly what I was thinking, since the problems started occuring on the 26th and the "what's new" blog is dated February 28th, but I did not see anything recent for the REST or Python API.

But yeah good idea, I'll send them an email.

Thanks!

0 Kudos
twhammond
Emerging Contributor

Any word on this one yet? I have a similar situation, except I am appending from an existing gdb.

fLyr.append(item_id=fgd_item.id, upload_format="filegdb", upsert=False, field_mappings=[])

I set up the process to run in task scheduler every few minutes for testing purposes to see what kind of errors I would get.  The script worked for weeks beforehand, and after setting it up in task scheduler, it worked for a couple days. Now when I run it, I get the same result as you: 

Exception: Unknown Error

(Error Code: 500)

mikaël
Frequent Contributor

Last update was yesterday, an ESRI analyst is still looking into this issue.

I changed my workflow to use edit_features() which is more complicated because I have to check beforehand which features I have to update and which I have to add, which I did not have to do with append(). But at least it's working now.
0 Kudos
twhammond
Emerging Contributor

Thanks, I'll start looking at moving away from append() in the meantime.  Hopefully they get to the bottom of it soon.

0 Kudos
mikaël
Frequent Contributor

Here is the latest update:

The outcome of the escalation was Esri Inc. logging the following defect:

BUG-000166918: Error 500 "Unknown error" encountered when overwriting hosted tables with any file type data using ArcGIS API for Python. 

A workaround for this issue is to use a File Geodatabase to append data to the table instead of GeoJSON (or CSV).

 

0 Kudos
twhammond
Emerging Contributor

That's interesting.  I got the issue while appending data using a file geodatabase.  However, the bug mysteriously disappeared after a couple days and has been working normally ever since.  I honestly have no idea what caused it to break, or why I stopped encountering the error.

So I can't say the workaround doesn't work, but I can say as of last Wednesday I was encountering the same error when appending to table from a geodatabase.

0 Kudos
gmaz
by
New Contributor

Glad ESRI could help a bit. I'm also appending a file gdb into a truncated dataset and getting the Error Code: 500. It doesn't seem to be a work around that actually works around. I've looked into edit_features(), but given the size of this dataset getting overwritten daily (~15,000 records) it seems like append() would/should be the tool for the job. Curious if you've heard anything else from ESRI. 

0 Kudos
mikaël
Frequent Contributor

Nope nothing yet. I've started using AGOL regularly 2 years ago and ESRI opened a couple of bugs from my emails.

mikAMD_1-1717591208853.png

No changes yet, so you have to be patient or try to workaround a problem or use something else completely 🙂

0 Kudos