Air-sdk

Latest version: v2.16.0

Safety actively analyzes 681775 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 6 of 8

2.0.1

Fixed
- `AirApi.simulations.duplicate()` was incorrectly treating a JSON object as a HTTP response (!2, thanks taka.mura!)
- `AirApi.simulations.duplicate()` did not work when passing in a `Simulation` object (2)

2.0.0

This version introduces a number of **BREKAING** changes from 1.x.x versions. Please read the following carefully.
Added
- Account API
- Demo API
- Image API
- Interface API
- Job API
- Link API
- Login API
- Organization API
- SSHKey API
- `SimulationNode.create_instructions()`, `SimulationNode.list_instructions()`, and `SimulationNode.delete_instructions()`
- `SimulationNode.control()` and related methods
- All `get()` and `list()` methods now support optional kwargs that are applied as filters to the `GET` request
- All objects now support a `refresh()` method to sync local instances with the API
- AirApi objects now have a `username` attribute when authorized:

air = AirApi(bearer_token='foo')
air.username
mrobertsonnvidia.com

Changed
- Instantiating an AirApi instance now requires a username/password or (pre-generated) bearer token

v1
air = AirApi()

v2
air = AirApi(username='foo', password='bar')
or
air = AirApi(bearer_token='foo')

- AirApi instances are now automatically authorized on creation. It is no longer required to call `AirApi.authorize()` separately.

v1
air = AirApi()
air.authorize(username='foo', password='bar')

v2
air = AirApi(username='foo', password='bar')

- Updating a local object property now immediately makes a `PATCH` call to update the remote object as well. Multiple properties can still be updated via a `PUT` call with the object's `update()` method.

v1
only updates the local object, no API calls are made
simulation.title = 'new title'
updates the remote object with a PUT call
simulation.update(title='new title', name='mrobertsonnvidia.com')

v2
immediately updates the remote object with a PATCH call
simulation.title = 'new title'
updates the remote object with a PUT call
simulation.update(title='new title', name='mrobertsonnvidia.com')

*Note:* If multiple properties need to be updated, it is recommended to make a single call to `update()` for efficiency's sake:

DO
simulation.update(title='new title', name='mrobertsonnvidia.com') PUT 1

DON'T
simulation.title = 'new title' PATCH 1
simulation.name = 'mrobertsonnvidia.com' PATCH 2

- The following deprecated methods no longer return a tuple of the created object and the `POST` response JSON. Instead, use `new_object.__dict__` or `new_object.json()`.
- `PermissionApi.create_permission()`
- `ServiceApi.create_service()`
- `SimulationApi.create_simulation()`
- `TopologyApi.create_topology()`

v1
simulation, payload = air.simulation.create_simulation(topology=topology_id)

v2
simulation = air.simulations.create(topology=topology)
simulation.__dict__
simulation.json()

- The following deprecated methods no longer return a list of dicts. Instead, they return a list of AIR objects.
- `NodeApi.get_nodes()`
- `ServiceApi.get_services()`
- `SimulationApi.get_simulations()`
- `SimulationInterfaceApi.get_simulation_interfaces()`
- `SimulationNodeApi.get_simulation_nodes()`
- `TopologyApi.get_topologies()`

v1
air.simulation.get_simulations()
[{...}, ...]

v2
air.simulations.list()
[<Simulation>, ...]

- The following methods now return the created `Permission` object (previously they returned `None`)
- `Simulation.add_permission()`
- `Topology.add_permission()`
- Any method arguments that represent an AIR object will now accept an instance of that object or its `id` as a string
- All methods that make API calls should now raise `AirUnexpectedResponse` if any non-success response is received
- All methods that make API calls should now raise `AirUnexpectedResponse` if any unexpected response format is received
Deprecated
- The following methods have been deprecated in favor of a more standard naming convention. These methods will still work in this release (logging a deprecation warning) but will be removed in a future release.
- `CapacityApi.get_capacity()` is now `CapacityApi.get()`
- `NodeApi.get_nodes()` is now `NodeApi.list()`
- `PermissionApi.create_permission()` is now `PermissionApi.create()`
- `ServiceApi.create_service()` is now `ServiceApi.create()`
- `ServiceApi.get_services()` is now `ServiceApi.list()`
- `ServiceApi.get_service()` is now `ServiceApi.get()`
- `SimulationApi.control()` is now `Simulation.control()`
- `SimulationApi.create_simulation()` is now `SimulationApi.create()`
- `SimulationApi.get_simulations()` is now `SimulationApi.list()`
- `SimulationApi.get_simulation()` is now `SimulationApi.get()`
- `SimulationApi.update_simulation()` is now `Simulation.update()`
- `SimulationInterfaceApi.get_simulation_interfaces()` is now `SimulationInterfaceApi.list()`
- `SimulationNodeApi.get_simulation_nodes()` is now `SimulationNodeApi.list()`
- `SimulationNodeApi.update_simulation_node()` is now `SimulationNode.update()`
- `TopologyApi.create_topology()` is now `TopologyApi.create()`
- `TopologyApi.get_topologies()` is now `TopologyApi.list()`
- `TopologyApi.update_topology()` is now `Topology.update()`
- `WorkerApi.get_workers()` is now `WorkerApi.list()`
- `Worker.set_available()` is now `worker.available = <True|False>`
- `WorkerApi.update_worker()` is now `Worker.update()`

v1
air.simulation.get_simulations()

v2
air.simulations.list()

- The following properties have been deprecated in favor of a more standard naming convention. These properties will still be available this release (logging a deprecation warning) but will be removed in a future release.
- `AirApi.node` is now `AirApi.nodes`
- `AirApi.permission` is now `AirApi.permissions`
- `AirApi.service` is now `AirApi.services`
- `AirApi.simulation` is now `AirApi.simulations`
- `AirApi.simulation_interface` is now `AirApi.simulation_interfaces`
- `AirApi.simulation_node` is now `AirApi.simulation_nodes`
- `AirApi.topology` is now `AirApi.topologies`
- `AirApi.worker` is now `AirApi.workers`

v1
air.simulation

v2
air.simulations

1.3.3

Added
- 403 responses now raise AirForbiddenError

1.3.2

Added
- `host` key to Service

1.3.1

Fixed
- Malformed request payload when using `worker.update_worker()`

1.3.0

Added
- Capacity API
- Worker API
- `SimulationApi.get_citc_simulation()`

Page 6 of 8

© 2024 Safety CLI Cybersecurity Inc. All Rights Reserved.