ArcGIS Notebooks allow you to publish notebooks as web tools. Administrators and notebook authors with the Publish web tools privilege can publish notebooks they own as web tools. When a notebook is published as a web tool, an asynchronous geoprocessing service is created and registered as a web tool. There is a one-to-one relationship between the notebook and the web tool, meaning only one web tool can be published per notebook. Web tools can be consumed by any client application that can work with RESTful asynchronous geoprocessing services.
Publishing a notebook as a web tool is supported for notebooks with runtime version 8.0 or later. To check a notebook's runtime information, click the Info button on the top ribbon of the notebook editor or on the Settings tab in the notebook's item details page. See View available Python libraries to learn more about notebook runtimes.
The notebook editor allows you to configure input and output parameters for a notebook. Input parameters correspond to input variables in a notebook that you want to externalize for user input when the notebook is run as a web tool. Output parameters represent the output variables in a notebook that you want to return as web tool outputs. When you register one or more input or output variables and publish a notebook, the parameters become available as input or output parameters for the corresponding web tool.
Note:
It is not required to define input or output parameters when publishing a notebook as a web tool. For example, notebooks that perform tasks with predefined inputs and outputs, such as feature layers referenced by itemId, may not require input or output parameters.
Note:
The following data types are supported as input or output parameters: String, Long, Double, Boolean, Feature set, Record set, Date, Linear unit, Raster data layer, and File. For more information, see Geoprocessing services data types in the ArcGIS REST API documentation.
When a web tool is run, ArcGIS Notebooks performs an automated run of the notebook by opening a new container and running the notebook without user interaction. Users with the run web tools privilege and with whom the web tool has been shared can access and run the web tool. In addition to the required run web tools privilege, any other privileges required to run the notebook are required. See the User types, roles, and privileges topic to learn more about privileges.
Note:
When authoring a notebook to be shared as a web tool, if the notebook references a file from your workspace directory as input data, those files will not be accessible by others with whom the notebook or web tool is shared. If you have a file that needs to be referenced as input data in the notebook, you can reference it through a shared item in your ArcGIS content.
Note:
If you do not see Parameters or Publish options in the notebook editor, you either do not have the Publish web tools privilege or are not the owner of the notebook. If you are in a newly created notebook, the Parameters and Publish options do not display until the notebook has been saved.
Configure input parameters
Input parameters represent input variables in a notebook that are externalized when a notebook is run as a web tool. Using the Parameters pane in the notebook editor, you can configure and add input parameters as variables to your notebook.
- In the notebook editor, click Parameters.
- Click Add.
- Select input for Direction.
- Enter a name for Variable name.Note:This must match a variable name that is in the notebook code or is already configured in the notebook.
- Enter a name for Display name for the web tool parameter.
- From the Data type drop-down menu, select a data type for the input parameter.
- Select Required or Optional for Parameter type.
- Optionally, if the data type of the input parameters is String, Long, or Double, configure the choice list by entering values under Choice list (optional).With a choice list configured, a web tool user must choose a value from a drop-down menu when running the tool. For example, if a user opens the tool in Map Viewer, they can choose from a drop-down menu of configured parameter values. 
- Enter a value for Default value for the input parameter. Refer to Geoprocessing services data types for the syntax of the default values for supported data types.Note:For the Long data type, the value must be between -9223372036854775808 and 9223372036854775807.Note:For the Double data type, the value must be between -1.7976931348623157e+308 and 1.7976931348623157e+308.
- For Description, enter a description for the input parameter.
- Click Save to save the input parameter.
- To add more input parameters, repeat steps 1 through 9.
- After adding all of your input parameters, select a cell in your notebook for the parameters to be inserted into and click Insert as variables.
- Click Save to save the notebook.
Configure output parameters
You can configure output for a notebook published as a web tool by configuring output parameters from the Parameters pane in the notebook editor.
- In the notebook editor, click Parameters.
- Click Add.
- Select output for the Direction parameter.
- Enter a name for Variable name.Note:This must match a variable name that is in the notebook code or is already configured in the notebook.
- Enter a name for Display name for the web tool parameter.
- From the Data type drop-down menu, select a data type for the output parameter.
- Select Required or Optional for Parameter type.
- Enter a value for Default value for the output parameter. Refer to Geoprocessing services data types for the syntax of the default values for supported data types.Note:For the Long data type, the value must be between -9223372036854775808 and 9223372036854775807.Note:For the Double data type, the value must be between -1.7976931348623157e+308 and 1.7976931348623157e+308.
- For Description, type a description for the output parameter.
- Click Save to save the output parameter.
- Select a cell in your notebook. Click the Add button  to add the Python code snippet  to write the output for the web tool.It is recommended that you select a cell near the bottom of the notebook, below the cells where the outputs are created. 
- Inspect the added code snippet to ensure the output variable names match the output defined in the notebook, and make any additional adjustments to the code snippet.
- Repeat steps 1 through 11 for any additional output parameters.
- Click Save to save the notebook.
Publish a web tool
You can publish a notebook as a web tool from the Publish pane in the notebook editor.
- Save your notebook to ensure the latest copy of the notebook is published.
- Manually run the notebook's cells interactively to ensure that no errors exist.
- Click Publish on the notebook editor ribbon.
- Enter a title and description for the web tool in the Title and Description fields in the Publish pane.
- Specify a number in the Maximum usage time field. This is the number of minutes the web tool can continue running before the system cancels it. The maximum allowed timeout value is 100 minutes. 
- Verify any input and output parameters.
- Click Publish to publish the notebook as a web tool.
- Once the web tool has published successfully, click View details to view the item details page for the web tool.
- Click Share to open the Share window.- Select Organization to share the web tool with all users in your organization.
- Click Edit group sharing to share the web tool with specific groups.
- Select the groups you want to share with.
- Click OK.
- Click Save.
 
