{"id":19606651,"url":"https://github.com/gothack/acmeasync","last_synced_at":"2025-12-14T00:08:32.481Z","repository":{"id":57408033,"uuid":"292286538","full_name":"GothAck/acmeasync","owner":"GothAck","description":"asyncio ACME / Letsencrypt client with built in TCP TLS proxy server","archived":false,"fork":false,"pushed_at":"2021-10-15T04:58:45.000Z","size":2347,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":3,"default_branch":"master","last_synced_at":"2025-01-09T09:21:54.840Z","etag":null,"topics":["acme-client","acme-http","acme-v2","letsencrypt","proxy","proxy-server","python","python3"],"latest_commit_sha":null,"homepage":"http://gothack.ninja/acmeasync/","language":"Python","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/GothAck.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE.txt","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2020-09-02T13:10:52.000Z","updated_at":"2022-10-15T19:56:31.000Z","dependencies_parsed_at":"2022-09-26T17:10:52.641Z","dependency_job_id":null,"html_url":"https://github.com/GothAck/acmeasync","commit_stats":null,"previous_names":["gothack/pyacmele"],"tags_count":2,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/GothAck%2Facmeasync","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/GothAck%2Facmeasync/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/GothAck%2Facmeasync/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/GothAck%2Facmeasync/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/GothAck","download_url":"https://codeload.github.com/GothAck/acmeasync/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":240894327,"owners_count":19874794,"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":["acme-client","acme-http","acme-v2","letsencrypt","proxy","proxy-server","python","python3"],"created_at":"2024-11-11T10:06:27.237Z","updated_at":"2025-12-14T00:08:32.448Z","avatar_url":"https://github.com/GothAck.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# ACMEasync\n\nAsyncIO ACME client for Python 3.\n\n## Why?\nMoar async moar better. Seriously though, I wanted to utilize Python's asyncio to create an automatically certifying proxy server that \"just works\".\n\n## How?\nYou can use the library as is, see `acmeasync/__main__.py` and `acmeasync/certbot2.py` as guides for spinning your own implementations, or use the built in tls reverse proxy (currently raw TCP only).\n\nTo run the proxy:\n```sh\nexport DOMAINS=\"example.com,example.net\"\nexport PORT=80 # or whatever port you wish to run the ACME challenge http server on, you need root to serve on 80, or you can forward 8080 if you're running in a docker container for example.\nexport EMAIL=\"youremail@example.com\"\nexport PROXIES=\"8081:towel.blinkenlights.nl:23,8082:towel.blinkenlights.nl:23\" # format: localport:remotehost:remoteport,...\nexport DIRECTORY_URL=\"https://acme-v02.api.letsencrypt.org/directory\"\nacmeleproxy\n```\n\nIt's recommended you run as root so that proxy processes can drop privileges and lose access to your private keys, but this is optional.\n\nAPI documentation incoming soon...\n\n## But why Python?\nYeah, I know, the GIL, the proxy server uses multiprocessing to spawn a subprocess per connection, which should give much better performance. This kinda thing exists the nodejs world already, why not python too?\n\n\n## Requirements\nPulled in by setup.py:\n- `acme`\n- `aiohttp`\n- `aiohttp-requests`\n\nRequired from your OS:\n- `python3-openssl`\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgothack%2Facmeasync","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fgothack%2Facmeasync","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgothack%2Facmeasync/lists"}