proxyfor 0.5.0

A powerful and flexible proxy CLI for capturing and inspecting HTTP(S) and WS(S) traffic
Documentation
<h1 id="install-proxyfors-certificate-authority">Install proxyfor’s
Certificate Authority</h1>
<head>
    <title>proxyfor</title>
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<style>
summary {
    display: flex;
    align-items: center;
}
summary * {
    margin: 0;
    padding: 0;
}

summary::-webkit-details-marker {
    display: none;
}

summary:before {
    content: '';
    display: inline-block;
    margin-right: 5px;
}
</style>
<details>
<summary>
<h2 id="windows">Windows</h2>
</summary>
<p><a
href="./proxyfor-ca-cert.cer">proxyfor-ca-cert.cer</a></p>
<h3 id="manual-installation">Manual Installation</h3>
<ol type="1">
<li>Double-click the CER file to start the import wizard.</li>
<li>Select a certificate store location. This determines who will trust
the certificate – only the current Windows user or everyone on the
machine. Click Next.</li>
<li>Click Next again.</li>
<li>Leave Password blank and click Next.</li>
<li>Select Place all certificates in the following
store, then click Browse, and select Trusted Root Certification
Authorities.<br />
Click OK and Next.</li>
<li>Click Finish.</li>
<li>Click Yes to confirm the warning dialog.</li>
</ol>
<h3 id="automated-installation">Automated Installation</h3>
<ol type="1">
<li>Run <code>certutil.exe -addstore root proxyfor-ca-cert.cer</code>
(<a
href="https://technet.microsoft.com/en-us/library/cc732443.aspx">details</a>).</li>
</ol>
</details>
<details>
<summary>
<h2 id="linux">Linux</h2>
</summary>
<p><a
href="./proxyfor-ca-cert.pem">proxyfor-ca-cert.pem</a></p>
<h3 id="ubuntudebian">Ubuntu/Debian</h3>
<ol type="1">
<li><code>mv proxyfor-ca-cert.pem /usr/local/share/ca-certificates/proxyfor.crt</code></li>
<li><code>sudo update-ca-certificates</code></li>
</ol>
<h3 id="fedora">Fedora</h3>
<ol type="1">
<li><code>mv proxyfor-ca-cert.pem /etc/pki/ca-trust/source/anchors/</code></li>
<li><code>sudo update-ca-trust</code></li>
</ol>
</details>
<details>
<summary>
<h2 id="macos">macOS</h2>
</summary>
<p><a
href="./proxyfor-ca-cert.pem">proxyfor-ca-cert.pem</a></p>
<h3 id="manual-installation-1">Manual Installation</h3>
<ol type="1">
<li>Double-click the PEM file to open the Keychain Access
application.</li>
<li>Locate the new certificate “proxyfor” in the list and double-click
it.</li>
<li>Change Secure Socket Layer (SSL) to Always Trust.</li>
<li>Close the dialog window and enter your password if prompted.</li>
</ol>
<h3 id="automated-installation-1">Automated Installation</h3>
<ol type="1">
<li><code>sudo security add-trusted-cert -d -p ssl -p basic -k /Library/Keychains/System.keychain proxyfor-ca-cert.pem</code></li>
</ol>
</details>
<details>
<summary>
<h2 id="ios">iOS</h2>
</summary>
<p><a
href="./proxyfor-ca-cert.pem">proxyfor-ca-cert.pem</a></p>
<h3 id="ios-13">iOS 13+</h3>
<ol type="1">
<li>Use Safari to download the certificate. Other browsers may not open
the proper installation prompt.</li>
<li>Install the new Profile (Settings -&gt; General -&gt; VPN &amp;
Device Management).</li>
<li><strong>Important: Go to Settings -&gt; General -&gt; About -&gt;
Certificate Trust Settings.</strong> Toggle proxyfor to ON.</li>
</ol>
</details>
<details>
<summary>
<h2 id="android">Android</h2>
</summary>
<p><a
href="./proxyfor-ca-cert.cer">proxyfor-ca-cert.cer</a></p>
<h3 id="android-10">Android 10+</h3>
<ol type="1">
<li>Open the downloaded CER file.</li>
<li>Enter proxyfor (or anything else) as the certificate name.</li>
<li>For credential use, select VPN and apps.</li>
<li>Click OK.</li>
</ol>
<p>Some Android distributions require you to install the certificate via
Settings -&gt; Security -&gt; Advanced -&gt; Encryption and credentials
-&gt; Install a certificate -&gt; CA certificate (or similar)
instead.</p>
<p><strong>Warning:</strong> Apps that target Android API Level 24
(introduced in 2016) and above only accept certificates from the system
trust store (<a
href="https://github.com/proxyfor/proxyfor/issues/2054">#2054</a>).
User-added CAs are not accepted unless the application manually opts in.
Except for browsers, you need to patch most apps manually (<a
href="https://developer.android.com/training/articles/security-config">Android
network security config</a>).</p>
<p>Alternatively, if you have rooted the device and have Magisk
installed, you can install <a href="/cert/magisk">this Magisk module</a>
via the Magisk Manager app.</p>
</details>
<details>
<summary>
<h2 id="firefox">Firefox</h2>
</summary>
<p><a
href="./proxyfor-ca-cert.pem">proxyfor-ca-cert.pem</a></p>
<h3 id="firefox-1">Firefox</h3>
<ol type="1">
<li>Open Options -&gt; Privacy &amp; Security and click View
Certificates… at the bottom of the page.</li>
<li>Click Import… and select the downloaded certificate.</li>
<li>Enable Trust this CA to identify websites and click OK.</li>
</ol>