/crowdsource-reporter-scripts

Scripts that can be used to extend the functionality of crowdsource reporter

Primary LanguagePythonApache License 2.0Apache-2.0

crowdsource-reporter-scripts

This repository contains a series of tools that can be used to extend the functionality of editable feature layers published to an ArcGIS Online organization or an ArcGIS portal. The scripts can be scheduled using an application such as Windows Tasks to scan the feature layers for new content.

Generate Report IDs

A script to generate identifiers for features using a defined sequence and a value that increments on a defined interval.

Requirements

Python 2.7, ArcPy

Configuration

For more information on configuring this script, see the documentation: Generate Report IDs

Download a supported version of the Service Functions script here, which contains the Generate Report IDs script.

Moderate Reports

A script to filter features based on lists of explicit and sensitive words. The script updates a flag field when a word on these lists is detected so that the feature no longer meets the requirements of a filter on a layer in a web map.

Requirements

Python 2.7, ArcPy

Configuration

For more information on configuring this script, see the documentation: Moderate Reports

Download a supported version of the Service Functions script here, which contains the Moderate Reports script.

Send Email Notifications

Send emails to specific email addresses, or to addresses in fields in the data. Multiple messages can be configured for each layer based on attribute values. The script updates a flag field to indicate that each message has been sent.

Requirements

Python 3, ArcGIS API for Python

Configuration

For more information on configuring this script, see the documentation: Send Email Notifications

Download a supported version of the Service Functions script here, which contains the Send Email Notifications script.

Enrich Reports

Calculate feature attributes based on the attributes of co-incident features.

Requirements

Python 3, ArcGIS API for Python

Configuration

For more information on configuring this script, see the documentation: Enrich Reports

Download a supported version of the Service Functions script here, which contains the Enrich Reports script.

Connect to ArcGIS Workforce

Create workforce assignments from incoming Crowdsource Reporter, GeoForm, and Survey 123 reports.

Requirements

Python 3, ArcGIS API for Python

Configuration

For more information on configuring this script, see the documentation: Connect to ArcGIS Workforce

Download a supported version of the Connect to ArcGIS Workforce script here

Cityworks Connection (Developed in Partnership with Cityworks)

A script to pass data from editable ArcGIS feature layers to Cityworks tables, including related records and attachments. The script also passes the Cityworks Request ID and open date back to the ArcGIS feature.

The script assumes that the data is being collected using the Crowdsource Reporter application. For input, it requires the group containing the maps that are visible in the Crowdsource Reporter app.

Note: This integration requires specific versions of the Cityworks platform and integration with existing service request content. If you would like to integrate Citizen Problem Reporter with your Cityworks implementation, please reach out to your Cityworks account representative. They will be able to help you with specific system requirements and the steps required to complete the integration.

Requirements

ArcGIS Pro 2.2+ Python 3.5+, ArcGIS API for Python 1.4.1+

Configuration
  1. If not previously installed, use the Python Package Manager in ArcGIS Pro to install the ArcGIS API for Python (package name: arcgis)
  2. In ArcGIS Pro, install the Solutions Deployment Tool, and use it to deploy the Citizen Problem Reporter solution to your portal or organization. If necessary, use this tool to add fields to the layers and to update the domains to match the report types found in Cityworks.
  3. In ArcGIS Pro, add the Connect2Cityworks toolbox to your current project.
  4. Open the tool contained in the toolbox.
  5. Provide the connection information for both Cityworks and ArcGIS Online/ArcGIS Enterprise.
  6. Choose the group used to configure the Crowdsource Reporter application being used to collect the data.
  7. Choose the layers that the tool should process. These parameters will list all layers from the maps in the group that have at least one editable field configured in the popup.
  8. Choose the Cityworks field that contains the Request ID, and the ArcGIS field where this value should be recorded. Only ArcGIS fields found in all selected layers will be options for the ArcGIS Report ID Field parameter.
  9. Choose the Cityworks field that contains the open date of the service request, and the ArcGIS field where this value should be recorded. Only ArcGIS fields found in all selected layers will be options for the ArcGIS Open Date Field parameter.
  10. Choose the Cityworks field and the ArcGIS field that contains the type of request generated by the report. Both fields must support identical values. Only ArcGIS fields found in all selected layers will be options for the ArcGIS Report Type Field parameter.
  11. Choose the field used to indicate the status of the report with regards to being transferred to Cityworks. Specify the value of this field when the report needs to be transferred in the Flag On Value parameter, and the value once the transfer is complete in the Flag Off Value parameter.
  12. Map other field pairs to transfer additional information received with the report to Cityworks. Some Cityworks fields you will want to consider are: CallerFirstName, CallerLastName, CallerAddress, CallerCity, CallerState, CallerZip, CallerHomePhone, CallerEmail, Details, Address. Map an unused Cityworks Universal Custom Field to the ArcGIS field OBJECTID. For example Num5 to OBJECTID.
  13. Optionally, choose editable tables from the maps to process as well as the layers. These related records will be copied to Cityworks as additional information on the report. As with the layers, map the ArcGIS and Cityworks fields to specify which data should be transferred. To transfer comments, map the following Cityworks fields: FirstName, LastName, Comments.
  14. Finally, choose a location to save out this information in a configuration file. This configuration file will be read by the script that will handle the transfer of information between ArcGIS and Cityworks.

