{"id":20533049,"url":"https://github.com/anatoliybr/todo-app","last_synced_at":"2026-04-18T12:02:34.260Z","repository":{"id":183212008,"uuid":"669775430","full_name":"AnatoliyBr/todo-app","owner":"AnatoliyBr","description":"REST API application for managing task lists (todo lists)","archived":false,"fork":false,"pushed_at":"2024-02-06T13:09:20.000Z","size":1036,"stargazers_count":0,"open_issues_count":0,"forks_count":1,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-02-13T05:47:27.458Z","etag":null,"topics":["clean-architecture","dependency-injection","docker-compose","dockerfile","go","jwt-authentication","middleware","migrations","postgresql","rest-api"],"latest_commit_sha":null,"homepage":"","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"agpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/AnatoliyBr.png","metadata":{"files":{"readme":"README.md","changelog":null,"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}},"created_at":"2023-07-23T11:45:56.000Z","updated_at":"2023-09-03T21:18:57.000Z","dependencies_parsed_at":"2023-09-25T00:00:13.106Z","dependency_job_id":"19753033-3067-47bd-a5c7-93a3aaf3f4b7","html_url":"https://github.com/AnatoliyBr/todo-app","commit_stats":null,"previous_names":["anatoliybr/todo-app"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/AnatoliyBr%2Ftodo-app","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/AnatoliyBr%2Ftodo-app/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/AnatoliyBr%2Ftodo-app/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/AnatoliyBr%2Ftodo-app/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/AnatoliyBr","download_url":"https://codeload.github.com/AnatoliyBr/todo-app/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":242138880,"owners_count":20078006,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","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":["clean-architecture","dependency-injection","docker-compose","dockerfile","go","jwt-authentication","middleware","migrations","postgresql","rest-api"],"created_at":"2024-11-16T00:18:25.722Z","updated_at":"2026-04-18T12:02:34.204Z","avatar_url":"https://github.com/AnatoliyBr.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"## TODO-APP\n### Описание\nREST API приложение для ведения **списков задач** (todo-списков).\n\n### Функционал\nДанное серверное (backend) приложение предоставляет API для **регистрации** и **аутентификации** пользователя, а также **работы** с todo-списками и отдельными задачами внутри них.\n\n## Структура REST API\n**Публичные endpoint'ы**, доступные всем:\n```\nPOST /users - регистрация пользователя\nPOST /tokens - аутентификация пользователя и выдача JWT\n```\n\n**Приватные endpoint'ы**, доступные только аутентифицированным пользователям:\n```\nGET /profile - просмотр профиля пользователя\n\nPOST /lists - создание списка\nGET /lists - просмотр всех списков\n\nGET /lists/{id} - просмотр списка\nPUT /lists/{id} - редактирование списка\nDELETE /lists/{id} - удаление списка\n\nPOST /lists/{id}/tasks - добавление задачи в список\nGET /lists/{id}/tasks - просмотр всех задач в списке\n\nGET /tasks/{id} - просмотр задачи в списке\nPUT /tasks/{id} - редактирование задачи в списке  \nDELETE /tasks/{id} - удаление задачи из списка\n```\n\n## Схема базы данных\n\n\u003cp align=\"center\"\u003e\n    \u003cimg src=\"/assets/images/er_schema.png\" width=\"800\"\u003e\n\u003c/p\u003e\n\n## Архитектура\n\n\u003cp align=\"center\"\u003e\n    \u003cimg src=\"/assets/images/architecture.png\" width=\"800\"\u003e\n\u003c/p\u003e\n\n## Структура проекта\n```\n├── cmd\n|   ├── app\n|\n├── configs\n├── internal\n|   ├── app\n|   ├── controller\n|   ├── entity\n|   ├── store\n|   ├── usecase\n|\n├── migrations\n├── .env\n├── .gitignore\n├── Makefile\n├── README.md\n├── go.mod\n├── go.sum\n```\n\n## Запуск и отладка\nВсе команды, используемые в процессе разработки и тестирования, фиксировались в `Makefile`.\n\nЧтобы поднять проект, необходимо выполнить **две задачи** из `Makefile`:\n\n```bash\nmake compose-build\nmake compose-up\n```\n\n## Техническая статья\n\n### [Мой опыт создания REST API сервера для ведения todo-списков](/todo_paper.md)\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"/assets/images/todo_paper_cover.png\" width=\"800\"\u003e\n\u003c/p\u003e\n\n`todo_paper.md` - файл со статьей\n\n## Примеры запросов\n* [Регистрация](#регистрация)\n* [Аутентификация](#аутентификация)\n* [Просмотр профиля](#просмотр-профиля)\n* [Создание списка](#создание-списка)\n* [Просмотр всех списков](#просмотр-всех-списков)\n* [Просмотр списка](#просмотр-списка)\n* [Редактирование списка](#редактирование-списка)\n\n### Регистрация\nРегистрация пользователя:\n\n```bash\ncurl --location --request POST http://localhost:8080/users \\\n--data-raw '{\n    \"email\":\"user@example.org\",\n    \"password\":\"password\"\n}'\n```\n\nПример ответа:\n\n```bash\n{\n    \"user_id\":1,\n    \"email\":\"user@example.org\"\n}\n```\n\n### Аутентификация\nАутентификация пользователя и выдача JWT:\n\n```bash\ncurl --location --request POST http://localhost:8080/tokens \\\n--data-raw '{\n    \"email\":\"user@example.org\",\n    \"password\":\"password\"\n}' -v\n```\n\nПример ответа:\n\n```bash\nHTTP/1.1 200 OK\nSet-Cookie: token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxLCJleHAiOjE2OTM3NjY5OTB9.FhxzjhKtylOZQYrpG88r_lH7-kssye9IWh7UsZ8_t6k\nX-Request-Id: f7e4e8ab-ac7f-4266-b683-d35564927fc7\nDate: Sun, 03 Sep 2023 18:44:50 GMT\nContent-Length: 0\n```\n\n### Просмотр профиля\nПросмотр профиля аутентифицированного пользователя:\n\n```bash\ncurl --location --request GET http://localhost:8080/profile \\\n--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxLCJleHAiOjE2OTM3NjY5OTB9.FhxzjhKtylOZQYrpG88r_lH7-kssye9IWh7UsZ8_t6k'\n```\n\nПример ответа:\n\n```bash\n{\n    \"user_id\":1,\n    \"email\":\"user@example.org\"\n}\n```\n\n### Создание списка\nСоздание списка задач:\n\n```bash\ncurl --location --request POST http://localhost:8080/lists \\\n--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxLCJleHAiOjE2OTM3NjY5OTB9.FhxzjhKtylOZQYrpG88r_lH7-kssye9IWh7UsZ8_t6k' \\\n--data-raw '{\n  \"list_title\":\"test title 1\"\n}'\n```\n\nПример ответа:\n\n```bash\n{\n    \"list_id\": 1,\n    \"list_title\": \"TEST TITLE 1\",\n    \"user_id\": 1\n}\n```\n\n### Просмотр всех списков\nПросмотр всех списков задач:\n\n```bash\ncurl --location --request GET http://localhost:8080/lists \\\n--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxLCJleHAiOjE2OTM3NjY5OTB9.FhxzjhKtylOZQYrpG88r_lH7-kssye9IWh7UsZ8_t6k'\n```\n\nПример ответа:\n\n```bash\n[\n    {\n        \"list_id\": 1,\n        \"list_title\": \"TEST TITLE 1\"\n    },\n    {\n        \"list_id\": 2,\n        \"list_title\": \"TEST TITLE 2\"\n    }\n]\n```\n\n### Просмотр списка\nПросмотр списка задач по идентификатору:\n\n```bash\ncurl --location --request GET http://localhost:8080/lists/1 \\\n--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxLCJleHAiOjE2OTM3NjY5OTB9.FhxzjhKtylOZQYrpG88r_lH7-kssye9IWh7UsZ8_t6k'\n```\n\nПример ответа:\n\n```bash\n{\n    \"list_id\": 1,\n    \"list_title\": \"TEST TITLE 1\",\n    \"user_id\": 1\n}\n```\n\n### Редактирование списка\nРедактирование названия списка задач по идентификатору:\n\n```bash\ncurl --location --request PUT http://localhost:8080/lists/1 \\\n--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxLCJleHAiOjE2OTM3NjY5OTB9.FhxzjhKtylOZQYrpG88r_lH7-kssye9IWh7UsZ8_t6k' \\\n--data-raw '{\n  \"list_title\":\"test title 2\"\n}'\n```\n\nПример ответа:\n\n```bash\n{\n    \"list_id\": 1,\n    \"list_title\": \"TEST TITLE 2\",\n    \"user_id\": 1\n}\n```","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fanatoliybr%2Ftodo-app","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fanatoliybr%2Ftodo-app","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fanatoliybr%2Ftodo-app/lists"}