{"id":16681813,"url":"https://github.com/ps1dr3x/ars-proxy","last_synced_at":"2025-10-29T08:11:52.416Z","repository":{"id":95424745,"uuid":"142221931","full_name":"ps1dr3x/ars-proxy","owner":"ps1dr3x","description":"Fast, minimal, asynchronous HTTP/HTTPS proxy server that can be used as a reverse proxy or for securing non-TLS services. Written in Rust","archived":false,"fork":false,"pushed_at":"2018-10-03T16:26:29.000Z","size":20,"stargazers_count":3,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-08-19T05:57:25.683Z","etag":null,"topics":["async","fast","futures","hyper","proxy","reverse","rust","server","tls","tokio"],"latest_commit_sha":null,"homepage":"","language":"Rust","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/ps1dr3x.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":"2018-07-24T23:13:05.000Z","updated_at":"2022-08-17T22:30:35.000Z","dependencies_parsed_at":"2023-05-03T12:47:24.112Z","dependency_job_id":null,"html_url":"https://github.com/ps1dr3x/ars-proxy","commit_stats":null,"previous_names":[],"tags_count":1,"template":false,"template_full_name":null,"purl":"pkg:github/ps1dr3x/ars-proxy","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ps1dr3x%2Fars-proxy","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ps1dr3x%2Fars-proxy/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ps1dr3x%2Fars-proxy/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ps1dr3x%2Fars-proxy/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ps1dr3x","download_url":"https://codeload.github.com/ps1dr3x/ars-proxy/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ps1dr3x%2Fars-proxy/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":271553422,"owners_count":24779821,"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-08-21T02:00:08.990Z","response_time":74,"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":["async","fast","futures","hyper","proxy","reverse","rust","server","tls","tokio"],"created_at":"2024-10-12T14:05:22.847Z","updated_at":"2025-10-29T08:11:47.397Z","avatar_url":"https://github.com/ps1dr3x.png","language":"Rust","funding_links":[],"categories":[],"sub_categories":[],"readme":"# ars-proxy [WIP]\nFast, minimal, asynchronous HTTP/HTTPS proxy server written in Rust\n\n```bash\n# Usage:\nars-proxy \u003clocal_port\u003e \u003cremote_url\u003e \u003cremote_port\u003e [--cert \u003ccrt_path\u003e --pass-file \u003cpass_file_path\u003e] [--to-https]\n```\n### Notes:\n\n- If `--to-https` parameter is specified (useful only in HTTP mode), the server will proxy all the received http requests to HTTPS.\n\n- If a TLS certificate path is specified (by `--cert` parameter), the server will listen on HTTPS only.\n  - The only certificate format supported is .pfx/.p12, it is possible to create a .pfx certificate from .crt and .key files using openssl:\n    ```bash\n    openssl pkcs12 -export -out cert.pfx -inkey cert.key -in cert.crt\n    ```\n  - The password file (whose path can be specified by `--pass-file` parameter) is supposed to be a file containing only the certificate password (setting file permissions to 600 is recommended). This avoids specifying the certificate password in command line, that can be a security problem.\n  - If argument `--pass-file` is not specified, the certificate password is assumed to be blank (\"\").\n\n### Credits:\n\nCredit for a working implementation of a (Tokio-based) Hyper HTTPS server goes to @izderadicka [[link]](https://github.com/izderadicka/tokio-tls/tree/new-tokio \"[link]\")","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fps1dr3x%2Fars-proxy","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fps1dr3x%2Fars-proxy","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fps1dr3x%2Fars-proxy/lists"}