{"id":24298146,"url":"https://github.com/ibrahimsezer/file_tranfer_web_interface","last_synced_at":"2025-09-26T00:31:15.310Z","repository":{"id":270767793,"uuid":"911396635","full_name":"ibrahimsezer/file_tranfer_web_interface","owner":"ibrahimsezer","description":"A file transfer application that allows users to share files using single-use codes. Built with React, Node.js, and Express. (Cursor ai was used)","archived":false,"fork":false,"pushed_at":"2025-01-05T12:50:39.000Z","size":3946,"stargazers_count":7,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-04-07T20:50:18.238Z","etag":null,"topics":["axios","cors","express","filetransfer","heroicons","i18next","nodejs","react","tailwindcss","vite"],"latest_commit_sha":null,"homepage":"https://file-tranfer-web-interface.onrender.com/","language":"JavaScript","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/ibrahimsezer.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}},"created_at":"2025-01-02T23:21:07.000Z","updated_at":"2025-02-26T15:18:39.000Z","dependencies_parsed_at":"2025-01-05T12:19:14.359Z","dependency_job_id":null,"html_url":"https://github.com/ibrahimsezer/file_tranfer_web_interface","commit_stats":null,"previous_names":["ibrahimsezer/secure_file_tranfer","ibrahimsezer/file_tranfer_web_interface"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/ibrahimsezer/file_tranfer_web_interface","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ibrahimsezer%2Ffile_tranfer_web_interface","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ibrahimsezer%2Ffile_tranfer_web_interface/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ibrahimsezer%2Ffile_tranfer_web_interface/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ibrahimsezer%2Ffile_tranfer_web_interface/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ibrahimsezer","download_url":"https://codeload.github.com/ibrahimsezer/file_tranfer_web_interface/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ibrahimsezer%2Ffile_tranfer_web_interface/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":274232031,"owners_count":25245855,"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-08T02:00:09.813Z","response_time":121,"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":["axios","cors","express","filetransfer","heroicons","i18next","nodejs","react","tailwindcss","vite"],"created_at":"2025-01-16T20:54:00.426Z","updated_at":"2025-09-26T00:31:14.063Z","avatar_url":"https://github.com/ibrahimsezer.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# File Transfer Web Interface\n\nA  file transfer application that allows users to share files using single-use codes. Built with React, Node.js, and Express.\n\n![License](https://img.shields.io/badge/license-MIT-blue.svg)\n\n## 🌟 Live Demo\n\nTry the application live at: [https://file-tranfer-web-interface.onrender.com](https://file-tranfer-web-interface.onrender.com)\n\n\u003e Note: The live demo is hosted on Render.com's free tier, so initial load might take a few seconds if the server has been inactive.\n\n## 🌟 Features\n\n- **File Sharing**: Transfer files using single-use download codes\n- **Multi-language Support**: Available in English, German, and Turkish\n- **Modern UI**: Clean and responsive interface built with Tailwind CSS\n- **File Type Support**: Handles various file types including:\n  - Images (JPG, PNG, GIF)\n  - Documents (PDF, DOC, DOCX, TXT)\n  - Audio (MP3, WAV)\n  - Video (MP4, MOV, AVI)\n- **File Size Limit**: Supports files up to 100MB\n- **Auto-cleanup**: Files are automatically deleted after download\n\n## 🚀 Getting Started\n\nYou can either use the live demo at [https://file-tranfer-web-interface.onrender.com](https://file-tranfer-web-interface.onrender.com) or run the application locally by following these steps:\n\n### Prerequisites\n\n- Node.js (v14 or higher)\n- npm (v6 or higher)\n\n### Installation\n\n1. Clone the repository:\n```bash\ngit clone https://github.com/ibrahimsezer/file_tranfer.git\ncd file_tranfer\n```\n2. Install dependencies for both client and server:\n```bash\n# Install client dependencies\ncd client\nnpm install\n\n# Install server dependencies\ncd ../server\nnpm install\n```\n\n3. Start the server:\n```bash\n# In the server directory\nnpm start\n```\n\n4. Start the client:\n```bash\n# In the client directory\nnpm run dev\n```\n\nThe application will be available at `http://localhost:5000`\n\n## 🔧 Usage\n\nYou can try the application directly at [https://file-tranfer-web-interface.onrender.com](https://file-tranfer-web-interface.onrender.com) or follow these steps for local usage: \n\n### Uploading a File\n\n1. Click on \"Upload a File\" on the home page\n2. Select a file by clicking the upload area or dragging and dropping\n3. Click \"Upload File\"\n4. Once uploaded, you'll receive a unique code\n5. Share this code with the recipient\n\n### Downloading a File\n\n1. Click on \"Download a File\" on the home page\n2. Enter the received code\n3. Click \"Download File\"\n4. The file will automatically download to your device\n5. Note: Each code can only be used once\n\n## 🛠️ Tech Stack\n\n### Frontend\n- React.js\n- Vite\n- Tailwind CSS\n- i18next (Internationalization)\n- Axios\n- Heroicons\n\n### Backend\n- Node.js\n- Express\n- Multer (File handling)\n- CORS\n- nanoid (Code generation)\n\n## 📁 Project Structure\n\n```\nfile_tranfer/\n├── client/\n│   ├── src/\n│   │   ├── components/\n│   │   ├── translations/\n│   │   ├── App.jsx\n│   │   └── main.jsx\n│   ├── public/\n│   └── package.json\n└── server/\n    ├── index.js\n    └── package.json\n```\n\n## 🌐 Internationalization\n\nThe application supports multiple languages:\n- English (en)\n- German (de)\n- Turkish (tr)\n\nLanguage can be changed using the language switcher in the top-right corner.\n\n## 🔒 Security Features\n\n- Single-use download codes\n- Automatic file deletion after download\n- File type validation\n- Size limitations\n- file storage\n\n## 💻 API Endpoints\n\n### POST `/upload`\n- Uploads a file and returns a unique code\n- Accepts multipart/form-data\n- Returns: `{ code: string }`\n\n### GET `/download/:code`\n- Downloads a file using the provided code\n- Returns: File stream with appropriate headers\n- Deletes file after successful download\n\n## 🤝 Contributing\n\n1. Fork the repository\n2. Create your feature branch (`git checkout -b feature/AmazingFeature`)\n3. Commit your changes (`git commit -m 'Add some AmazingFeature'`)\n4. Push to the branch (`git push origin feature/AmazingFeature`)\n5. Open a Pull Request\n\n## 📝 License\n\nThis project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.\n\n## 👤 Author\n\nIbrahim Sezer\n- GitHub: [@ibrahimsezer](https://github.com/ibrahimsezer)\n- LinkedIn: [ibrahim-sezer](https://www.linkedin.com/in/ibrahim-sezer/)\n- Website: [ibrahimsezer.github.io](https://ibrahimsezer.github.io)\n\n## 🙏 Acknowledgments\n\n- React.js community\n- Tailwind CSS team\n- All contributors and users of the project\n\n## 📸 Screenshots\n\n![Home Page](client/src/assets/screenshots/home.png)\n![Upload Page](client/src/assets/screenshots/upload.png)\n![Download Page](client/src/assets/screenshots/download.png)\n\n## 🌟 Star History\n\n[![Star History Chart](https://api.star-history.com/svg?repos=ibrahimsezer/secure_file_tranfer\u0026type=Date)](https://star-history.com/#ibrahimsezer/secure_file_tranfer\u0026Date)\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fibrahimsezer%2Ffile_tranfer_web_interface","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fibrahimsezer%2Ffile_tranfer_web_interface","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fibrahimsezer%2Ffile_tranfer_web_interface/lists"}