Deployment

Table of contents

Deploy ACAP application

Given you only have one Axis device, deploying an ACAP application is pretty straightforward. You navigate to the device using a web browser and install and start the application in the Apps section utilizing the device’s web pages. What about deploying the application to ten devices or even 1000? At some point, depending on your mileage, this becomes a significant problem. For information on how to deploy applications to a more substantial number of Axis devices, the following chapters guide you toward a few alternative options.

Deploy ACAP application using AXIS Device Manager

AXIS Device Manager is a Windows application tailored toward device management in large installations. Follow these steps to deploy an ACAP application to many Axis devices:

  1. In AXIS Device Manager select the devices.
  2. Right-click any of the selected devices and select Install Camera Application… in the context menu.
  3. Browse and select the ACAP application to install.
  4. Select whether to install the licenses.
  5. Click Finish to complete the wizard.
  6. A task is created showcasing the progress and its outcome.

Deploy ACAP application using PowerShell

The following alternative uses PowerShell to deploy an ACAP application to many Axis devices, each with its IP address, username, and password. PowerShell is available on Windows, macOS, and many Linux distributions. Make sure to use PowerShell 7 or higher. To determine the version of PowerShell you are using, run the $PSVersionTable command on a PowerShell prompt. See Install PowerShell on Windows, Linux, and macOS on how to install or upgrade PowerShell on your computer.

First, create a file named deploy.ps1 and add the following content:

<#
  .PARAMETER Devices
  The filename containing the devices. The file should contain comma-separated
  values (CSV) where each line represents a device and contains the IP address,
  the username, and the password.
 
  Example:
 
  192.168.1.90,root,pass1
  192.168.1.91,root,pass2
 
  .PARAMETER App
  The filename of the ACAP application to be installed.
 
  .PARAMETER AppName
  The name of the ACAP application, as defined by its package configuration or
  manifest.
#>
param (
    [Parameter(Mandatory)] [string] $Devices,
    [Parameter(Mandatory)] [string] $App,
    [Parameter(Mandatory)] [string] $AppName
)
 
foreach ($device in Import-Csv -Path $Devices -Header "IP", "Username", "Password")
{
    $ip = $device.IP
    $username = $device.Username
    $password = $device.Password | ConvertTo-SecureString -AsPlainText -Force
    $credential = New-Object PSCredential -ArgumentList $username, $password
    $content = Get-Item $app
 
    Write-Host $ip
    Write-Host -NoNewline "  Install: "
    Write-Host -NoNewline $(Invoke-RestMethod -Credential $credential `
        -AllowUnencryptedAuthentication `
        -Method Post `
        -Uri "http://$ip/axis-cgi/applications/upload.cgi" `
        -ContentType "multipart/form-data" `
        -Form @{ file = $content })
    Write-Host -NoNewline "  Start:   "
    Write-Host -NoNewline $(Invoke-RestMethod -Credential $credential `
        -AllowUnencryptedAuthentication `
        -Method Post `
        -Uri "http://$ip/axis-cgi/applications/control.cgi?package=$AppName&action=start")
}

Now create a file named devices.csv describing the devices on which you want to deploy the ACAP application. The file should contain the device IP addresses, usernames, and passwords, formatted using comma-separated values (CSV). The following example file describes ten devices:

192.168.1.90,root,pass1
192.168.1.91,root,pass2
192.168.1.92,root,pass3
192.168.1.93,root,pass4
192.168.1.94,root,pass5
192.168.1.95,root,pass6
192.168.1.96,root,pass7
192.168.1.97,root,pass8
192.168.1.98,root,pass9
192.168.1.99,root,pass10

The final piece to the puzzle is the actual ACAP application and its name, as defined by the package configuration or the manifest. Let’s assume that the app is called my_app.eap and is located in the same directory as deploy.ps1 and devices.csv. Regarding the application name, there is no good way to get hold of this other than to install the ACAP application on a device and view the URL of its logs. Please use the following steps to get the name of the ACAP application:

  1. Install the ACAP application on an Axis device using its web pages.
  2. When installed, view the logs either by selecting the App log link or the context menu (three vertical dots), depending on your version of the device interface.
  3. Once the logs are shown, take note of the URL. In the URL http://192.168.1.90/axis-cgi/admin/systemlog.cgi?appname=my_app, the name of the application would be my_app.

With the ACAP application file and the application name, let’s run the script that deploys the ACAP application on all devices.

.\deploy.ps1 -Devices devices.csv -App my_app.eap -AppName my_app

Executing the command produces the following output describing a successful result.

192.168.1.90
  Install: OK
  Start:   OK
192.168.1.91
  Install: OK
  Start:   OK
192.168.1.92
  Install: OK
  Start:   OK
192.168.1.93
  Install: OK
  Start:   OK
