Skip to main content

F5 plugins for Nornir

Project description

nornir_f5

Build Status codecov made-with-python Python Version Code style: black GitHub license

Collection of Nornir plugins to interact with F5 systems and deploy declaratives to F5 Automation Toolchain (ATC) services like AS3, DO, and TS.

Installation

Pip

pip install nornir-f5

Poetry

poetry add nornir-f5

Usage

from nornir import InitNornir
from nornir.core.task import Result, Task
from nornir_utils.plugins.functions import print_result

from nornir_f5.plugins.tasks import (
    atc,
    bigip_cm_config_sync,
    bigip_cm_failover_status,
)

def as3_post(task: Task, as3_tenant: str) -> Result:
    # Get the failover status of the device.
    failover_status = task.run(
        name="Get failover status", task=bigip_cm_failover_status
    ).result

    # If it's the ACTIVE device, send the declaration and perform a sync.
    if failover_status == "ACTIVE":
        task.run(
            name="POST AS3 Declaration from file",
            task=atc,
            atc_method="POST",
            atc_service="AS3",
            as3_tenant=as3_tenant,
            atc_declaration_file=task.host["appsvcs"][as3_tenant][
                "atc_declaration_file"
            ],
        )

        task.run(
            name="Synchronize the devices",
            task=bigip_cm_config_sync,
            device_group=task.host["device_group"],
        )

        return Result(
            host=task.host,
            result="ACTIVE device, AS3 declaration successfully deployed.",
        )
    # Else, do nothing...
    else:
        return Result(host=task.host, result="STANDBY device, skipped.")

nr = InitNornir(config_file="config.yml")
nr = nr.filter(platform="f5_bigip")

result = nr.run(
    name="AS3 POST",
    task=as3_post,
    as3_tenant="Simple_01",
)

print_result(result)

Plugins

Connections

  • f5: Connects to an F5 REST server.

Tasks

  • atc: Deploys ATC declaratives on a BIG-IP/IQ system.
  • atc_info: Returns the version and release information of the ATC service instance.
  • bigip_cm_config_sync: Synchronizes the configuration between BIG-IP systems.
  • bigip_cm_failover_status: Gets the failover status of the BIG-IP system.
  • bigip_cm_sync_status: Gets the configuration synchronization status of the BIG-IP system.
  • bigip_shared_file_transfer_uploads: Uploads a file to a BIG-IP system.
  • bigip_shared_iapp_lx_package: Manages Javascript LX packages on a BIG-IP system.
  • bigip_sys_version: Gets software version information for the BIG-IP system.
  • bigip_util_unix_ls: Lists information about the file(s) or directory content on a BIG-IP system.
  • bigip_util_unix_rm: Deletes a file on a BIG-IP system.

Authors

  • Eric Jacob (@erjac77)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nornir_f5-0.5.1.tar.gz (16.5 kB view details)

Uploaded Source

Built Distribution

nornir_f5-0.5.1-py3-none-any.whl (22.3 kB view details)

Uploaded Python 3

File details

Details for the file nornir_f5-0.5.1.tar.gz.

File metadata

  • Download URL: nornir_f5-0.5.1.tar.gz
  • Upload date:
  • Size: 16.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.0 importlib_metadata/4.8.2 pkginfo/1.8.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for nornir_f5-0.5.1.tar.gz
Algorithm Hash digest
SHA256 eca6d9d7bfa4a580ad9cb6c2e5d5d4fab6cbcb6de599d2e71c36e2e91aadc7f4
MD5 86cb8b5a351b366276bc114be54a3c6e
BLAKE2b-256 ab1aa23b2f4d208ab8b0a0e15ebe94b12f499920221403088dee50f11c718f3b

See more details on using hashes here.

Provenance

File details

Details for the file nornir_f5-0.5.1-py3-none-any.whl.

File metadata

  • Download URL: nornir_f5-0.5.1-py3-none-any.whl
  • Upload date:
  • Size: 22.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.0 importlib_metadata/4.8.2 pkginfo/1.8.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for nornir_f5-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 879830484cc2b690f314ecfd3e60ea2eef1c156a91f3d73fd1b15ad8e421c483
MD5 e0e13271847993eb0488dc589d1a228a
BLAKE2b-256 268fb592fa2300b07c77dc777355da596af6bff33f4db4c2ca74f551641def4c

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page