The purpose of this project is to develop a robust tool for reliably transferring datasets between ERDDAP services and ArcGIS Online (AGOL) OR ArcGIS Enterprise. Erddap2agol is a "hands-off" Python package designed to operate seamlessly within the AGOL environment. Its core functionalities include creating, managing, and updating ERDDAP datasets at various levels of granularity. Developed by the Gulf of America Ocean Observing System (GCOOS), erddap2agol is available for use by data providers leveraging ERDDAP services, as well as individuals and organizations aiming to analyze and visualize ERDDAP data on a GIS platform.
For questions or problems with the program, please submit an issue. 
This tool was principally designed for data managers who wish to expand the utility and accessibility of their ERDDAP services. To use the data maintenance capabilities (NRT or Weekly updates), you must be an administrator of your ArcGIS Online organization. That said, anyone can run this tool to create ERDDAP data on their ArcGIS Online account! With an easy to use command line user interface and a ready made ArcGIS Online notebook, virtually no programming experience is necessary! 
Please note that this program, if you ask it to, will obediently consume all your ArcGIS Online credits. 
- 
Manage your ERDDAP data on ArcGIS Online at a variety of time-scales or data types! 
- 
Explore data on 63 ERDDAP services with search features 
- 
Create ERDDAP datasets in batch. (Available now!) 
- 
NRT: 7 day moving window, Level 1. (Available now!) 
- 
Glider DAC Line Segments: Create multiline HFLs from the Glider DAC ERDDAP (Available now!) 
- 
Create multidimensional hosted imagery layers from griddap layers (Available now!) 
- 
Historical: Updated weekly, contains all data, Level 2. (WIP) 
- 
QC Historical: QC Flags, low quality records removed, Level 3. (WIP) 
- 
Multiple install options (Updating README on program functionality soon!). 
- 
Install directly into an AGOL notebook. 
- 
Build AGOL environment locally. 
To publish hosted imagery layers from griddap services, erddap2agol must be run in an ArcPy enabled environment. A local environment is recommended for best performance.
Erddap2agol can be pip installed into any active ArcGIS Conda Environment, whether that be on your desktop with an ArcGIS Python interpreter, or in an ArcGIS Online Hosted Notebook. 
The following is an example of the code required to access the erddap2agol CUI
!pip install https://github.com/GCOOS/erddap2agol/archive/refs/heads/main.zip 
import erddap2agol 
from erddap2agol import run 
run.cui() 
Functionality in erddap2agol is divided into two major components, each with their own use requirment:
- Command-Line User Interface (CUI)
- To access the CUI, follow the instructions from instillation options. 
- Standalone Notebook functions (e.g., _updateNRT)
- The underscore functions within the run module are to be used in AGOL hosted notebooks. To deploy these capabilities, simply follow the pip install/import process outlined above, then schedule the notebook to run at your desired interval. 
Access the ArcGIS Online Notebook that is configured to run the CUI here
Contains the ERDDAPHandler class.
Different ERDDAP Servers exist as objects of the ERDDAPHandler class. 
Class methods relate to generating request URLS and handling response content.
Contains the DataWrangler class. 
This class is responsible for receiving and processing the ERDDAP datasets.
Determines the size of the requested dataset and chunks dataset requests if needed. 
Contains the AgolWrangler class. 
Responsible for connecting the client to AGOL and interfacing with the ArcGIS Python API. 
Attributes of the NC Global section of the DAS are used to construct the item_properties dictionary. 
A feature service is created and populated with the dataset returned by the ERDDAP_Client URL. 
Update / Overwrite Feature Service v2.1.4 
By: Deniz Karagulle & Paul Dodd, Software Product Release, Esri