192.168.1.94
  Install: OK
  Start:   OK
192.168.1.95
  Install: OK
  Start:   OK
192.168.1.96
  Install: OK
  Start:   OK
192.168.1.97
  Install: OK
  Start:   OK
192.168.1.98
  Install: OK
  Start:   OK
192.168.1.99
  Install: OK
  Start:   OK

Deploy ACAP application using Bash

The following alternative uses Bash and curl to deploy an ACAP application to many Axis devices, each with their IP address, username, and password. Bash is available natively on Linux and macOS and can be accessed on Windows by installing Windows Subsystem for Linux (WSL).

First, create a file named deploy.sh and add the following content:

#!/bin/bash
set -e
 
if [[ $# -ne 3 ]]; then
  echo "Error: Unsupported number of arguments"
  echo
  echo "USAGE:"
  echo "    install.sh <devices> <app> <app name>"
  echo
  echo "WHERE:"
  echo "    devices     The filename containing the devices. The file should contain comma-separated"
  echo "                values (CSV) where each line represents a device and contains the IP address,"
  echo "                the username, and the password."
  echo
  echo "                Example:"
  echo
  echo "                192.168.1.90,root,pass1"
  echo "                192.168.1.91,root,pass2"
  echo "    app         The filename of the ACAP application to be installed."
  echo "    app name    The name of the ACAP application, as defined by its package configuration or"
  echo "                manifest."
  exit 1
fi
 
devices=$1
app=$2
app_name=$3
 
while IFS="," read ip username password
do
  echo "$ip"
  echo -n "  Install: "
  curl --anyauth -u "$username:$password" -F packfil=@"$app" "http://$ip/axis-cgi/applications/upload.cgi"
  echo -n "  Start:   "
  curl --anyauth -u "$username:$password" "http://$ip/axis-cgi/applications/control.cgi?package=$app_name&action=start"
 
done < "$devices"

Mark the file as an executable:

chmod +x ./deploy.sh

Now create a file named devices.csv describing the devices on which you want to deploy the ACAP application. The file should contain the device IP addresses, usernames, and passwords, formatted using comma-separated values (CSV). The following file would describe ten devices:

192.168.1.90,root,pass1
192.168.1.91,root,pass2
192.168.1.92,root,pass3
192.168.1.93,root,pass4
192.168.1.94,root,pass5
192.168.1.95,root,pass6
192.168.1.96,root,pass7
192.168.1.97,root,pass8
192.168.1.98,root,pass9
192.168.1.99,root,pass10

The final piece to the puzzle is the actual ACAP application and its name, as defined by the package configuration or the manifest. Let’s assume that the app is called my_app.eap and is located in the same directory as deploy.sh and devices.csv. Regarding the application name, there is no good way to get hold of this other than to install the ACAP application on a device and view the URL of its logs. Please use the following steps to get the name of the ACAP application:

  1. Install the ACAP application on an Axis device using its web pages.
  2. When installed, view the logs either by selecting the App log link or the context menu (three vertical dots), depending on your version of the device interface.
  3. Once the logs are shown, take note of the URL. In the URL http://192.168.1.90/axis-cgi/admin/systemlog.cgi?appname=my_app, the name of the application would be my_app.

With the ACAP application file and the application name, let’s run the script that deploys the ACAP application on all devices.

./deploy.sh devices.csv my_app.eap my_app

Executing the command would produce the following output describing a successful result.

192.168.1.90
  Install: OK
  Start:   OK
192.168.1.91
  Install: OK
  Start:   OK
192.168.1.92
  Install: OK
  Start:   OK
192.168.1.93
  Install: OK
  Start:   OK
192.168.1.94
  Install: OK
  Start:   OK
192.168.1.95
  Install: OK
  Start:   OK
192.168.1.96
  Install: OK
  Start:   OK
192.168.1.97
  Install: OK
  Start:   OK
192.168.1.98
  Install: OK
  Start:   OK
192.168.1.99
  Install: OK
  Start:   OK

Deploy ACAP application using a programming language

There are only three things to consider when deploying an ACAP application using Python, NodeJS, or any other programming language:

  • Authentication - Axis devices use digest access authentication. All HTTP requests sent to the device must use this authentication protocol.
  • Uploading the ACAP application - Use the upload.cgi to upload the application. The CGI is also used when updating an existing application, see the VAPIX documentation for more information.
  • Starting the ACAP application - Use the control.cgi to start the application. The CGI is also used when stopping the application, see the VAPIX documentation for more information.

Back to top

© Axis Communications AB. All rights reserved. AXIS COMMUNICATIONS, AXIS, ARTPEC and VAPIX are registered trademarks of Axis AB in various jurisdictions, and you are not granted any license to use them. All other trademarks are the property of their respective owners.