Metadata-Version: 2.1
Name: visionai
Version: 0.1.3
Summary: Vision AI toolkit
Author: Harsh Murari
Author-email: hmurari@visionify.ai
Requires-Python: >=3.7,<4.0
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Requires-Dist: pytest (>=7.2.1,<8.0.0)
Requires-Dist: requests (>=2.28.2,<3.0.0)
Requires-Dist: typer[all] (>=0.7.0,<0.8.0)
Description-Content-Type: text/markdown

# edgectl

Edge device, cameras & scenarios controller.

## Overview

1. Start the server instance

```bash
make server.install
make server.start
```

1. Run this utility through docker:

```bash
make cli.install
make cli.start

# Run python edgectl.py utility from within container
python3 edgectl.py --get-cameras
```

1. OR Run CLI from host machine

```bash
# Run python edgectl.py utility from host machine
python3 edgectl.py --get-cameras
```

## Commands

The following set of commands are supported.

- TODO: Instead of using IoT Hub connection string - support it via an API key that is generated from our website.
- TODO: Make edgectl into its own repo (public). Create nice documentation on how this can be used in Gitbooks.
- TODO: Connection string to API key translation through Azure Keyvault

After the edgectl configured, we can run the following commands.

```bash
# Configure edgectl
python3 edgectl.py --setup --api-key <api-key>

#  Run edgectl utility
python3 edgectl.py \
    # Device
    --list-devices                          # list devices
    --use-device <device-id>                # set default device to use
    --list-modules                          # list running modules status
    --gpu-stats                             # get device's GPU stats
    --mem-stats                             # get device's memory stats
    --scenarios-health                      # how many more scenarios can run

    # Scenarios
    --list-all-scenarios                    # list all available scenarios
    --list-scenarios                        # list running scenarios for a camera
        --camera <camera-name>
    --start-scenario <scenario-name>        # start a scenario for a camera
        --camera <camera-name>
    --stop-scenario <scenario-name>         # stop a scenario for a camera
        --camera <camera-name>

    # Cameras
    --list-cameras                          # list cameras
    --add-camera <camera-name>              # add a camera
        --camera-uri <camera-uri>
    --remove-camera <camera-name>           # remove camera

    # Livestream
    --start-livestream <camera-name>        # start live-stream for camera
    --stop-livestream <camera-name>         # stop live-stream for camera

    # Events
    --list-events                           # list supported events
        --scenario  <scenario-name>

    --event-details                         # list details for an event
        --scenario <scenario-name>
        --event <event-name>

    --event-log                             # list last few events from camera
        --camera <camera-name>
        --last <duration-seconds>

    # Simulation
    --simulate-event                        # simulate generating an event
        --camera <camera-name>
        --scenario <scenario-name>
        --event <event-name>
        --event-data <event-data>

```