The following is an example of what a config file might look like:

{
    "cityworks": {
        "username": "apiuser",
        "password": "apipassword",
        "url": "https://cityworks.your-org.com/CityworksSite",
        "timezone": "America/Denver",
        "isCWOL": false
    },
    "fields": {
        "ids": [
            "RequestId",
            "REPORTID"
        ],
        "type": [
            "ProblemSid",
            "PROBTYPE"
        ],
        "opendate": [
            "DateTimeInit",
            "submitdt"
        ],
        "layers": [
            [
                "CallerAddress",
                "ADDRESS"
            ],
            [
                "CallerCity",
                "CITY"
            ],
            [
                "CallerState",
                "STATE"
            ],
            [
                "CallerZip",
                "ZIP"
            ],
            [
                "CallerFirstName",
                "FNAME"
            ],
            [
                "CallerLastName",
                "LNAME"
            ],
            [
                "CallerHomePhone",
                "PHONE"
            ],
            [
                "CallerEmail",
                "EMAIL"
            ],
            [
                "Details",
                "DETAILS"
            ],
            [
                "Address",
                "LOCATION"
            ],
            [
                "Num5",
                "OBJECTID"
            ]
        ],
        "tables": [
            [
                "FirstName",
                "FNAME"
            ],
            [
                "LastName",
                "LNAME"
            ],
            [
                "Comments",
                "COMMENT"
            ]
        ]
    },
    "flag": {
        "field": "processed",
        "on": "No",
        "off": "Yes"
    },
    "arcgis": {
        "username": "ArcGISUser",
        "password": "ArcGISPassword",
        "layers": [
            "https://services.arcgis.com/5555555555555555/arcgis/rest/services/Citizen_Request_Portal/FeatureServer/2",
            "https://services.arcgis.com/5555555555555555/arcgis/rest/services/Citizen_Request_Portal/FeatureServer/1",
            "https://services.arcgis.com/5555555555555555/arcgis/rest/services/Citizen_Request_Portal/FeatureServer/0"
        ],
        "tables": [
            "https://services.arcgis.com/5555555555555555/arcgis/rest/services/Citizen_Request_Portal/FeatureServer/4",
            "https://services.arcgis.com/5555555555555555/arcgis/rest/services/Citizen_Request_Portal/FeatureServer/3",
            "https://services.arcgis.com/5555555555555555/arcgis/rest/services/Citizen_Request_Portal/FeatureServer/5"
        ],
        "url": "https://yourorg.maps.arcgis.com"
    }
}

To execute the script that transfers data between ArcGIS and Cityworks, configure an application such as Windows Task Scheduler.

  1. Open Windows Task Scheduler
  2. Click Action > Create Task and provide a name for the task.
  3. Click the Action tab and click New.
  4. Set Action to Start a Program.
  5. Browse to the location of your Python 3 installation (for example, \Program Files\ArcGIS\Pro\bin\Python\envs\arcgispro-python3\python.exe).
  6. In the Add arguments text box, copy the name of the script (connect_to_cityworks.py) and the path to the configuration file save from running the tool in ArcGIS Pro.The script name and the configuration file path must be separated by a script, and the configuration file path must be surrounded with double quotes if it contains any spaces.
  7. In the Start in text box, type the path to the folder containing the scripts and email templates and click OK.
  8. Click the Trigger tab, click New, and set a schedule for your task.
  9. Click OK.

General Help

Resources

Learn more about Esri's ArcGIS for Local Government maps and apps.

Show me a list of other Local Government GitHub repositories.

Issues

Find a bug or want to request a new feature? Please let us know by submitting an issue.

Contributing

Esri welcomes contributions from anyone and everyone. Please see our guidelines for contributing.

Licensing

Copyright 2016 Esri

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

A copy of the license is available in the repository's LICENSE file.