<div align="center">
<img height="250px" src="https://github.com/yuvalherziger/tomodo/raw/main/tomodo-nopg.png" alt="tomodo logo"></img>
![Latest Release](https://img.shields.io/github/v/release/yuvalherziger/tomodo?display_name=release&style=flat&color=%2332c955)
![Unit Tests](https://github.com/yuvalherziger/tomodo/actions/workflows/unit-tests.yml/badge.svg)
[![codecov](https://codecov.io/gh/yuvalherziger/tomodo/graph/badge.svg?token=3CE8D8NAAY)](https://codecov.io/gh/yuvalherziger/tomodo)
![Python Version](https://img.shields.io/pypi/pyversions/tomodo)
![License](https://img.shields.io/github/license/yuvalherziger/tomodo)
</div>
# tomodo
**tomodo** is a Toolbox for MongoDB on Docker.
-------
Use it to create and manage Docker-based MongoDB community deployments - standalone instances, replica sets, sharded clusters, and local Atlas deployments.
* [Installation](#installation)
+ [Install with Homebrew](#install-with-homebrew)
+ [Install with pip](#install-with-pip)
+ [Install from Source](#install-from-source)
- [Install with Poetry Package Manager for Python](#install-with-poetry-package-manager-for-python)
- [Install from source with pip](#install-from-source-with-pip)
* [CLI Usage](#cli-usage)
+ [Create a Deployment](#create-a-deployment)
+ [Describe Deployments](#describe-deployments)
+ [List Deployments](#list-deployments)
+ [Stop Deployments](#stop-deployments)
+ [Start Deployments](#start-deployments)
+ [Remove Deployments](#remove-deployments)
+ [List Image Tags](#list-tags)
* [Programmatic Usage](#programmatic-usage)
* [Disclaimer](#disclaimer)
---
## Installation
### Install with Homebrew
[Homebrew](https://brew.sh/) is a popular package manager for macOS. You can install tomodo by
running the following commands:
```shell
brew tap yuvalherziger/homebrew-tomodo
brew install tomodo
```
After installing the tool with `brew`, you can run it the following way:
```bash
tomodo --help
```
### Install with pip
To install with `pip`, run the following command:
```shell
pip install tomodo
```
### Install from Source
If you wish to set up a development environment, or if you simply can't use Homebrew or aren't a macOS user,
you can install tomodo using Python. The recommended way to perform the Python installation is by using the
[Poetry](https://python-poetry.org/) Python package manager.
**Requirements:**
* Python 3.8 or higher
#### Install with Poetry Package Manager for Python
If you have the [Poetry](https://python-poetry.org/) Python package manager installed locally, you can install
the CLI the following way:
```bash
git clone https://github.com/yuvalherziger/tomodo.git
cd tomodo
poetry shell
poetry install
```
After installing the tool with Poetry, you can run it the following way:
```bash
tomodo --help
```
#### Install from source with pip
You can install the dependencies with pip using the following command:
```bash
git clone https://github.com/yuvalherziger/tomodo.git
cd tomodo
pip install .
```
After installing the dependencies with pip, you can validate the installation by invoking the help page:
```bash
python tomodo/cmd.py --help
```
## CLI Usage
Before you begin, make sure you have a Docker daemon running. The most popular platform
is [Docker Desktop](https://www.docker.com/products/docker-desktop/).
### Create a Deployment
Create a deployment with the `provision` command. For example, here's how you create a standalone
instance with zero configuration:
```shell
tomodo provision standalone
```
To create a replica set with zero configuration, run the following command:
```shell
tomodo provision replica-set
```
To create a sharded cluster with zero configuration, run the following command:
```shell
tomodo provision sharded
```
To create a local Atlas deployment (a single-node replica set) with zero configuration, run the following command:
```shell
tomodo provision atlas
```
Take a look at each `provision` command's help page to read the full set of options
with `tomodo provision --help`.
```
Usage: tomodo provision [OPTIONS] COMMAND [ARGS]...
Provision a MongoDB deployment
╭─ Options ──────────────────────────────────────────────────────────────╮
│ --help Show this message and exit. │
╰────────────────────────────────────────────────────────────────────────╯
╭─ Commands ─────────────────────────────────────────────────────────────╮
│ atlas Provision a local MongoDB Atlas deployment │
│ replica-set Provision a MongoDB replica set deployment │
│ sharded Provision a MongoDB sharded cluster │
│ standalone Provision a standalone MongoDB deployment │
╰────────────────────────────────────────────────────────────────────────╯
```
### Describe Deployments
Use the `describe` command to print the details of one or all deployments:
```shell
# Describe all deployments
tomodo describe
# Describe a deployment by name
tomodo describe --name yawning-mole
# Describe only running deployments
tomodo describe --exclude-stopped
```
### List Deployments
Use the `list` command to list your deployments:
```shell
# List all deployments
tomodo list
# List only running deployments
tomodo list --exclude-stopped
```
### Stop Deployments
Use the `stop` command to stop your deployments:
```shell
# Stop all deployments
tomodo stop
# Stop a deployment by name
tomodo stop --name troubled-narwhal
# Stop all deployments without prompting for confirmation
tomodo stop --auto-approve
```
### Start Deployments
Use the `start` command to start a deployment you previously stopped:
```shell
tomodo start --name printed-lemming
```
### Remove Deployments
Use the `remove` command to permanently remove deployments:
```shell
# Remove all deployments
tomodo remove
# Remove a deployment by name
tomodo remove --name troubled-narwhal
# Remove all deployments without prompting for confirmation
tomodo remove --auto-approve
```
### List Tags
Use the `tags list` command to list the available image tags on Docker Hub.
```shell
tomodo tags list --version 7
```
Sample output:
```
7.0.6
7.0.6-jammy
7.0.6-nanoserver
7.0.6-nanoserver-1809
7.0.6-nanoserver-ltsc2022
7.0.6-windowsservercore
7.0.6-windowsservercore-1809
7.0.6-windowsservercore-ltsc2022
7.0.5
7.0.5-jammy
7.0.5-nanoserver
7.0.5-nanoserver-1809
7.0.5-nanoserver-ltsc2022
7.0.5-windowsservercore
7.0.5-windowsservercore-1809
7.0.5-windowsservercore-ltsc2022
7.0.4
7.0.4-jammy
7.0.4-nanoserver
7.0.4-nanoserver-1809
7.0.4-nanoserver-ltsc2022
7.0.4-windowsservercore
7.0.4-windowsservercore-1809
7.0.4-windowsservercore-ltsc2022
7.0.3
7.0.3-jammy
7.0.3-nanoserver
7.0.3-nanoserver-1809
7.0.3-nanoserver-ltsc2022
7.0.3-windowsservercore
7.0.3-windowsservercore-1809
7.0.3-windowsservercore-ltsc2022
7.0.2
7.0.2-jammy
7.0.2-nanoserver
7.0.2-nanoserver-1809
7.0.2-nanoserver-ltsc2022
7.0.2-windowsservercore
7.0.2-windowsservercore-1809
7.0.2-windowsservercore-ltsc2022
```
## Programmatic Usage
You can install tomodo in your Python (>=3.8) projects using `pip` or any other Python package manager, and use it
programmatically (you'll still need a Docker daemon running).
```python
from typing import Dict
from tomodo import functional as tfunc
from tomodo.common.errors import DeploymentNotFound
from tomodo.common.models import AtlasDeployment, Deployment, Mongod, ReplicaSet, ShardedCluster
# Create a standalone instance:
mongod: Mongod = tfunc.provision_standalone_instance(port=1000)
# Create an Atlas instance:
atlas_depl: AtlasDeployment = tfunc.provision_atlas_instance(port=2000)
# Create a replica set:
replica_set: ReplicaSet = tfunc.provision_replica_set(port=3000, replicas=3)
# Create a sharded cluster:
sh_cluster: ShardedCluster = tfunc.provision_sharded_cluster(port=4000, shards=2, config_servers=3, mongos=2)
# Stop a deployment:
mongod.stop()
# Start a stopped deployment:
mongod.start()
# Remove a deployment permanently:
mongod.remove()
# Find a deployment by name
try:
deployment = tfunc.get_deployment(name="elegant-leopard", include_stopped=True)
except DeploymentNotFound:
print("Deployment not found")
# List all deployments:
deployments: Dict = tfunc.list_deployments(include_stopped=True)
for name in deployments.keys():
deployment: Deployment = deployments[name]
print(f"Deployment {name} is {deployment.last_known_state}")
```
## Disclaimer
This software is not supported by MongoDB, Inc. under any of their commercial support subscriptions or otherwise.
Any usage of tomodo is at your own risk. Bug reports, feature requests, and questions can be posted in the
[Issues section](https://github.com/yuvalherziger/tomodo/issues) of this repository.
Raw data
{
"_id": null,
"home_page": "https://tomodo.dev",
"name": "tomodo",
"maintainer": null,
"docs_url": null,
"requires_python": "<3.13,>=3.8",
"maintainer_email": null,
"keywords": "mongodb, docker, upgrade, python, cli",
"author": "Yuval Herziger",
"author_email": "yuvalhrz@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/7d/40/019b0bea2d4916130ff012159551f0ed2ad137856a4dec6bcf270d20f604/tomodo-1.3.1.tar.gz",
"platform": null,
"description": "<div align=\"center\">\n <img height=\"250px\" src=\"https://github.com/yuvalherziger/tomodo/raw/main/tomodo-nopg.png\" alt=\"tomodo logo\"></img>\n\n![Latest Release](https://img.shields.io/github/v/release/yuvalherziger/tomodo?display_name=release&style=flat&color=%2332c955)\n![Unit Tests](https://github.com/yuvalherziger/tomodo/actions/workflows/unit-tests.yml/badge.svg)\n[![codecov](https://codecov.io/gh/yuvalherziger/tomodo/graph/badge.svg?token=3CE8D8NAAY)](https://codecov.io/gh/yuvalherziger/tomodo)\n![Python Version](https://img.shields.io/pypi/pyversions/tomodo)\n![License](https://img.shields.io/github/license/yuvalherziger/tomodo)\n\n</div>\n\n# tomodo\n\n**tomodo** is a Toolbox for MongoDB on Docker.\n\n-------\n\nUse it to create and manage Docker-based MongoDB community deployments - standalone instances, replica sets, sharded clusters, and local Atlas deployments.\n\n* [Installation](#installation)\n + [Install with Homebrew](#install-with-homebrew)\n + [Install with pip](#install-with-pip)\n + [Install from Source](#install-from-source)\n - [Install with Poetry Package Manager for Python](#install-with-poetry-package-manager-for-python)\n - [Install from source with pip](#install-from-source-with-pip)\n* [CLI Usage](#cli-usage)\n + [Create a Deployment](#create-a-deployment)\n + [Describe Deployments](#describe-deployments)\n + [List Deployments](#list-deployments)\n + [Stop Deployments](#stop-deployments)\n + [Start Deployments](#start-deployments)\n + [Remove Deployments](#remove-deployments)\n + [List Image Tags](#list-tags)\n* [Programmatic Usage](#programmatic-usage)\n* [Disclaimer](#disclaimer)\n\n--- \n\n## Installation\n\n### Install with Homebrew\n\n[Homebrew](https://brew.sh/) is a popular package manager for macOS. You can install tomodo by\nrunning the following commands:\n\n```shell\nbrew tap yuvalherziger/homebrew-tomodo\nbrew install tomodo\n```\n\nAfter installing the tool with `brew`, you can run it the following way:\n\n```bash\ntomodo --help\n```\n\n### Install with pip\n\nTo install with `pip`, run the following command:\n\n```shell\npip install tomodo\n```\n\n### Install from Source\n\nIf you wish to set up a development environment, or if you simply can't use Homebrew or aren't a macOS user,\nyou can install tomodo using Python. The recommended way to perform the Python installation is by using the\n[Poetry](https://python-poetry.org/) Python package manager.\n\n**Requirements:**\n\n* Python 3.8 or higher\n\n#### Install with Poetry Package Manager for Python\n\nIf you have the [Poetry](https://python-poetry.org/) Python package manager installed locally, you can install\nthe CLI the following way:\n\n```bash\ngit clone https://github.com/yuvalherziger/tomodo.git\ncd tomodo\npoetry shell\npoetry install\n```\n\nAfter installing the tool with Poetry, you can run it the following way:\n\n```bash\ntomodo --help\n```\n\n#### Install from source with pip\n\nYou can install the dependencies with pip using the following command:\n\n```bash\ngit clone https://github.com/yuvalherziger/tomodo.git\ncd tomodo\npip install .\n```\n\nAfter installing the dependencies with pip, you can validate the installation by invoking the help page:\n\n```bash\npython tomodo/cmd.py --help\n```\n\n## CLI Usage\n\nBefore you begin, make sure you have a Docker daemon running. The most popular platform\nis [Docker Desktop](https://www.docker.com/products/docker-desktop/).\n\n### Create a Deployment\n\nCreate a deployment with the `provision` command. For example, here's how you create a standalone\ninstance with zero configuration:\n\n```shell\ntomodo provision standalone\n```\n\nTo create a replica set with zero configuration, run the following command:\n\n```shell\ntomodo provision replica-set\n```\n\nTo create a sharded cluster with zero configuration, run the following command:\n\n```shell\ntomodo provision sharded\n```\n\nTo create a local Atlas deployment (a single-node replica set) with zero configuration, run the following command:\n\n```shell\ntomodo provision atlas\n```\n\nTake a look at each `provision` command's help page to read the full set of options\nwith `tomodo provision --help`.\n\n```\n Usage: tomodo provision [OPTIONS] COMMAND [ARGS]...\n\n Provision a MongoDB deployment\n\n\u256d\u2500 Options \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256e\n\u2502 --help Show this message and exit. \u2502\n\u2570\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256f\n\u256d\u2500 Commands \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256e\n\u2502 atlas Provision a local MongoDB Atlas deployment \u2502\n\u2502 replica-set Provision a MongoDB replica set deployment \u2502\n\u2502 sharded Provision a MongoDB sharded cluster \u2502\n\u2502 standalone Provision a standalone MongoDB deployment \u2502\n\u2570\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256f\n```\n\n### Describe Deployments\n\nUse the `describe` command to print the details of one or all deployments:\n\n```shell\n# Describe all deployments\ntomodo describe\n\n# Describe a deployment by name\ntomodo describe --name yawning-mole\n\n# Describe only running deployments\ntomodo describe --exclude-stopped\n```\n\n### List Deployments\n\nUse the `list` command to list your deployments:\n\n```shell\n# List all deployments\ntomodo list\n\n# List only running deployments\ntomodo list --exclude-stopped\n```\n\n### Stop Deployments\n\nUse the `stop` command to stop your deployments:\n\n```shell\n# Stop all deployments\ntomodo stop\n\n# Stop a deployment by name\ntomodo stop --name troubled-narwhal\n\n# Stop all deployments without prompting for confirmation\ntomodo stop --auto-approve\n```\n\n### Start Deployments\n\nUse the `start` command to start a deployment you previously stopped:\n\n```shell\ntomodo start --name printed-lemming\n```\n\n### Remove Deployments\n\nUse the `remove` command to permanently remove deployments:\n\n```shell\n# Remove all deployments\ntomodo remove\n\n# Remove a deployment by name\ntomodo remove --name troubled-narwhal\n\n# Remove all deployments without prompting for confirmation\ntomodo remove --auto-approve\n```\n\n### List Tags\n\nUse the `tags list` command to list the available image tags on Docker Hub.\n\n```shell\ntomodo tags list --version 7\n```\n\nSample output:\n\n```\n7.0.6\n7.0.6-jammy\n7.0.6-nanoserver\n7.0.6-nanoserver-1809\n7.0.6-nanoserver-ltsc2022\n7.0.6-windowsservercore\n7.0.6-windowsservercore-1809\n7.0.6-windowsservercore-ltsc2022\n7.0.5\n7.0.5-jammy\n7.0.5-nanoserver\n7.0.5-nanoserver-1809\n7.0.5-nanoserver-ltsc2022\n7.0.5-windowsservercore\n7.0.5-windowsservercore-1809\n7.0.5-windowsservercore-ltsc2022\n7.0.4\n7.0.4-jammy\n7.0.4-nanoserver\n7.0.4-nanoserver-1809\n7.0.4-nanoserver-ltsc2022\n7.0.4-windowsservercore\n7.0.4-windowsservercore-1809\n7.0.4-windowsservercore-ltsc2022\n7.0.3\n7.0.3-jammy\n7.0.3-nanoserver\n7.0.3-nanoserver-1809\n7.0.3-nanoserver-ltsc2022\n7.0.3-windowsservercore\n7.0.3-windowsservercore-1809\n7.0.3-windowsservercore-ltsc2022\n7.0.2\n7.0.2-jammy\n7.0.2-nanoserver\n7.0.2-nanoserver-1809\n7.0.2-nanoserver-ltsc2022\n7.0.2-windowsservercore\n7.0.2-windowsservercore-1809\n7.0.2-windowsservercore-ltsc2022\n```\n\n## Programmatic Usage\n\nYou can install tomodo in your Python (>=3.8) projects using `pip` or any other Python package manager, and use it\nprogrammatically (you'll still need a Docker daemon running).\n\n```python\nfrom typing import Dict\n\nfrom tomodo import functional as tfunc\nfrom tomodo.common.errors import DeploymentNotFound\nfrom tomodo.common.models import AtlasDeployment, Deployment, Mongod, ReplicaSet, ShardedCluster\n\n# Create a standalone instance:\nmongod: Mongod = tfunc.provision_standalone_instance(port=1000)\n\n# Create an Atlas instance:\natlas_depl: AtlasDeployment = tfunc.provision_atlas_instance(port=2000)\n\n# Create a replica set:\nreplica_set: ReplicaSet = tfunc.provision_replica_set(port=3000, replicas=3)\n\n# Create a sharded cluster:\nsh_cluster: ShardedCluster = tfunc.provision_sharded_cluster(port=4000, shards=2, config_servers=3, mongos=2)\n\n# Stop a deployment:\nmongod.stop()\n\n# Start a stopped deployment:\nmongod.start()\n\n# Remove a deployment permanently:\nmongod.remove()\n\n# Find a deployment by name\ntry:\n deployment = tfunc.get_deployment(name=\"elegant-leopard\", include_stopped=True)\nexcept DeploymentNotFound:\n print(\"Deployment not found\")\n\n# List all deployments:\ndeployments: Dict = tfunc.list_deployments(include_stopped=True)\nfor name in deployments.keys():\n deployment: Deployment = deployments[name]\n print(f\"Deployment {name} is {deployment.last_known_state}\")\n```\n\n## Disclaimer\nThis software is not supported by MongoDB, Inc. under any of their commercial support subscriptions or otherwise.\nAny usage of tomodo is at your own risk. Bug reports, feature requests, and questions can be posted in the\n[Issues section](https://github.com/yuvalherziger/tomodo/issues) of this repository.\n\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A CLI for managing MongoDB deployments on Docker",
"version": "1.3.1",
"project_urls": {
"Homepage": "https://tomodo.dev",
"Repository": "https://github.com/yuvalherziger/tomodo"
},
"split_keywords": [
"mongodb",
" docker",
" upgrade",
" python",
" cli"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "b5ba0cf7d8f33f4b037bbc17770eb823e98fb9bf5a5a49d73f3f8e65e29658b8",
"md5": "122274f2ee50fd33334fba6bb91dbccb",
"sha256": "0d7337ae609a4643c272f0ddf88ce20020f15a132c894dbb753e12b8889432b8"
},
"downloads": -1,
"filename": "tomodo-1.3.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "122274f2ee50fd33334fba6bb91dbccb",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<3.13,>=3.8",
"size": 35246,
"upload_time": "2024-08-30T11:12:35",
"upload_time_iso_8601": "2024-08-30T11:12:35.535905Z",
"url": "https://files.pythonhosted.org/packages/b5/ba/0cf7d8f33f4b037bbc17770eb823e98fb9bf5a5a49d73f3f8e65e29658b8/tomodo-1.3.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "7d40019b0bea2d4916130ff012159551f0ed2ad137856a4dec6bcf270d20f604",
"md5": "a9fc489d82cb0164c5e12c8e3ff8df9d",
"sha256": "88dc29d0b7d184ae192ee82e98d0e02c67659fcfab42b9f38532ee130c5be822"
},
"downloads": -1,
"filename": "tomodo-1.3.1.tar.gz",
"has_sig": false,
"md5_digest": "a9fc489d82cb0164c5e12c8e3ff8df9d",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<3.13,>=3.8",
"size": 29467,
"upload_time": "2024-08-30T11:12:37",
"upload_time_iso_8601": "2024-08-30T11:12:37.149148Z",
"url": "https://files.pythonhosted.org/packages/7d/40/019b0bea2d4916130ff012159551f0ed2ad137856a4dec6bcf270d20f604/tomodo-1.3.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-08-30 11:12:37",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "yuvalherziger",
"github_project": "tomodo",
"travis_ci": false,
"coveralls": true,
"github_actions": true,
"requirements": [
{
"name": "certifi",
"specs": [
[
"==",
"2024.7.4"
]
]
},
{
"name": "charset-normalizer",
"specs": [
[
"==",
"3.3.2"
]
]
},
{
"name": "click",
"specs": [
[
"==",
"8.1.7"
]
]
},
{
"name": "colorama",
"specs": [
[
"==",
"0.4.6"
]
]
},
{
"name": "dnspython",
"specs": [
[
"==",
"2.6.1"
]
]
},
{
"name": "docker",
"specs": [
[
"==",
"7.1.0"
]
]
},
{
"name": "idna",
"specs": [
[
"==",
"3.7"
]
]
},
{
"name": "markdown-it-py",
"specs": [
[
"==",
"3.0.0"
]
]
},
{
"name": "mdurl",
"specs": [
[
"==",
"0.1.2"
]
]
},
{
"name": "pygments",
"specs": [
[
"==",
"2.18.0"
]
]
},
{
"name": "pymongo",
"specs": [
[
"==",
"4.8.0"
]
]
},
{
"name": "pywin32",
"specs": [
[
"==",
"306"
]
]
},
{
"name": "requests",
"specs": [
[
"==",
"2.32.3"
]
]
},
{
"name": "rich",
"specs": [
[
"==",
"13.7.1"
]
]
},
{
"name": "ruamel-yaml-clib",
"specs": [
[
"==",
"0.2.8"
]
]
},
{
"name": "ruamel-yaml",
"specs": [
[
"==",
"0.17.40"
]
]
},
{
"name": "shellingham",
"specs": [
[
"==",
"1.5.4"
]
]
},
{
"name": "typer",
"specs": [
[
"==",
"0.9.4"
]
]
},
{
"name": "typing-extensions",
"specs": [
[
"==",
"4.12.2"
]
]
},
{
"name": "unique-names-generator",
"specs": [
[
"==",
"1.0.2"
]
]
},
{
"name": "urllib3",
"specs": [
[
"==",
"2.2.2"
]
]
}
],
"lcname": "tomodo"
}