SmartLinxToFeatureClass exports LightPoint devices from SmartLinx Core APIs (https://ats-api.smartlinx.tech/api/v2/) to Esri ArcGIS Feature Class format capturing attributes in the name, coords, core, and metering tables from SmartLinx API. In order to run, a cloned Esri ArcGIS Anaconda Python Environment must be created and additionally aiohttp, and asyncio must be installed within this Python Environment. These additional libraries are required to allow optimized asynchronous calls to the SmartLinx API, which will retrieve all LightPoint devices with all attributes in the SmartLinx name, coords, core, and metering tables. Once the information is retrieved from the SmartLinx API, it is then converted into a csv file, and an Esri ArcGIS Feature Class. Using the tool interface provided in Esri ArcGIS Pro, users can enter the SmartLinx API i.e https://ats-api.smartlinx.tech/api/v2/, their BEARER_TOKEN (which will be provided by SmartLinx to manage access/authentication into the system), and the desired location of the output feature class.
- ArcGIS cloned Python env with aiohttp and asyncio installed
- Bearer_token (provided by SmartLinx)
- SmartLinx API -> copy here: https://ats-api.smartlinx.tech/api/v2/
- Bearer Token to SmartLinx API -> as text
- Output Feature Class Location -> make an output name in an Esri File Geodatabase
- Within Esri ArcGIS Pro, Navigate using the Project Button-> Package Manager
- Within the Package Manager Page, click the gear icon followed by the plus-folder icon (which says clone environment) A Dialog Box will pop-up stating, "Clone Environment" and provide options for "Source" and "Destination." Leave the "Source" as deault, as it is the original Python environment that is configured to work with ArcGIS Pro, but modify the "Destination" to a location of your choosing (can be the same as the Source Path but with a different ending name i.e if "Source" is C:\Program Files\ArcGIS\Pro\bin\Python\envs\arcgispro-py3, it can be C:\Program Files\ArcGIS\Pro\bin\Python\envs\arcgispro-py3-main). Once you have decided a Path for your clone, Click "Okay". After clicking "Okay" ArcGIS will begin cloning your environment, which will take a little time. Wait a little bit to receieve a confirmation that the clone has been successfully created.
- After creating the cloned environment, Click the "Active Environment" window, and select the new environment, that was just created. Once we have a cloned environment, we have the ability to modify it i.e add packages. But before we can add packages, it must be set as the "Active Environment" in the ArcGIS Pro window.
- Once you have created your cloned env, and activated it within Esri ArcGIS Package manager, open the windows start panel and navigate to the app "Python Command Prompt"
- Enter the app, and a terminal window should open. It is necessary to open this specific terminal, because it is installed with ArcGIS Pro and has access to the ArcGIS anaconda python environments. You should receive a terminal, resembling the windows below -> That shows it is "active" with the new Esri ArcGIS Pro Env, i.e. the cloned env that was just created. If it says arcgispro-py3 ONLY, and not the name of the one that was just created, please ensure that the cloned environment is showing up in Pro, and that it is set as the "Active Environment."
- Run the command below in the terminal to install aiohttp
pip install aiohttp
- Run the command below in the terminal to install asyncio
pip install asyncio
- Assuming packages install successfully, exit the terminal window and go back to Esri ArcGIS Pro
- Using the "Download ZIP" button in the Github webpage, download the repo and extract it to a location your ArcGIS Pro project has access to.
If you know git, can also use git clone:
git clone https://github.com/SDGIS/ArcProTool_Smartlinx.git
Once you have downloaded the repo, you can proceed to using the tool in ArcGIS Pro.
-
Using ArcGIS Pro Catalog View -> Navigate to the Toolbox SmartLinx.atbx which will be in the location where you downloaded the repo
-
Double click on SmartLinx toolbox to enter the toolbox, and see that the SmartLinxToFeatureClass tool is within the toolbox
-
Double click on the SmartLinxToFeatureClass Tool and the GP Pane will open the tool where you can fill in the parameters.
-
Fill in the API (https://ats-api.smartlinx.tech/api/v2/), add your Bearer Token from SmartLinx as text, and select an output feature class, and click the Run button in the bottom of the pane. The tool should beginning running, and display messages.
-
Check your output feature class for your results!