{"id":13620940,"url":"https://github.com/HotPotatoC/twitter-clone","last_synced_at":"2025-04-14T22:33:01.130Z","repository":{"id":42479989,"uuid":"348959590","full_name":"HotPotatoC/twitter-clone","owner":"HotPotatoC","description":"🕊 Twitter Clone developed using Go + Vue 3 + Vite + TailwindCSS + PostgreSQL + Redis","archived":false,"fork":false,"pushed_at":"2023-11-01T17:09:56.000Z","size":15884,"stargazers_count":433,"open_issues_count":2,"forks_count":64,"subscribers_count":14,"default_branch":"rewrite","last_synced_at":"2024-11-17T02:41:52.783Z","etag":null,"topics":["aws","clone","docker","full-stack","golang","postgresql","redis","rest-api","s3","tailwindcss","twitter","typescript","vite","vue"],"latest_commit_sha":null,"homepage":"","language":"Go","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/HotPotatoC.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}},"created_at":"2021-03-18T06:03:43.000Z","updated_at":"2024-11-14T17:56:07.000Z","dependencies_parsed_at":"2024-01-11T14:09:22.915Z","dependency_job_id":"551eaf35-4b4e-401c-ab1f-ac8a6e39ae8e","html_url":"https://github.com/HotPotatoC/twitter-clone","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/HotPotatoC%2Ftwitter-clone","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/HotPotatoC%2Ftwitter-clone/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/HotPotatoC%2Ftwitter-clone/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/HotPotatoC%2Ftwitter-clone/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/HotPotatoC","download_url":"https://codeload.github.com/HotPotatoC/twitter-clone/tar.gz/refs/heads/rewrite","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":248972472,"owners_count":21191798,"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":["aws","clone","docker","full-stack","golang","postgresql","redis","rest-api","s3","tailwindcss","twitter","typescript","vite","vue"],"created_at":"2024-08-01T21:01:00.936Z","updated_at":"2025-04-14T22:32:56.100Z","avatar_url":"https://github.com/HotPotatoC.png","language":"Go","readme":"# Twitter Clone\n\nAn attempt to recreate one of the largest social networking application Twitter.\n\n\u003e Note: This is my first attempt at developing a distributed system, so any feedback would be greatly appreciated.\n\n## Services\n\n1. [Edge Service (GraphQL)](./edge/)\n2. [Media Service](./media/)\n3. [Notifications Service](./notifications/)\n4. [Search Service](./search/)\n5. [Timeline Service](./timeline/)\n6. [Tweet Service](./tweet/)\n7. [Web UI Service](./website/)\n\n## Technologies Used\n\n1. Golang (Internal Services)\n2. Next.JS (Website UI)\n3. Kafka (Pub/Sub)\n4. Apache Spark (Analytics)\n5. PostgreSQL (Main Database)\n6. PgPool II (Database Load Balancer)\n7. Redis (Caching)\n8. Docker (Containerization)\n9. Nginx (Load Balancer)\n10. GraphQL (Edge Server / Frontend for Backend)\n11. ElasticSearch (Searching \u0026 Indexing)\n12. Firebase Cloud Messenger (Notification Service)\n\n## System Design\n\n### Functional Requirements\n1. Create Tweets (text, images, videos, etc)\n2. View Timeline\n3. Like tweets\n4. Retweet / Quote Retweet\n5. Follow others\n\n### Non-Functional Requirements\n1. Scalable \u0026 Efficient\n2. High Availability\n\n### Optional Requirements\n1. Metrics and analytics\n2. Notifications\n3. Observability \u0026 Monitoring (Prometheus, Grafana, Jaeger, etc)\n\n### Database Schema\n\n# How to run locally\n\nCheck [here](RUNNING_LOCALLY.md) on how to run locally\n","funding_links":[],"categories":["T"],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FHotPotatoC%2Ftwitter-clone","html_url":"https://awesome.ecosyste.ms/projects/github.com%2FHotPotatoC%2Ftwitter-clone","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FHotPotatoC%2Ftwitter-clone/lists"}