{"id":48222213,"url":"https://github.com/diviatrix/ts-cms","last_synced_at":"2026-04-04T19:12:18.341Z","repository":{"id":297559339,"uuid":"985025457","full_name":"diviatrix/ts-cms","owner":"diviatrix","description":"Pet project cms with TypeScript, Node.js, Express and sqlite. Frontend is served right from backend.","archived":false,"fork":false,"pushed_at":"2026-01-10T17:20:37.000Z","size":4496,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2026-01-11T05:15:44.083Z","etag":null,"topics":["cms","simple"],"latest_commit_sha":null,"homepage":"https://1337.plus","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/diviatrix.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":null,"license":"LICENSE","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":"2025-05-16T23:37:41.000Z","updated_at":"2026-01-10T17:20:41.000Z","dependencies_parsed_at":"2025-06-06T05:26:28.760Z","dependency_job_id":"9fd3dae7-a621-456d-9308-a9c9281e3a6b","html_url":"https://github.com/diviatrix/ts-cms","commit_stats":null,"previous_names":["diviatrix/ts-cms"],"tags_count":1,"template":false,"template_full_name":null,"purl":"pkg:github/diviatrix/ts-cms","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diviatrix%2Fts-cms","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diviatrix%2Fts-cms/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diviatrix%2Fts-cms/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diviatrix%2Fts-cms/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/diviatrix","download_url":"https://codeload.github.com/diviatrix/ts-cms/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diviatrix%2Fts-cms/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31409541,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-04T10:20:44.708Z","status":"ssl_error","status_checked_at":"2026-04-04T10:20:06.846Z","response_time":60,"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":["cms","simple"],"created_at":"2026-04-04T19:12:18.283Z","updated_at":"2026-04-04T19:12:18.336Z","avatar_url":"https://github.com/diviatrix.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"![TypeScript Lightweight CMS](public/img/promo/index.png)\n\n# TypeScript CMS\n\nЛегковесная система управления контентом на TypeScript с Express.js и SQLite.\n\n## Возможности\n\n- **Управление контентом**: Записи с markdown, тегами, категориями и изображениями\n- **Пагинация и поиск**: Фильтрация по категориям/тегам, полнотекстовый поиск\n- **Аутентификация**: JWT токены с ролевой системой (admin/user)\n- **Система тем**: Темы с CSS переменными и настройками\n- **Система приглашений**: Контролируемая регистрация через invite-коды\n- **API**: REST API с Swagger документацией\n- **Безопасность**: Rate limiting, валидация, санитизация данных\n\n## Установка\n\n```bash\ngit clone https://github.com/diviatrix/ts-cms.git\ncd ts-cms\nnpm install\nnpm run dev\n```\n\nПриложение запустится на `http://localhost:7331`\n\n## Первоначальная настройка\n\n1. Зарегистрируйтесь на `/login`, первый зарегистрированный пользователь всегда в группе admin.\nДобавить admin роль можно и через SQL:\n   ```sql\n   INSERT INTO user_groups (user_id, group_id) VALUES ('YOUR_USER_ID', 'admin');\n   ```\n2. Настройте режим регистрации в Admin Panel - OPEN, CLOSED, INVITE_ONLY\n3. Настройте параметры, инвайты, пользователей и тему в админке. (Тему после сохранения надо записать на фронт)\n4. Наполняйте контентом\n\n## Команды\n\n```bash\nnpm start                             # Продакшн сервер\nnpm run dev                           # Разработка с автоперезагрузкой\nnpm run lint                          # ESLint проверка\nnpm test                              # Запуск тестов\n\n# Тестирование с Allure отчетами\nnpm run test:allure                   # Тесты + генерация + открытие Allure отчета\nnpm run allure:generate               # Генерировать Allure отчет из результатов\nnpm run allure:open                   # Открыть готовый Allure отчет\nnpm run allure:serve                  # Запустить сервер с Allure отчетом\n\n# Проверка базы данных\nnpx ts-node server.ts --checkdb       # Проверить схему БД\nnpx ts-node server.ts --checkdb --fix # Исправить недостающие таблицы\n```\n\n## API эндпоинты\n/docs/API_DOCUMENTATION.md\nИли \n- в админке включить api_docs_enabled\n- /api-docs\n\n## Структура проекта\n\n```\nts-cms/\n├── src/                    # Backend TypeScript\n│   ├── routes/            # API маршруты  \n│   ├── functions/         # Бизнес-логика\n│   ├── middleware/        # Express middleware\n│   ├── types/             # TypeScript интерфейсы\n│   └── db-adapter/        # Адаптер базы данных\n├── public/                # Frontend\n│   ├── js/               # Vanilla JavaScript (SPA)\n│   ├── css/              # Модульный CSS\n│   └── partials/         # HTML шаблоны\n├── tests/                 # Тесты\n└── data/                 # SQLite база данных\n```\n\n## Конфигурация\n\nПеременные окружения:\n```bash\nAPI_PORT=7331                    # Порт сервера\nCORS_ORIGIN=http://localhost:7331 # CORS origin\nNODE_ENV=production              # Режим окружения\n```\n\n## Лицензия\n\nISC License\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdiviatrix%2Fts-cms","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdiviatrix%2Fts-cms","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdiviatrix%2Fts-cms/lists"}