{"id":15686728,"url":"https://github.com/thenets/do-kyoka","last_synced_at":"2026-04-15T16:03:41.797Z","repository":{"id":57569772,"uuid":"272808513","full_name":"thenets/do-kyoka","owner":"thenets","description":"Auto-update Digital Ocean 🌊  firewall. The easiest way to access all your instances without a VPN.","archived":false,"fork":false,"pushed_at":"2023-03-07T01:59:22.000Z","size":138,"stargazers_count":0,"open_issues_count":2,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-03-29T10:34:49.265Z","etag":null,"topics":["digitalocean","docker","docker-image"],"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/thenets.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":"2020-06-16T20:44:30.000Z","updated_at":"2022-02-13T15:34:54.000Z","dependencies_parsed_at":"2024-06-20T01:33:58.334Z","dependency_job_id":"c81ebb8a-4193-4156-bd90-e2ea14e7863c","html_url":"https://github.com/thenets/do-kyoka","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/thenets%2Fdo-kyoka","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/thenets%2Fdo-kyoka/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/thenets%2Fdo-kyoka/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/thenets%2Fdo-kyoka/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/thenets","download_url":"https://codeload.github.com/thenets/do-kyoka/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":246310977,"owners_count":20757052,"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":["digitalocean","docker","docker-image"],"created_at":"2024-10-03T17:41:05.839Z","updated_at":"2026-04-15T16:03:36.743Z","avatar_url":"https://github.com/thenets.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"[![Docker Repository on Quay](https://quay.io/repository/thenets/do-kyoka/status \"Docker Repository on Quay\")](https://quay.io/repository/thenets/do-kyoka)\n\n# do-kyoka 💂‍♀️\n\nAuto-update Digital Ocean 🌊 firewall. The easiest way to access all your instances without a VPN.\n\nIt gets your public IP address and creates/updates a firewall at Digital Ocean that allows you to join your instances.\n\n![do-kyoka diagram](./do-kyoka-diagram.png)\n\n## 👨‍💻 Motivation\n\nDigital Ocean is a very good cloud provider for developers who want an easy way to deploy their applications. No fancy features. Just create a droplet (VM), jump into the instance and play with it.\n\nThe problem is: many times I don't want to have an instance joining my VPN but I also don't want to have the instance publicly available on the internet.\n\nSo, this project is my attempt to solve my problem to allow me to access everything that I want without exposing my application everywhere or deploying my instance in one specific VPC, or joining into my VPN.\n\n\u003e 🔴 This solution IS NOT DESIGNED FOR PRODUCTION. You must use a VPN and a private network to have a secure environment and not expose your application to the internet.\n\n## 📚 Requirements\n\n- Digital Ocean API token with write access (https://cloud.digitalocean.com/account/api/)\n- A container runner (docker|podman)\n\n## 🚢 How to use \n\nThe `do-kyoka` creates a firewall at Digital Ocean that allows you to join your instances. Add the corresponding `tag` to your droplet and you will be able to access it.\n\nContainer image:\n- `quay.io/thenets/do-kyoka:latest`\n\n### 🛠 Environment variables\n\n- `DO_API_TOKEN`: `[required]` Digital Ocean API token with `write` permission. NEVER SHARE IT WITH ANYONE.\n- `FIREWALL_NAME`: [default: do-kyoka] The name of the firewall to create/update on Digital Ocean. It's important to notice that ALL CURRENT FIREWALL RULES WILL BE DELETED!\n- `FIREWALL_TAG`: [default: do-kyoka] The `tag` to add to your droplet to allow it to join the firewall.\n\n### 💽 Example\n\n```bash\ndocker run -it \\\n    --name \"do-kyoka-firewall\" \\\n    --restart unless-stopped \\\n    -e \"DO_API_TOKEN=Nxkal9ZWxOMjo6WtU26KLNAnsaW8xQnJjGaT88VkkjyTX8POOdP52Z9XM5K0TM542\" \\\n    -e \"FIREWALL_NAME=do-kyoka\" \\\n    -e \"FIREWALL_TAG=do-kyoka\" \\\n    quay.io/thenets/do-kyoka:latest\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fthenets%2Fdo-kyoka","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fthenets%2Fdo-kyoka","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fthenets%2Fdo-kyoka/lists"}