<p align="center">
<a href="https://github.com/hitsz-ids/dataucon"><img alt="DataUCon" src="https://raw.githubusercontent.com/hitsz-ids/dataucon/main/img/white-icon-simple.png"></a>
</p>
<h2 align="center">duetector๐: Data Usage Extensible detector(eBPF Support)</h2>
<p align="center">
<a href="https://github.com/hitsz-ids/duetector/actions"><img alt="Actions Status" src="https://github.com/hitsz-ids/duetector/actions/workflows/python-package.yml/badge.svg"></a>
<a href='https://duetector.readthedocs.io/en/latest/?badge=latest'><img src='https://readthedocs.org/projects/duetector/badge/?version=latest' alt='Documentation Status' /></a>
<a href="https://results.pre-commit.ci/latest/github/hitsz-ids/duetector/main"><img alt="pre-commit.ci status" src="https://results.pre-commit.ci/badge/github/hitsz-ids/duetector/main.svg"></a>
<a href="https://github.com/hitsz-ids/duetector/blob/main/LICENSE"><img alt="LICENSE" src="https://img.shields.io/github/license/hitsz-ids/duetector"></a>
<a href="https://github.com/hitsz-ids/duetector/releases/"><img alt="Releases" src="https://img.shields.io/github/v/release/hitsz-ids/duetector"></a>
<a href="https://github.com/hitsz-ids/duetector/releases/"><img alt="Pre Releases" src="https://img.shields.io/github/v/release/hitsz-ids/duetector?include_prereleases&label=pre-release&logo=github"></a>
<a href="https://github.com/hitsz-ids/duetector"><img alt="Last Commit" src="https://img.shields.io/github/last-commit/hitsz-ids/duetector"></a>
<a href="https://github.com/hitsz-ids/duetector"><img alt="Python version" src="https://img.shields.io/pypi/pyversions/duetector"></a>
<a href="https://github.com/hitsz-ids/duetector/contributors"><img alt="contributors" src="https://img.shields.io/github/all-contributors/hitsz-ids/duetector?color=ee8449&style=flat-square"></a>
<a href="https://join.slack.com/t/hitsz-ids/shared_invite/zt-2395mt6x2-dwf0j_423QkAgGvlNA5E1g"><img alt="slack" src="https://img.shields.io/badge/slack-join%20chat-ff69b4.svg?style=flat-square"></a>
</p>
<p align="center">
<a href="./README.md">English</a> | <a href="./README_zh.md">ไธญๆ</a>
</p>
## Introduction
> duetector is one of the components in the DataUCON project, which is designed to provide support for data usage control. [Intro DataUCON](https://dataucon.idslab.io/).
duetector๐ is an extensible data usage control detector that provides support for data usage control by probing for data usage behavior in the Linux kernel(based on eBPF).
**๐๐๐งช The project is under heavy development, looking forward to any bug reports, feature requests, pull requests!**
In the [ABAUC control model](https://github.com/hitsz-ids/dataucon), duetector can be used as a PIP (Policy Information Point) to obtain data usage behavior, so as to provide information about data usage behavior for PDP (Policy Decision Point). Provide information on data usage behavior to PDP (Policy Decision Point).
Try simple user case: [Simplest Open Count](./docs/usercases/simplest-open-count/README.md).
Join our [slack channel](https://join.slack.com/t/hitsz-ids/shared_invite/zt-2395mt6x2-dwf0j_423QkAgGvlNA5E1g).
## Table of Contents
- [Features](#Features)
- [Installation](#Installation)
- [Quick Start](#quick-start)
- [API](#API-documentation)
- [Maintainers](#Maintainers)
- [Contributors](#Contributors)
- [How to contribute](#How-to-contribute)
- [License](#License)
## Feature
- Plug-in system support, see [examples](./examples/README.md) for more details
- [x] Custom `Tracer` and `TracerManager`
- [x] Custom `Filters` and `FilterManager`
- [x] Custom `Collector` and `CollectorManager`
- [x] Custom `Analyzer` and `AnalyzerManager`
- Configuration Management
- [x] Configuration using a single configuration file
- [x] Generate Plugin Configuration
- [ ] Support for dynamically loading configurations
- `Tracer` Support
- [x] eBPF-based tracer
- [x] Shell command tracer
- [x] Subprocess tracer
- `Filter` Support
- [x] Pattern matching, based on regular expressions
- Data Collection and Analysis
- [x] `Analyzer` Support SQL database
- [x] `Collector` Support SQL database and *OpenTelemetry(Experimental)*
- User Interface
- [x] CLI Tools
- [x] PIP Service
- [ ] Control Panel
- Enhancements
- [ ] `RunC` containers identification
The eBPF program requires kernel support, see [Kernel Support](./docs/kernel_config.md)
## Installation
The code is distributed via Pypi, and you can install it with the following command
```bash
pip install duetector
```
Currently, the code relies on [BCC](https://github.com/iovisor/bcc) for on-the-fly compilation of eBPF code, we recommend [installing the latest BCC compiler](https://github.com/iovisor/bcc/blob/master/INSTALL.md)
Or use the Docker image that we provide, which uses [JupyterLab](https://github.com/jupyterlab/jupyterlab) as the **example** user application, or you can modify the [Dockerfile](./docker/Dockerfile) and [startup script](./docker/start.sh) to customize the user application.
```bash
docker pull dataucon/duetector:latest
```
Pre-releases will not be updated to `latest`, you can specify the tag to pull, e.g. `v0.0.1a`
```bash
docker pull dataucon/duetector:v0.0.1a
```
For more details on running with docker images see [here](./docs/how-to/run-with-docker.md)
## Quick start
> More documentation and examples can be found [here](./docs/).
### Start detector
Start monitor using the command line, since bcc requires root privileges, we use the `sudo` command, which will start all probes and collect the probes into the `duetector-dbcollector.sqlite3` file in the current directory
```bash
sudo duectl start
```
Press `CRTL+C` to exit monitoring and you will see a summary output on the screen
```
{'DBCollector': {'OpenTracer': {'count': 31, 'first at': 249920233249912, 'last': Tracking(tracer='OpenTracer', pid=641616, uid=1000, gid= 1000, comm='node', cwd=None, fname='SOME-FILE', timestamp=249923762308577, extended={})}}}
```
Enable `DEBUG` log
```bash
sudo DUETECTOR_LOG_LEVEL=DEBUG duectl start
```
At startup, the configuration file will be automatically generated at `~/.config/duetector`, and you can specify the configuration file to use with `--config`.
```bash
sudo duectl start --config <config-file-path>
```
Configuration using environment variables is also supported:
```bash
Usage: duectl start [OPTIONS]
Start A bcc monitor and wait for KeyboardInterrupt
Options:
...
--load_env BOOLEAN Weather load env variables,Prefix: DUETECTOR_,
Separator:__, e.g. DUETECTOR_config__a means
config.a, default: True
...
```
When using a plugin, the default configuration file will not contain the plugin's configuration, use the dynamically-generated configuration directive to generate a configuration file with the plugin's configuration, this directive also supports merging existing configuration files and environment variables.
```bash
duectl generate-dynamic-config --help
```
Use `generate-config` to restore the default state in case of configuration file errors.
```bash
duectl generate-config
```
Going a step further, running in the background you can use the `duectl-daemon start` command, which will run a daemon in the background, which you can stop using `duectl-daemon stop`
Use `duectl-daemon --help` for more details:
```bash
Usage: duectl-daemon [OPTIONS] COMMAND [ARGS]...
Options:
--help Show this message and exit.
Commands:
start Start a background process of command `duectl start`.
status Show status of process.
stop Stop the process.
```
### Analyzing with analyzer
We provide an [Analyzer](https://duetector.readthedocs.io/en/latest/analyzer/index.html) that can query the data in storage, try it in [user case](./docs/usercases/simplest-open-count/README.md)
### Using duetector server
We provide a Duetector Server as an external PIP service and control interface
A Duetector Server can be started using `duectl-server` and will listen on `0.0.0.0:8120` by default, you can modify it using `--host` and `--port`.
```bash
$ duectl-server start --help
Usage: duectl-server start [OPTIONS]
Start duetector server
Options:
--config TEXT Config file path, default:
``~/.config/duetector/config.toml``.
--load_env BOOLEAN Weather load env variables, Prefix: ``DUETECTOR_``,
Separator:``__``, e.g. ``DUETECTOR_config__a`` means
``config.a``, default: True
--workdir TEXT Working directory, default: ``.``.
--host TEXT Host to listen, default: ``0.0.0.0``.
--port INTEGER Port to listen, default: ``8120``.
--workers INTEGER Number of worker processes, default: ``1``.
--help Show this message and exit.
```
After the service has started, visit `http://{ip}:{port}/docs` to see the API documentation.
Similarly, using `duectl-server-daemon start` you can run a Duetector Server in the background, and you can stop it using `duectl-server-daemon stop`
```bash
$ duectl-server-daemon
Usage: duectl-server-daemon [OPTIONS] COMMAND [ARGS]...
Options:
--help Show this message and exit.
Commands:
start Start a background process of command ``duectl-server start``.
status Show status of process.
stop Stop the process.
```
## API documentation
See [docs of duetector](https://duetector.readthedocs.io/)
## Maintainers
This project is initiated by **Institute of Data Security, Harbin Institute of Technology (Shen Zhen)**, if you are interested in this project and [DataUCON](https://dataucon.idslab.io/) project and willing to work together to improve it, welcome to join our open source community.
## Contributors
<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->
<!-- prettier-ignore-start -->
<!-- markdownlint-disable -->
<table>
<tbody>
<tr>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/wunder957"><img src="https://avatars.githubusercontent.com/u/141890183?v=4?s=100" width="100px;" alt="wunder957"/><br /><sub><b>wunder957</b></sub></a><br /><a href="#code-wunder957" title="Code">๐ป</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/WYXsb"><img src="https://avatars.githubusercontent.com/u/62527555?v=4?s=100" width="100px;" alt="MayDown"/><br /><sub><b>MayDown</b></sub></a><br /><a href="#code-WYXsb" title="Code">๐ป</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/tsdsnk"><img src="https://avatars.githubusercontent.com/u/93241244?v=4?s=100" width="100px;" alt="tsdsnk"/><br /><sub><b>tsdsnk</b></sub></a><br /><a href="#doc-tsdsnk" title="Documentation">๐</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/zhemulin"><img src="https://avatars.githubusercontent.com/u/89471919?v=4?s=100" width="100px;" alt="zhemulin"/><br /><sub><b>zhemulin</b></sub></a><br /><a href="#doc-zhemulin" title="Documentation">๐</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/aklly"><img src="https://avatars.githubusercontent.com/u/87172923?v=4?s=100" width="100px;" alt="Mortal"/><br /><sub><b>Mortal</b></sub></a><br /><a href="#doc-aklly" title="Documentation">๐</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/mingzhedream"><img src="https://avatars.githubusercontent.com/u/58738872?v=4?s=100" width="100px;" alt="mingzhedream"/><br /><sub><b>mingzhedream</b></sub></a><br /><a href="#doc-mingzhedream" title="Documentation">๐</a></td>
</tr>
</tbody>
</table>
<!-- markdownlint-restore -->
<!-- prettier-ignore-end -->
<!-- ALL-CONTRIBUTORS-LIST:END -->
## How to contribute
Starting with the [good first issue](https://github.com/hitsz-ids/duetector/issues/70) and reading our [contributing guidelines](./CONTRIBUTING.md).
Learn about the designing and architecture of this project here: [docs/design](./docs/design/README.md).
## License
This project uses Apache-2.0 license, please refer to [LICENSE](./LICENSE).
Raw data
{
"_id": null,
"home_page": "",
"name": "duetector",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": "",
"keywords": "duetector",
"author": "hitsz-ids",
"author_email": "",
"download_url": "https://files.pythonhosted.org/packages/c0/3d/a107795a9a65a4aa6295ff0e3030cc1e72eac7f6a20987f5cd4aff006c5c/duetector-0.1.3.tar.gz",
"platform": null,
"description": "<p align=\"center\">\n<a href=\"https://github.com/hitsz-ids/dataucon\"><img alt=\"DataUCon\" src=\"https://raw.githubusercontent.com/hitsz-ids/dataucon/main/img/white-icon-simple.png\"></a>\n</p>\n\n<h2 align=\"center\">duetector\ud83d\udd0d: Data Usage Extensible detector(eBPF Support)</h2>\n<p align=\"center\">\n<a href=\"https://github.com/hitsz-ids/duetector/actions\"><img alt=\"Actions Status\" src=\"https://github.com/hitsz-ids/duetector/actions/workflows/python-package.yml/badge.svg\"></a>\n<a href='https://duetector.readthedocs.io/en/latest/?badge=latest'><img src='https://readthedocs.org/projects/duetector/badge/?version=latest' alt='Documentation Status' /></a>\n<a href=\"https://results.pre-commit.ci/latest/github/hitsz-ids/duetector/main\"><img alt=\"pre-commit.ci status\" src=\"https://results.pre-commit.ci/badge/github/hitsz-ids/duetector/main.svg\"></a>\n<a href=\"https://github.com/hitsz-ids/duetector/blob/main/LICENSE\"><img alt=\"LICENSE\" src=\"https://img.shields.io/github/license/hitsz-ids/duetector\"></a>\n<a href=\"https://github.com/hitsz-ids/duetector/releases/\"><img alt=\"Releases\" src=\"https://img.shields.io/github/v/release/hitsz-ids/duetector\"></a>\n<a href=\"https://github.com/hitsz-ids/duetector/releases/\"><img alt=\"Pre Releases\" src=\"https://img.shields.io/github/v/release/hitsz-ids/duetector?include_prereleases&label=pre-release&logo=github\"></a>\n<a href=\"https://github.com/hitsz-ids/duetector\"><img alt=\"Last Commit\" src=\"https://img.shields.io/github/last-commit/hitsz-ids/duetector\"></a>\n<a href=\"https://github.com/hitsz-ids/duetector\"><img alt=\"Python version\" src=\"https://img.shields.io/pypi/pyversions/duetector\"></a>\n<a href=\"https://github.com/hitsz-ids/duetector/contributors\"><img alt=\"contributors\" src=\"https://img.shields.io/github/all-contributors/hitsz-ids/duetector?color=ee8449&style=flat-square\"></a>\n<a href=\"https://join.slack.com/t/hitsz-ids/shared_invite/zt-2395mt6x2-dwf0j_423QkAgGvlNA5E1g\"><img alt=\"slack\" src=\"https://img.shields.io/badge/slack-join%20chat-ff69b4.svg?style=flat-square\"></a>\n</p>\n\n<p align=\"center\">\n <a href=\"./README.md\">English</a> | <a href=\"./README_zh.md\">\u4e2d\u6587</a>\n</p>\n\n## Introduction\n\n> duetector is one of the components in the DataUCON project, which is designed to provide support for data usage control. [Intro DataUCON](https://dataucon.idslab.io/).\n\nduetector\ud83d\udd0d is an extensible data usage control detector that provides support for data usage control by probing for data usage behavior in the Linux kernel(based on eBPF).\n\n**\ud83d\udc1b\ud83d\udc1e\ud83e\uddea The project is under heavy development, looking forward to any bug reports, feature requests, pull requests!**\n\nIn the [ABAUC control model](https://github.com/hitsz-ids/dataucon), duetector can be used as a PIP (Policy Information Point) to obtain data usage behavior, so as to provide information about data usage behavior for PDP (Policy Decision Point). Provide information on data usage behavior to PDP (Policy Decision Point).\n\nTry simple user case: [Simplest Open Count](./docs/usercases/simplest-open-count/README.md).\n\nJoin our [slack channel](https://join.slack.com/t/hitsz-ids/shared_invite/zt-2395mt6x2-dwf0j_423QkAgGvlNA5E1g).\n\n## Table of Contents\n\n- [Features](#Features)\n- [Installation](#Installation)\n- [Quick Start](#quick-start)\n- [API](#API-documentation)\n- [Maintainers](#Maintainers)\n- [Contributors](#Contributors)\n- [How to contribute](#How-to-contribute)\n- [License](#License)\n\n## Feature\n\n- Plug-in system support, see [examples](./examples/README.md) for more details\n - [x] Custom `Tracer` and `TracerManager`\n - [x] Custom `Filters` and `FilterManager`\n - [x] Custom `Collector` and `CollectorManager`\n - [x] Custom `Analyzer` and `AnalyzerManager`\n- Configuration Management\n - [x] Configuration using a single configuration file\n - [x] Generate Plugin Configuration\n - [ ] Support for dynamically loading configurations\n- `Tracer` Support\n - [x] eBPF-based tracer\n - [x] Shell command tracer\n - [x] Subprocess tracer\n- `Filter` Support\n - [x] Pattern matching, based on regular expressions\n- Data Collection and Analysis\n - [x] `Analyzer` Support SQL database\n - [x] `Collector` Support SQL database and *OpenTelemetry(Experimental)*\n- User Interface\n - [x] CLI Tools\n - [x] PIP Service\n - [ ] Control Panel\n- Enhancements\n - [ ] `RunC` containers identification\n\nThe eBPF program requires kernel support, see [Kernel Support](./docs/kernel_config.md)\n\n## Installation\n\nThe code is distributed via Pypi, and you can install it with the following command\n\n```bash\npip install duetector\n```\n\nCurrently, the code relies on [BCC](https://github.com/iovisor/bcc) for on-the-fly compilation of eBPF code, we recommend [installing the latest BCC compiler](https://github.com/iovisor/bcc/blob/master/INSTALL.md)\n\nOr use the Docker image that we provide, which uses [JupyterLab](https://github.com/jupyterlab/jupyterlab) as the **example** user application, or you can modify the [Dockerfile](./docker/Dockerfile) and [startup script](./docker/start.sh) to customize the user application.\n\n```bash\ndocker pull dataucon/duetector:latest\n```\n\nPre-releases will not be updated to `latest`, you can specify the tag to pull, e.g. `v0.0.1a`\n\n```bash\ndocker pull dataucon/duetector:v0.0.1a\n```\n\nFor more details on running with docker images see [here](./docs/how-to/run-with-docker.md)\n\n## Quick start\n\n> More documentation and examples can be found [here](./docs/).\n\n### Start detector\n\nStart monitor using the command line, since bcc requires root privileges, we use the `sudo` command, which will start all probes and collect the probes into the `duetector-dbcollector.sqlite3` file in the current directory\n\n```bash\nsudo duectl start\n```\n\nPress `CRTL+C` to exit monitoring and you will see a summary output on the screen\n\n```\n{'DBCollector': {'OpenTracer': {'count': 31, 'first at': 249920233249912, 'last': Tracking(tracer='OpenTracer', pid=641616, uid=1000, gid= 1000, comm='node', cwd=None, fname='SOME-FILE', timestamp=249923762308577, extended={})}}}\n```\n\nEnable `DEBUG` log\n\n```bash\nsudo DUETECTOR_LOG_LEVEL=DEBUG duectl start\n```\n\nAt startup, the configuration file will be automatically generated at `~/.config/duetector`, and you can specify the configuration file to use with `--config`.\n\n```bash\nsudo duectl start --config <config-file-path>\n```\n\nConfiguration using environment variables is also supported:\n\n```bash\nUsage: duectl start [OPTIONS]\n\n Start A bcc monitor and wait for KeyboardInterrupt\n\nOptions:\n ...\n --load_env BOOLEAN Weather load env variables,Prefix: DUETECTOR_,\n Separator:__, e.g. DUETECTOR_config__a means\n config.a, default: True\n ...\n```\n\nWhen using a plugin, the default configuration file will not contain the plugin's configuration, use the dynamically-generated configuration directive to generate a configuration file with the plugin's configuration, this directive also supports merging existing configuration files and environment variables.\n\n```bash\nduectl generate-dynamic-config --help\n```\n\nUse `generate-config` to restore the default state in case of configuration file errors.\n\n```bash\nduectl generate-config\n```\n\nGoing a step further, running in the background you can use the `duectl-daemon start` command, which will run a daemon in the background, which you can stop using `duectl-daemon stop`\n\nUse `duectl-daemon --help` for more details:\n\n```bash\nUsage: duectl-daemon [OPTIONS] COMMAND [ARGS]...\n\nOptions:\n --help Show this message and exit.\n\nCommands:\n start Start a background process of command `duectl start`.\n status Show status of process.\n stop Stop the process.\n```\n\n### Analyzing with analyzer\n\nWe provide an [Analyzer](https://duetector.readthedocs.io/en/latest/analyzer/index.html) that can query the data in storage, try it in [user case](./docs/usercases/simplest-open-count/README.md)\n\n### Using duetector server\n\nWe provide a Duetector Server as an external PIP service and control interface\n\nA Duetector Server can be started using `duectl-server` and will listen on `0.0.0.0:8120` by default, you can modify it using `--host` and `--port`.\n\n```bash\n$ duectl-server start --help\nUsage: duectl-server start [OPTIONS]\n\n Start duetector server\n\nOptions:\n --config TEXT Config file path, default:\n ``~/.config/duetector/config.toml``.\n --load_env BOOLEAN Weather load env variables, Prefix: ``DUETECTOR_``,\n Separator:``__``, e.g. ``DUETECTOR_config__a`` means\n ``config.a``, default: True\n --workdir TEXT Working directory, default: ``.``.\n --host TEXT Host to listen, default: ``0.0.0.0``.\n --port INTEGER Port to listen, default: ``8120``.\n --workers INTEGER Number of worker processes, default: ``1``.\n --help Show this message and exit.\n```\n\nAfter the service has started, visit `http://{ip}:{port}/docs` to see the API documentation.\n\nSimilarly, using `duectl-server-daemon start` you can run a Duetector Server in the background, and you can stop it using `duectl-server-daemon stop`\n\n```bash\n$ duectl-server-daemon\nUsage: duectl-server-daemon [OPTIONS] COMMAND [ARGS]...\n\nOptions:\n --help Show this message and exit.\n\nCommands:\n start Start a background process of command ``duectl-server start``.\n status Show status of process.\n stop Stop the process.\n```\n\n## API documentation\n\nSee [docs of duetector](https://duetector.readthedocs.io/)\n\n## Maintainers\n\nThis project is initiated by **Institute of Data Security, Harbin Institute of Technology (Shen Zhen)**, if you are interested in this project and [DataUCON](https://dataucon.idslab.io/) project and willing to work together to improve it, welcome to join our open source community.\n\n## Contributors\n\n<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->\n\n<!-- prettier-ignore-start -->\n\n<!-- markdownlint-disable -->\n\n<table>\n <tbody>\n <tr>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/wunder957\"><img src=\"https://avatars.githubusercontent.com/u/141890183?v=4?s=100\" width=\"100px;\" alt=\"wunder957\"/><br /><sub><b>wunder957</b></sub></a><br /><a href=\"#code-wunder957\" title=\"Code\">\ud83d\udcbb</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/WYXsb\"><img src=\"https://avatars.githubusercontent.com/u/62527555?v=4?s=100\" width=\"100px;\" alt=\"MayDown\"/><br /><sub><b>MayDown</b></sub></a><br /><a href=\"#code-WYXsb\" title=\"Code\">\ud83d\udcbb</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/tsdsnk\"><img src=\"https://avatars.githubusercontent.com/u/93241244?v=4?s=100\" width=\"100px;\" alt=\"tsdsnk\"/><br /><sub><b>tsdsnk</b></sub></a><br /><a href=\"#doc-tsdsnk\" title=\"Documentation\">\ud83d\udcd6</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/zhemulin\"><img src=\"https://avatars.githubusercontent.com/u/89471919?v=4?s=100\" width=\"100px;\" alt=\"zhemulin\"/><br /><sub><b>zhemulin</b></sub></a><br /><a href=\"#doc-zhemulin\" title=\"Documentation\">\ud83d\udcd6</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/aklly\"><img src=\"https://avatars.githubusercontent.com/u/87172923?v=4?s=100\" width=\"100px;\" alt=\"Mortal\"/><br /><sub><b>Mortal</b></sub></a><br /><a href=\"#doc-aklly\" title=\"Documentation\">\ud83d\udcd6</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/mingzhedream\"><img src=\"https://avatars.githubusercontent.com/u/58738872?v=4?s=100\" width=\"100px;\" alt=\"mingzhedream\"/><br /><sub><b>mingzhedream</b></sub></a><br /><a href=\"#doc-mingzhedream\" title=\"Documentation\">\ud83d\udcd6</a></td>\n </tr>\n </tbody>\n</table>\n\n<!-- markdownlint-restore -->\n\n<!-- prettier-ignore-end -->\n\n<!-- ALL-CONTRIBUTORS-LIST:END -->\n\n## How to contribute\n\nStarting with the [good first issue](https://github.com/hitsz-ids/duetector/issues/70) and reading our [contributing guidelines](./CONTRIBUTING.md).\n\nLearn about the designing and architecture of this project here: [docs/design](./docs/design/README.md).\n\n## License\n\nThis project uses Apache-2.0 license, please refer to [LICENSE](./LICENSE).\n",
"bugtrack_url": null,
"license": "Apache Software License 2.0",
"summary": "duetector",
"version": "0.1.3",
"project_urls": {
"Source": "https://github.com/hitsz-ids/duetector"
},
"split_keywords": [
"duetector"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "442418ed651d0e562a96c4e902491310781dabcf0f7ee6fd6e3e80bf0cbdf66b",
"md5": "118196b1ae99665b7b54b5d056448109",
"sha256": "f89f800c132c9975dd6b7b1f23a0a89c433ead2c7d9f1a64a211c63be4816378"
},
"downloads": -1,
"filename": "duetector-0.1.3-py3-none-any.whl",
"has_sig": false,
"md5_digest": "118196b1ae99665b7b54b5d056448109",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 96164,
"upload_time": "2023-12-01T09:06:55",
"upload_time_iso_8601": "2023-12-01T09:06:55.069457Z",
"url": "https://files.pythonhosted.org/packages/44/24/18ed651d0e562a96c4e902491310781dabcf0f7ee6fd6e3e80bf0cbdf66b/duetector-0.1.3-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "c03da107795a9a65a4aa6295ff0e3030cc1e72eac7f6a20987f5cd4aff006c5c",
"md5": "d19e174a9549dc3a4d0f4f0e07e91f78",
"sha256": "b2f538d04a299f801b083d3fd366f27cc119e0fb1b3544e7ba051c4f5c645cdf"
},
"downloads": -1,
"filename": "duetector-0.1.3.tar.gz",
"has_sig": false,
"md5_digest": "d19e174a9549dc3a4d0f4f0e07e91f78",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 1779595,
"upload_time": "2023-12-01T09:06:57",
"upload_time_iso_8601": "2023-12-01T09:06:57.409066Z",
"url": "https://files.pythonhosted.org/packages/c0/3d/a107795a9a65a4aa6295ff0e3030cc1e72eac7f6a20987f5cd4aff006c5c/duetector-0.1.3.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-12-01 09:06:57",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "hitsz-ids",
"github_project": "duetector",
"travis_ci": false,
"coveralls": true,
"github_actions": true,
"lcname": "duetector"
}