{"id":28936299,"url":"https://github.com/argf013/projects-api","last_synced_at":"2026-05-05T08:37:26.289Z","repository":{"id":300184594,"uuid":"1004116713","full_name":"argf013/projects-api","owner":"argf013","description":"Project Portfolio API built with Express.js and TypeScript, optimized for serverless environments.","archived":false,"fork":false,"pushed_at":"2025-06-20T11:23:34.000Z","size":129,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"master","last_synced_at":"2025-07-23T23:48:01.107Z","etag":null,"topics":["express","github","learn","neon","netlify","portfolio","rest-api","typescript"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/argf013.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"CONTRIBUTING.md","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}},"created_at":"2025-06-18T06:28:27.000Z","updated_at":"2025-07-04T13:41:18.000Z","dependencies_parsed_at":"2025-06-20T09:43:23.217Z","dependency_job_id":"0d6a0bd8-0e70-4950-b71d-2d179e88694b","html_url":"https://github.com/argf013/projects-api","commit_stats":null,"previous_names":["argf013/projects-api"],"tags_count":0,"template":false,"template_full_name":"argf013/express-ts-netlify-template","purl":"pkg:github/argf013/projects-api","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/argf013%2Fprojects-api","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/argf013%2Fprojects-api/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/argf013%2Fprojects-api/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/argf013%2Fprojects-api/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/argf013","download_url":"https://codeload.github.com/argf013/projects-api/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/argf013%2Fprojects-api/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32642278,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-04T10:08:07.713Z","status":"online","status_checked_at":"2026-05-05T02:00:06.033Z","response_time":54,"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":["express","github","learn","neon","netlify","portfolio","rest-api","typescript"],"created_at":"2025-06-22T20:08:20.260Z","updated_at":"2026-05-05T08:37:26.273Z","avatar_url":"https://github.com/argf013.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Projects API\n\nA simple API to manage project data along with thumbnail images, built with Express, TypeScript, Neon (serverless PostgreSQL), and Cloudinary for image storage.\n\n## Features\n\n- CRUD Project (Create, Read, Update, Delete)\n- Upload and manage thumbnail files (Cloudinary)\n- Pagination for project and file listing\n- Bulk deletion for projects and thumbnails\n- Endpoint to initialize the database (tables)\n- Public HTML uploader for thumbnails\n\n## Folder Structure\n\n- `netlify/functions/api.ts` — Netlify Function entry point (Express API)\n- `routes/` — Endpoint logic for projects \u0026 files\n- `public/` — Static HTML uploader\n- `dist/` — TypeScript build output\n\n## Setup \u0026 Installation\n\n1. **Clone the repo \u0026 install dependencies**\n\n   ```bash\n   npm install\n   ```\n\n2. **Create a `.env` file**\n\n   ```\n   DATABASE_URL=postgresql://username:password@host:port/database?sslmode=require\n   CLOUD_NAME=your_cloud_name\n   API_KEY=your_api_key\n   API_SECRET=your_api_secret\n   ```\n\n3. **Build TypeScript**\n\n   ```bash\n   npm run build\n   ```\n\n4. **Run locally (Netlify Dev)**\n   ```bash\n   npm run dev\n   ```\n\n## API Endpoints\n\nAll endpoints are prefixed with `/api` (or `/.netlify/functions/api` on Netlify).\n\n### Project\n\n- `GET    /projects` — List projects (pagination: `page`, `limit`)\n- `GET    /project/:id` — Project details\n- `POST   /project` — Add a project\n- `PUT    /project/:id` — Update a project\n- `DELETE /project` — Delete multiple projects (body: `{ ids: string[] }`)\n\n### File \u0026 Thumbnail\n\n- `GET    /files` — List thumbnail files\n- `GET    /files/thumbnails` — List thumbnails from Cloudinary\n- `POST   /files/thumbnail` — Upload thumbnail (body: `{ file: base64, filename: string }`)\n- `DELETE /files/thumbnails` — Delete multiple thumbnails (body: `{ ids: string[] }`)\n\n### Database Initialization\n\n- `GET /init` — Create `projects` \u0026 `files` tables if they do not exist\n\n## Example Requests\n\n### Thumbnail Upload Request\n\n```http\nPOST /files/thumbnail\nContent-Type: application/json\n\n{\n  \"file\": \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA...\",\n  \"filename\": \"myimage.png\"\n}\n```\n\n### Bulk Project Deletion\n\n```http\nDELETE /project\nContent-Type: application/json\n\n{\n  \"ids\": [\"project-id-1\", \"project-id-2\", \"project-id-3\"]\n}\n```\n\n### Bulk Thumbnail Deletion\n\n```http\nDELETE /files/thumbnails\nContent-Type: application/json\n\n{\n  \"ids\": [\"project-thumbnails/thumbnail-id-1\", \"project-thumbnails/thumbnail-id-2\"]\n}\n```\n\n## Static Uploader\n\nOpen `public/index.html` to visually upload thumbnails.\n\n## Deployment\n\n- Ready to deploy on Netlify (see `netlify.toml` and `_redirects`)\n- Make sure environment variables are set in the Netlify dashboard\n\n## License\n\nMIT\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fargf013%2Fprojects-api","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fargf013%2Fprojects-api","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fargf013%2Fprojects-api/lists"}