Metadata-Version: 2.1
Name: manageritm
Version: 0.3.0
Summary: Manage processes via an HTTP based API
Home-page: http://github.com/dskard/manageritm
License: MIT
Author: dskard
Requires-Python: >=3.9,<4.0
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Requires-Dist: flask (>=2.2.5,<3.0.0)
Requires-Dist: jsonschema (>=4.18.6,<5.0.0)
Requires-Dist: mitmproxy (>=9.0.1,<10.0.0)
Requires-Dist: requests (>=2.27.1,<3.0.0)
Requires-Dist: urllib3 (>=1.26.16,<2.0.0)
Project-URL: Repository, http://github.com/dskard/manageritm
Description-Content-Type: text/markdown

# manageritm

Manage a mitmproxy service on another system over a RESTful API

## Getting Started

1. Install manageritm.
   ```python
   pip install manageritm gunicorn
   ```
2. Start manageritm server on port 8000.
   ```python
   gunicorn --bind 0.0.0.0:8000 --workers 1 --log-level debug "manageritm.app:main()"
   ```
3. In Python, create a client, start the mitmproxy service, stop the mitmproxy service
   ```python

   import manageritm

   manageritm_addr = "localhost"
   manageritm_port = "8000"

   # create a manageritm client
   mc = manageritm.client.ManagerITMProxyClient(f'http://{manageritm_addr}:{manageritm_port}')
   proxy_details = mc.client()

   print(f"proxy port: {proxy_details['port']}")
   print(f"proxy webport: {proxy_details['webport']}")

   # start a proxy server
   mc.start()

   # set your application to use the proxy
   #  host: "localhost"
   #  port: f"{proxy_details['port']}"

   # do some work...

   # stop the proxy server
   mc.stop()
   ```

Or start a video client

1. Create a custom configuration file named `flask_config_video.py`
  ```bash
  MANAGERITM_CLIENT_COMMAND = ['/opt/bin/video.sh']
  ```

2. Start manageritm server on port 8000.
   ```python
   gunicorn --bind 0.0.0.0:8000 --workers 1 --log-level debug "manageritm.app:main()"
   ```

3. In Python, create a client, start the ffmpeg service, stop the ffmpeg service
   ```python

   import manageritm

   manageritm_addr = "localhost"
   manageritm_port = "8000"

   # create a manageritm client
   mc = manageritm.client.ManagerITMCommandClient(f'http://{manageritm_addr}:{manageritm_port}')
   client_details = mc.client(additional_env={
       'DISPLAY_CONTAINER_NAME': 'hanet_chrome_1',
       'DISPLAY_NUM': '99',
       'SE_VIDEO_FOLDER': '/videos',
       'FILE_NAME': 'blahh.mp4'
   })

   # start a proxy server
   mc.start()

   # recording should happening
   # ...

   # stop the proxy server
   mc.stop()
   ```

## Local Development

1. Check out this repository
2. Create a virtual environment
   ```bash
   make pyenv
   ```
3. Install Python dependencies
   ```bash
   make install
   ```
4. Start the server
   ```bash
   make server
   ```
5. Start a client, in a Python interpreter:
   ```python

   import manageritm

   manageritm_addr = "localhost"
   manageritm_port = "8000"

   # create a manageritm client
   mc = manageritm.client.ManagerITMProxyClient(f'http://{manageritm_addr}:{manageritm_port}')
   proxy_details = mc.client()

   print(f"proxy port: {proxy_details['port']}")
   print(f"proxy webport: {proxy_details['webport']}")

   # start a proxy server
   mc.start()
   ```
6. Navigate a web browser to `http://localhost:<proxy webport>` to watch the traffic
7. Configure a web browser to use the proxy port.
8. Stop the client
   ```python
   # stop the proxy server
   mc.stop()
   ```

### Helpful Commands

To build a package for the development version:
```python
make all
```

To install a copy into your local python virtualenv
```python
make install
```

To run the test cases:
```python
make test
```

To run the development version of the service:
```python
make run
```