Note:
Skip cells that contain the code snippets for the output parameters, as they do not run in interactive mode.Share a web tool
To share or update the sharing settings for an existing notebook web tool with your organization or specific groups in your organization, follow the steps below.
Note:
Users with whom the web tool is shared must have the Run web tools privilege and any additional privileges necessary to run the notebook to be able to run the shared web tool.
You cannot share notebook web tools with the public. Even if you have privileges to share data publicly, the option to share notebook web tools with Everyone (public) is not available.
- Verify that you are signed in to ArcGIS Online and have sufficient privileges to share content with your organization.
- Click Content.
- Check the box next to the title of the web tool you want to share.
- Click Share.- Select Organization to share the web tool with all users in your organization.
- Click Edit group sharing to share the web tool with specific groups.
- Select the groups you want to share with.
- Click OK.
- Click Save.
 
Overwrite a web tool
Overwriting a web tool will update a web tool to use the latest snapshot of that notebook. You can overwrite a notebook web tool in the Publish pane in the notebook editor.
- If an existing input or output parameter needs to be updated, follow the steps in the Edit an existing input or output parameter section of this topic.
- If you are adding new input or output parameters, follow the steps in the Configure input parameters or the Configure output parameters sections of this topic.
- Click Save to ensure that the latest copy of the notebook is published.
- Manually run each cell in the notebook to ensure that no errors exist.Note:Do not run cells that contain the code snippets for the output parameters, as they will not run in interactive mode.
- Click Publish.
- Click Overwrite to overwrite the web tool.
Delete a web tool
You can delete a web tool published from a notebook by deleting the web tool item.
- On the top ribbon of the notebook editor, click Publish.
- Click View details to view the item details page for the web tool.
- Click Settings.
- Click Delete item and confirm that you want to remove the web tool item.
Note:
If the notebook item from which the web tool is published is deleted, the web tool item will also be deleted.
Edit an existing input or output parameter
You can make changes to an existing input or output parameter from the Parameters pane in the notebook editor.
Note:
If a notebook has already been published as a web tool, you must turn on the Enable editing toggle button in the Parameters pane before you can make changes to your parameters. Be cautious when making changes to your parameters after the notebook has been published as a web tool, as these changes can potentially break any web apps using the web tool.
- On the top ribbon of the notebook editor, click Parameters.
- Click the options button next to the parameter and click Edit.
- Update the parameter and click Save.- If an input parameter was updated, manually clear or remove the existing cell with the input variables and repeat the step to insert the input parameters as variables into the notebook.
- If an output parameter was updated, manually clear the code snippet corresponding to the output variable and repeat the steps to add the code snippet for the output parameter to the notebook.
 
- Click Save to save the notebook.
Delete an existing input or output parameter
You can delete existing input or output parameters from the Parameters pane.
- On the top ribbon of the notebook editor, click Parameters.
- Click the options button next to the parameter and click Delete.
- Click delete to permanently remove the parameter.
- Manually clear or remove the input variable or output code snippet in the notebook.
- Click Save to save the notebook.
Use the map extent
When you run a web tool in Map Viewer, if the processing extent and output coordinate system are modified, they will be passed into the notebook as a Python variable named context, along with other input parameters, as seen below.
context = {
    "extent": {
        "ymin": 1759249.9654418486,
        "xmin": 6481923.176042713,
        "ymax": 1795442.256243616,
        "xmax": 6531137.243576055,
        "spatialReference": {"latestWkid": 2229, "wkid": 102645},
    },
    "outSR": {"latestWkid": 4269},
}You can use the value of the context variable to set the extent and output coordinate system of the spatial analysis workflows in your notebook. To test your spatial analysis workflows before publishing the notebook as a web tool, declare the context variable with a default value.
When you are ready to publish, insert the input parameters as variables after the cell where you declare the context variable.