{"id":37714094,"url":"https://github.com/ig-rudenko/loop-detector","last_synced_at":"2026-01-16T13:23:13.523Z","repository":{"id":241079230,"uuid":"804191140","full_name":"ig-rudenko/loop-detector","owner":"ig-rudenko","description":"Приложение предназначено для анализа и мониторинга сетевых петель","archived":false,"fork":false,"pushed_at":"2025-10-31T10:19:52.000Z","size":16053,"stargazers_count":1,"open_issues_count":17,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-10-31T12:17:06.192Z","etag":null,"topics":["docker","elasticsearch","fastapi","logs-analysis","loop-detectors","network-visualization","python","vue"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/ig-rudenko.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2024-05-22T06:05:06.000Z","updated_at":"2025-10-07T11:34:06.000Z","dependencies_parsed_at":"2024-05-28T15:37:23.138Z","dependency_job_id":"cae6e74d-cca3-449d-9040-7eafa92b2241","html_url":"https://github.com/ig-rudenko/loop-detector","commit_stats":null,"previous_names":["ig-rudenko/loop-detector"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/ig-rudenko/loop-detector","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ig-rudenko%2Floop-detector","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ig-rudenko%2Floop-detector/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ig-rudenko%2Floop-detector/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ig-rudenko%2Floop-detector/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ig-rudenko","download_url":"https://codeload.github.com/ig-rudenko/loop-detector/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ig-rudenko%2Floop-detector/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28479033,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-16T11:59:17.896Z","status":"ssl_error","status_checked_at":"2026-01-16T11:55:55.838Z","response_time":107,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["docker","elasticsearch","fastapi","logs-analysis","loop-detectors","network-visualization","python","vue"],"created_at":"2026-01-16T13:23:12.846Z","updated_at":"2026-01-16T13:23:13.518Z","avatar_url":"https://github.com/ig-rudenko.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"## Loop Detector\n\n![techs](https://skillicons.dev/icons?i=elasticsearch,py,redis,fastapi,vue,vite,ts,docker)\n\n---\n\nПриложение помогает выявлять и визуализировать текущие петли на сети, а также просматривать историю их возникновения.\n\nПриложение обрабатывает логи, поступающие от сетевого оборудования, и определяет наличие петель в реальном\nвремени. При обнаружении петли, приложение предоставляет графическое отображение связей между устройствами,\nчто позволяет легко локализовать проблему и определить, на каком оборудовании её искать.\n\n![schema](/docs/notification-schema.svg)\n\nСистема состоит из трех приложений:\n\n1. GraphGen - генератор графов [Подробнее](https://github.com/ig-rudenko/loop-detector/tree/master/graph_gen#readme).\n2. WebApp - приложение на FastAPI для взаимодействия с графами через API.\n3. Frontend - Vue+TS+Vite\n\n## Структура приложения\n\n![schema](/docs/schema.svg)\n\n## Настройка\n\nДля работы приложения необходимо иметь настроенные приложение\n[Ecstasy](https://github.com/ig-rudenko/ecstasy) и Elasticsearch.\n\n### GraphGen\n\nНужно создать файл `.env` в папке `graph_gen/env` с переменными окружения.\n\nПример файла со значениями по умолчанию находится в\n`graph_gen/env/sample.env`. На основе этого файла нужно создать свой.\n\nСкопируем и заполним своими данными:\n\n```shell\ncp graph_gen/env/sample.env graph_gen/env/.env;\n```\n\nМожно его разместить в другом месте, но тогда придется указать его в `docker-compose.yaml` файле.\n\n[Подробнее про настройку GraphGen](https://github.com/ig-rudenko/loop-detector/tree/master/graph_gen#readme).\n\nДалее нужно скопировать JSON файл с начальными правилами поиска сообщений\nо петлях в корень проекта. Для этого скопируем базовый файл (если нужно,\nв нём можно настроить свои параметры):\n\n```shell\ncp graph_gen/config/sample.es-matches.json es-matches.json;\n```\n\n### Web App\n\nНужно также создать файл для переменных окружения.\nПример файла находится в `web_app/env/sample.env`.\n\nСкопируем и заполним своими данными:\n\n```shell\ncp web_app/env/sample.env web_app/env/.env;\n```\n\n## Запуск\n\nПеред запуском нужно создать файл в корне проекта (изначально пустой) для хранения настроек\nоповещений о новых петлях. По умолчанию в docker-compose.yaml его название\nуказано как `notifications.json`. Там будут храниться способы оповещений.\n\nНе удаляйте этот файл в дальнейшем!\n\n```shell\ntouch notifications.json;\n```\n\nПриложение запускается с помощью:\n\n```shell\ndocker compose up -d\n```\n\nПриложение будет сохранять граф петель и его сообщения в json файлы.\nХранилище по умолчанию указано как `./loop_storage`.\n\n## Визуализация\n\n![img.png](docs/img/img.png)\n\n![img.png](docs/img/img_1.png)\n\n![img.png](docs/img/img_2.png)\n\n![img.png](docs/img/img_3.png)\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fig-rudenko%2Floop-detector","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fig-rudenko%2Floop-detector","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fig-rudenko%2Floop-detector/lists"}