{"id":31006438,"url":"https://github.com/lenaar/column-operations-api","last_synced_at":"2026-05-19T14:34:32.773Z","repository":{"id":313672072,"uuid":"1052221200","full_name":"lenaar/column-operations-api","owner":"lenaar","description":"Flask API with basic calculations","archived":false,"fork":false,"pushed_at":"2025-09-07T17:58:43.000Z","size":21,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"feature/rest-api-implementation","last_synced_at":"2025-09-07T19:21:54.146Z","etag":null,"topics":["flask-api","openapi","pydantic","python3","sqlalchemy"],"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/lenaar.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":"2025-09-07T16:48:09.000Z","updated_at":"2025-09-07T17:50:17.000Z","dependencies_parsed_at":"2025-09-07T19:32:20.858Z","dependency_job_id":null,"html_url":"https://github.com/lenaar/column-operations-api","commit_stats":null,"previous_names":["lenaar/column-operations-api"],"tags_count":null,"template":false,"template_full_name":null,"purl":"pkg:github/lenaar/column-operations-api","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lenaar%2Fcolumn-operations-api","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lenaar%2Fcolumn-operations-api/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lenaar%2Fcolumn-operations-api/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lenaar%2Fcolumn-operations-api/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/lenaar","download_url":"https://codeload.github.com/lenaar/column-operations-api/tar.gz/refs/heads/feature/rest-api-implementation","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lenaar%2Fcolumn-operations-api/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":274907841,"owners_count":25371822,"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","status":"online","status_checked_at":"2025-09-13T02:00:10.085Z","response_time":70,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"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":["flask-api","openapi","pydantic","python3","sqlalchemy"],"created_at":"2025-09-13T02:12:39.335Z","updated_at":"2026-05-19T14:34:32.728Z","avatar_url":"https://github.com/lenaar.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Column Operations API\n\nA Flask-based REST API for performing column operations on integer data stored in SQLite.\n\n## 🚀 Quick Start\n\n### Option 1: Docker (Recommended)\n\n```bash\n# Clone the repository\ngit clone \u003crepository-url\u003e\ncd tacton\n\n# Build and run with Docker Compose\ndocker-compose up --build\n\n# Or run with Docker directly\ndocker build -t column-operations-api .\ndocker run -p 8000:8000 column-operations-api\n```\n\n### Option 2: Local Python\n\n#### Prerequisites\n\n- Python 3.11+\n- pip\n\n#### Installation\n\n```bash\n# Clone the repository\ngit clone \u003crepository-url\u003e\ncd tacton\n\n# Install dependencies\npip install -r requirements.txt\n\n# Run the application\npython main.py\n```\n\nThe API will be available at `http://localhost:8000`\n\n## 📚 API Documentation\n\nInteractive API documentation is available at: `http://localhost:8000/apidocs`\n\n## 🔗 API Endpoints\n\n### 1. View All Data\n\n```http\nGET /api/v1/data\n```\n\n**Response:**\n\n```json\n{\n  \"data\": [\n    {\n      \"id\": 1,\n      \"column_1\": 10,\n      \"column_2\": 20,\n      \"column_3\": 30,\n      \"column_4\": 40,\n      \"column_5\": 50\n    },\n    {\n      \"id\": 2,\n      \"column_1\": 15,\n      \"column_2\": 25,\n      \"column_3\": 35,\n      \"column_4\": 45,\n      \"column_5\": 55\n    }\n  ],\n  \"count\": 2\n}\n```\n\n### 2. Sum Two Columns\n\n```http\nPOST /api/v1/data:sumColumns\n```\n\n**Request:**\n\n```json\n{\n  \"the_first_col_name\": \"column_1\",\n  \"my_second_colname\": \"column_5\"\n}\n```\n\n**Response:**\n\n```json\n{\n  \"result\": [60, 70]\n}\n```\n\n### 3. Calculate Formula\n\n```http\nPOST /api/v1/data:calculateFormula\n```\n\n**Request:**\n\n```json\n{\n  \"myFormula\": \"column_1 + column_2 * column_3\"\n}\n```\n\n**Response:**\n\n```json\n{\n  \"result\": [610, 890]\n}\n```\n\n## 🧪 Testing\n\n### Docker Testing\n\n```bash\n# Run tests in Docker container\ndocker-compose run test\n\n# Or build and run tests only\ndocker build -t column-operations-api .\ndocker run --rm column-operations-api python run_tests.py\n```\n\n### Local Testing\n\n```bash\n# Run all tests\npython run_tests.py\n\n# Or using pytest directly\npytest tests/ -v\n```\n\n## 🏗️ Architecture\n\n```\n├── api/           # API routes and schemas\n├── config/        # Configuration and environment\n├── db/            # Database models and initialization\n├── services/      # Business logic\n├── tests/         # Test suite\n└── docs/          # API documentation\n```\n\n## ⚙️ Configuration\n\nCopy `env.sample` to `.env` and customize:\n\n```bash\ncp env.sample .env\n```\n\nAvailable environment variables:\n\n- `DATABASE_URL`: SQLite database path\n- `TABLE_NAME`: Database table name\n- `LOG_LEVEL`: Logging level\n- `API_HOST`: API host (default: localhost)\n- `API_PORT`: API port (default: 8000)\n\n## 🔧 Development\n\n### Adding New Columns\n\n1. Update `config/columns.py`:\n\n```python\nCOLUMN_NAMES = ['column_1', 'column_2', 'column_3', 'column_4', 'column_5', 'column_6']\n```\n\n2. Update Swagger documentation manually in `docs/openapi/v1.yaml`\n\n3. Update database schema (migration needed)\n\n### Code Quality\n\n- **Type hints** throughout the codebase\n- **Pydantic models** for validation\n- **Comprehensive tests** with 30+ test cases\n- **Error handling** with proper HTTP status codes\n\n## 📊 Features\n\n- ✅ **RESTful API** with Flask\n- ✅ **SQLite database** with automatic initialization\n- ✅ **Pydantic validation** for request/response\n- ✅ **Swagger documentation** with OpenAPI 2.0\n- ✅ **Comprehensive testing** with pytest\n- ✅ **Error handling** with detailed error messages\n- ✅ **Environment configuration** support\n- ✅ **API versioning** (`/api/v1/`)\n- ✅ **Modular architecture** with separation of concerns\n- ✅ **Docker support** with automated testing\n- ✅ **Health checks** for monitoring\n\n## 🚧 Future Enhancements\n\nSee [ENHANCEMENTS.md](ENHANCEMENTS.md) for planned improvements.\n\n## 📝 License\n\n[Add your license here]\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flenaar%2Fcolumn-operations-api","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Flenaar%2Fcolumn-operations-api","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flenaar%2Fcolumn-operations-api/lists"}