diff --git a/AGHTechDoc.md b/AGHTechDoc.md
index 5e9fa0d5..5bae787a 100644
--- a/AGHTechDoc.md
+++ b/AGHTechDoc.md
@@ -830,6 +830,36 @@ Request:
"private_key_path":"..." // if set, private_key must be empty
}
+Response:
+
+ 200 OK
+
+### API: Validate TLS configuration
+
+Request:
+
+ POST /control/tls/validate
+
+ {
+ "enabled":true,
+ "port_https":443,
+ "port_dns_over_tls":853,
+ "port_dns_over_quic":784,
+ "allow_unencrypted_doh":false,
+ "certificate_chain":"...",
+ "private_key":"...",
+ "certificate_path":"...",
+ "private_key_path":"...",
+ "valid_cert":true,
+ "valid_chain":false,
+ "not_before":"2019-03-19T08:23:45Z",
+ "not_after":"2029-03-16T08:23:45Z",
+ "dns_names":null,
+ "valid_key":true,
+ "valid_pair":true
+ }
+
+
Response:
200 OK
@@ -1948,6 +1978,29 @@ Check if host name is blocked by SB/PC service:
sha256(sub.host.com)[0..1] -> hashes[2],...
...
+## API: Get DNS over HTTPS .mobileconfig
+
+Request:
+
+ GET /apple/doh.mobileconfig
+
+Response:
+
+ 200 OK
+
+ DOH plist file
+
+## API: Get DNS over TLS .mobileconfig
+
+Request:
+
+ GET /apple/dot.mobileconfig
+
+Response:
+
+ 200 OK
+
+ DOT plist file
## ipset
diff --git a/Makefile b/Makefile
index f83b45eb..121dcc91 100644
--- a/Makefile
+++ b/Makefile
@@ -56,10 +56,10 @@ ifeq ($(CHANNEL),edge)
endif
# goreleaser command depends on the $CHANNEL
-GORELEASER_COMMAND=goreleaser release --rm-dist --skip-publish --snapshot
+GORELEASER_COMMAND=goreleaser release --rm-dist --skip-publish --snapshot --parallelism 1
ifneq ($(CHANNEL),edge)
# If this is not an "edge" build, use normal release command
- GORELEASER_COMMAND=goreleaser release --rm-dist --skip-publish
+ GORELEASER_COMMAND=goreleaser release --rm-dist --skip-publish --parallelism 1
endif
# Version properties
diff --git a/README.md b/README.md
index 8f9805c3..addbf204 100644
--- a/README.md
+++ b/README.md
@@ -64,14 +64,29 @@ It operates as a DNS server that re-routes tracking domains to a "black hole," t
## Getting Started
-Please read the **[Getting Started](https://github.com/AdguardTeam/AdGuardHome/wiki/Getting-Started)** article on our Wiki to learn how to install AdGuard Home, and how to configure your devices to use it.
+### Automated install (Linux and Mac)
+Run the following command in your terminal:
+```
+curl -sSL https://raw.githubusercontent.com/AdguardTeam/AdGuardHome/master/scripts/install.sh | sh
+```
+
+### Alternative methods
+
+#### Manual installation
+
+Please read the **[Getting Started](https://github.com/AdguardTeam/AdGuardHome/wiki/Getting-Started)** article on our Wiki to learn how to install AdGuard Home manually, and how to configure your devices to use it.
+
+#### Docker
+
+You can use our [official Docker image](https://hub.docker.com/r/adguard/adguardhome).
+
+#### Snap Store
If you're running **Linux**, there's a secure and easy way to install AdGuard Home - you can get it from the [Snap Store](https://snapcraft.io/adguard-home).
-Alternatively, you can use our [official Docker image](https://hub.docker.com/r/adguard/adguardhome).
-
### Guides
+* [FAQ](https://github.com/AdguardTeam/AdGuardHome/wiki/FAQ)
* [Configuration](https://github.com/AdguardTeam/AdGuardHome/wiki/Configuration)
* [AdGuard Home as a DNS-over-HTTPS or DNS-over-TLS server](https://github.com/AdguardTeam/AdGuardHome/wiki/Encryption)
* [How to install and run AdGuard Home on Raspberry Pi](https://github.com/AdguardTeam/AdGuardHome/wiki/Raspberry-Pi)
@@ -228,13 +243,17 @@ There are three options how you can install an unstable version:
1. [Snap Store](https://snapcraft.io/adguard-home) -- look for "beta" and "edge" channels there.
2. [Docker Hub](https://hub.docker.com/r/adguard/adguardhome) -- look for "beta" and "edge" tags there.
-3. Standalone builds. Look for the available builds below.
+3. Standalone builds. Use the automated installation script or look for the available builds below.
-There are three options how you can install an unstable version.
+Beta:
+```
+curl -sSL https://raw.githubusercontent.com/AdguardTeam/AdGuardHome/master/scripts/install.sh | sh -s beta
+```
-1. You can either install AdGuard Home from "beta" or "edge" distribution channel which we update periodically. If you're already using stable version of AdGuard Home, just replace the executable file with a new one.
-2. You can use the Docker image from the `edge` tag, which is synced with the repo master branch.
-3. You can install AdGuard Home from `beta` or `edge` channels on the Snap Store.
+Edge:
+```
+curl -sSL https://raw.githubusercontent.com/AdguardTeam/AdGuardHome/master/scripts/install.sh | sh -s edge
+```
* Beta channel builds
* Linux: [64-bit](https://static.adguard.com/adguardhome/beta/AdGuardHome_linux_amd64.tar.gz), [32-bit](https://static.adguard.com/adguardhome/beta/AdGuardHome_linux_386.tar.gz)
diff --git a/client/src/__locales/en.json b/client/src/__locales/en.json
index 678dd39f..8f2eb5c9 100644
--- a/client/src/__locales/en.json
+++ b/client/src/__locales/en.json
@@ -249,6 +249,8 @@
"blocking_ipv6": "Blocking IPv6",
"dns_over_https": "DNS-over-HTTPS",
"dns_over_tls": "DNS-over-TLS",
+ "download_mobileconfig_doh": "Download .mobileconfig for DNS-over-HTTPS",
+ "download_mobileconfig_dot": "Download .mobileconfig for DNS-over-TLS",
"plain_dns": "Plain DNS",
"form_enter_rate_limit": "Enter rate limit",
"rate_limit": "Rate limit",
@@ -415,7 +417,8 @@
"dns_privacy": "DNS Privacy",
"setup_dns_privacy_1": "<0>DNS-over-TLS:0> Use <1>{{address}}1> string.",
"setup_dns_privacy_2": "<0>DNS-over-HTTPS:0> Use <1>{{address}}1> string.",
- "setup_dns_privacy_3": "<0>Please note that encrypted DNS protocols are supported only on Android 9. So you need to install additional software for other operating systems.0><0>Here's a list of software you can use.0>",
+ "setup_dns_privacy_3": "<0>Here's a list of software you can use.0>",
+ "setup_dns_privacy_4": "On an iOS 14 or MacOS Big Sur device you can download special '.mobileconfig' file that adds
text
,
+ ],
+ },
+ {
+ label: 'setup_dns_privacy_4',
+ components: {
+ highlight:
,
+ },
+ renderComponent: renderMobileconfigInfo,
+ },
{
label: 'setup_dns_privacy_ios_1',
components: [
@@ -51,16 +101,6 @@ const dnsPrivacyList = [{
],
},
- {
- label: 'setup_dns_privacy_ios_2',
- components: [
- {
- key: 0,
- href: 'https://adguard.com/adguard-ios/overview.html',
- },
- text
,
- ],
- },
],
},
{
@@ -116,26 +156,15 @@ const dnsPrivacyList = [{
},
];
-const renderDnsPrivacyList = ({ title, list }) =>