Common questions about the Agdir Satellite API, analysis types, status codes, and troubleshooting.
Analyses labeled as "crop-specific" (like Potato Analyses) use specialized ML models trained on data from that particular crop. However, the underlying satellite imagery captures all vegetation in the field — the analysis runs regardless of what is actually growing. It is your responsibility to ensure that the correct crop type is planted in the field for the results to be meaningful.
If you run a potato yield analysis on a wheat field, the system will still produce results, but they will not be accurate because the model was calibrated for potato canopy characteristics.
General analyses (vegetation indices, plant health, water stress) measure properties common to all vegetation — chlorophyll content, water content, leaf area. They work on any crop type.
Crop-specific analyses (crude protein, dry matter, biomass, potato yield/starch) use specialized models that have been trained and calibrated for specific crop types. They produce more accurate results for their target crop but should not be used on other crops.
An HTTP status code 200 and a GraphQL response with "Status": "OK" means the API successfully received and accepted your request. It does not mean the analysis is complete.
Think of it like placing an order at a restaurant: the waiter confirms your order (status 200), but the food still needs to be prepared. You need to check whether your order is ready by monitoring the request.
Use any of the three monitoring queries:
retrieveRequestDetails(requestId) — Check a specific request by its ID. Best for tracking a single analysis.retrieveRequestsHistory(polygonId, startDate, endDate) — View all completed and failed requests for a polygon. Good for batch monitoring.retrieveRequestsInProgress(polygonId) — List all active requests for a polygon. Useful for seeing what is still being processed.A request is done when its status is Success, Error, or NoAvailableDate. See the Monitor a Request page for the full status workflow.
There are several common causes:
Results are only available after the request reaches the Success status. Check the status with retrieveRequestDetails(). If the status is still Submitted, SentinelQueue, or another intermediate status, the analysis is still processing.
If the status is NoAvailableDate, it means no cloud-free satellite imagery was available for your polygon during the requested date range. Try expanding the date range or checking satellite download availability.
Some analyses take longer than others, especially for large polygons or long date ranges. The processing pipeline handles satellite downloads, analysis computation, and result generation — each step takes time. Allow at least 10–30 minutes for most analyses.
In rare cases, a request may end in Error status due to internal processing issues. If this happens:
No. The latest available date is yesterday. Satellite data requires processing time after acquisition before it becomes available in the Agdir system. See API Restrictions for all date limits.
The earliest supported date is 2018-01-01. This is when Sentinel-2 data became reliably available with sufficient coverage and quality for the analyses provided by the API.
Contact the Agdir support team at support@agdir.no. Include your polygon ID and request ID when reporting issues for faster resolution.