Settings
Note
If you're unsure about what "Django settings" are, you can refer to How to Edit Django Settings in OpenWISP for guidance.
OPENWISP_FIRMWARE_UPGRADER_RETRY_OPTIONS
| type: | 
 | 
| default: | see below | 
# default value of OPENWISP_FIRMWARE_UPGRADER_RETRY_OPTIONS:
dict(
    max_retries=4,
    retry_backoff=60,
    retry_backoff_max=600,
    retry_jitter=True,
)
Retry settings for recoverable failures during firmware upgrades.
By default if an upgrade operation fails before the firmware is flashed (e.g.: because of a network issue during the upload of the image), the upgrade operation will be retried 4 more times with an exponential random backoff and a maximum delay of 10 minutes.
For more information regarding these settings, consult the celery documentation regarding automatic retries for known errors.
OPENWISP_FIRMWARE_UPGRADER_TASK_TIMEOUT
| type: | 
 | 
| default: | 
 | 
Timeout for the background tasks which perform firmware upgrades.
If for some unexpected reason an upgrade remains stuck for more than 10 minutes, the upgrade operation will be flagged as failed and the task will be killed.
This should not happen, but a global task time out is a best practice when using background tasks because it prevents the situation in which an unexpected bug causes a specific task to hang, which will quickly fill all the available slots in a background queue and prevent other tasks from being executed, which will end up affecting negatively the rest of the application.
OPENWISP_CUSTOM_OPENWRT_IMAGES
| type: | 
 | 
| default: | 
 | 
This setting can be used to extend the list of firmware image types included in OpenWISP Firmware Upgrader. This setting is suited to add support for custom OpenWrt images.
OPENWISP_CUSTOM_OPENWRT_IMAGES = (
    (
        # Firmware image file name.
        "customimage-squashfs-sysupgrade.bin",
        {
            # Human readable name of the model which is displayed on
            # the UI
            "label": "Custom WAP-1200",
            # Tuple of board names with which the different versions of
            # the hardware are identified on OpenWrt
            "boards": ("CWAP1200",),
        },
    ),
)
Kindly read Automatic Device Firmware Detection section of this documentation to know how OpenWISP Firmware Upgrader uses this setting in upgrades.
OPENWISP_FIRMWARE_UPGRADER_MAX_FILE_SIZE
| type: | 
 | 
| default: | 
 | 
This setting can be used to set the maximum size limit for firmware images, e.g.:
OPENWISP_FIRMWARE_UPGRADER_MAX_FILE_SIZE = 40 * 1024 * 1024  # 40MB
Notes:
- Value must be specified in bytes. - Nonemeans unlimited.
OPENWISP_FIRMWARE_UPGRADER_API
| type: | 
 | 
| default: | 
 | 
Indicates whether the API for Firmware Upgrader is enabled or not.
OPENWISP_FIRMWARE_UPGRADER_OPENWRT_SETTINGS
| type: | 
 | 
| default: | 
 | 
Allows changing the default OpenWrt upgrader settings, e.g.:
OPENWISP_FIRMWARE_UPGRADER_OPENWRT_SETTINGS = {
    "reconnect_delay": 180,
    "reconnect_retry_delay": 20,
    "reconnect_max_retries": 35,
    "upgrade_timeout": 90,
}
- reconnect_delay: amount of seconds to wait before trying to connect again to the device after the upgrade command has been launched; the re-connection step is necessary to verify the upgrade has completed successfully; defaults to- 120seconds
- reconnect_retry_delay: amount of seconds to wait after a re-connection attempt has failed; defaults to- 20seconds
- reconnect_max_retries: maximum re-connection attempts defaults to- 15attempts
- upgrade_timeout: amount of seconds before the shell session is closed after the upgrade command is launched on the device, useful in case the upgrade command hangs (it happens on older OpenWrt versions); defaults to- 90seconds
OPENWISP_FIRMWARE_API_BASEURL
| type: | 
 | 
| default: | 
 | 
If you have a separate instance of OpenWISP Firmware Upgrader API on a
different domain, you can use this option to change the base of the image
download URL, this will enable you to point to your API server's domain,
e.g.: https://api.myservice.com.
OPENWISP_FIRMWARE_UPGRADERS_MAP
| type: | 
 | 
| default: |  | 
A dictionary that maps update strategies to upgraders.
If you want to use a custom update strategy you will need to use this setting to provide an entry with the class path of your update strategy as the key.
If you need to use a custom upgrader class you will need to use this setting to provide an entry with the class path of your upgrader as the value.
OPENWISP_FIRMWARE_PRIVATE_STORAGE_INSTANCE
| type: | 
 | 
| default: | 
 | 
Dotted path to an instance of any one of the storage classes in private_storage. This instance is used to store firmware image files.
By default, an instance of
private_storage.storage.files.PrivateFileSystemStorage is used.