2018-10-15 14:20:57 +00:00
< p align = "center" >
< img src = "https://cdn.adguard.com/public/Adguard/Common/adguard_home.svg" width = "300px" alt = "AdGuard Home" / >
< / p >
< h3 align = "center" > Privacy protection center for you and your devices< / h3 >
< p align = "center" >
Free and open source, powerful network-wide ads & trackers blocking DNS server.
< / p >
< p align = "center" >
< a href = "https://adguard.com/" > AdGuard.com< / a > |
< a href = "https://github.com/AdguardTeam/AdGuardHome/wiki" > Wiki< / a > |
< a href = "https://reddit.com/r/Adguard" > Reddit< / a > |
2019-01-25 09:55:13 +00:00
< a href = "https://twitter.com/AdGuard" > Twitter< / a > |
< a href = "https://t.me/adguard_en" > Telegram< / a >
2018-10-15 14:20:57 +00:00
< br / > < br / >
< a href = "https://travis-ci.org/AdguardTeam/AdGuardHome" >
< img src = "https://travis-ci.org/AdguardTeam/AdGuardHome.svg" alt = "Build status" / >
< / a >
2019-01-25 09:55:13 +00:00
< a href = "https://codecov.io/github/AdguardTeam/AdGuardHome?branch=master" >
< img src = "https://img.shields.io/codecov/c/github/AdguardTeam/AdGuardHome/master.svg" alt = "Code Coverage" / >
< / a >
< a href = "https://goreportcard.com/report/AdguardTeam/AdGuardHome" >
< img src = "https://goreportcard.com/badge/github.com/AdguardTeam/AdGuardHome" alt = "Go Report Card" / >
< / a >
2019-01-25 19:23:09 +00:00
< a href = "https://golangci.com/r/github.com/AdguardTeam/AdGuardHome" >
< img src = "https://golangci.com/badges/github.com/AdguardTeam/AdGuardHome.svg" alt = "GolangCI" / >
< / a >
2018-10-15 14:20:57 +00:00
< a href = "https://github.com/AdguardTeam/AdGuardHome/releases" >
2018-10-15 19:04:38 +00:00
< img src = "https://img.shields.io/github/release/AdguardTeam/AdGuardHome/all.svg" alt = "Latest release" / >
2018-10-15 14:20:57 +00:00
< / a >
< / p >
< br / >
< p align = "center" >
< img src = "https://cdn.adguard.com/public/Adguard/Common/adguard_home.gif" width = "800" / >
< / p >
< hr / >
2018-08-30 15:16:37 +00:00
2018-10-15 14:20:57 +00:00
AdGuard Home is a network-wide software for blocking ads & tracking. After you set it up, it'll cover ALL your home devices, and you don't need any client-side software for that.
2018-08-30 14:25:33 +00:00
2019-02-24 15:42:44 +00:00
It operates as a DNS server that re-routes tracking domains to a "black hole," thus preventing your devices from connecting to those servers. It's based on software we use for our public [AdGuard DNS ](https://adguard.com/en/adguard-dns/overview.html ) servers -- both share a lot of common code.
2018-08-30 14:25:33 +00:00
2019-02-24 15:42:44 +00:00
* [Getting Started ](#getting-started )
* [How to build from source ](#how-to-build )
* [Contributing ](#contributing )
* [Reporting issues ](#reporting-issues )
* [Acknowledgments ](#acknowledgments )
2018-08-30 14:25:33 +00:00
2019-02-24 15:42:44 +00:00
< a id = "getting-started" > < / a >
## Getting Started
2019-02-05 11:09:05 +00:00
2019-02-24 15:42:44 +00:00
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.
2018-08-30 14:25:33 +00:00
2019-02-24 17:13:58 +00:00
Alternatively, you can use our [official Docker image ](https://hub.docker.com/r/adguard/adguardhome ).
### Guides
* [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 )
* [How to install and run AdGuard Home on a Virtual Private Server ](https://github.com/AdguardTeam/AdGuardHome/wiki/VPS )
2018-09-19 12:51:28 +00:00
2019-02-24 15:42:44 +00:00
< a id = "how-to-build" > < / a >
2018-09-20 15:15:52 +00:00
## How to build from source
2018-09-20 12:03:34 +00:00
### Prerequisites
You will need:
2018-09-20 15:15:52 +00:00
2019-02-26 12:32:56 +00:00
* [go ](https://golang.org/dl/ ) v1.12 or later.
2019-01-30 12:05:19 +00:00
* [node.js ](https://nodejs.org/en/download/ ) v10 or later.
2018-09-20 12:03:34 +00:00
2018-09-20 15:15:52 +00:00
You can either install it via the provided links or use [brew.sh ](https://brew.sh/ ) if you're on Mac:
2018-09-20 12:03:34 +00:00
```bash
brew install go node
```
### Building
2018-09-20 15:15:52 +00:00
2018-09-20 12:03:34 +00:00
Open Terminal and execute these commands:
2018-09-20 15:15:52 +00:00
2018-09-20 12:03:34 +00:00
```bash
2018-10-15 13:02:19 +00:00
git clone https://github.com/AdguardTeam/AdGuardHome
cd AdGuardHome
2018-09-20 12:03:34 +00:00
make
```
2019-02-24 15:42:44 +00:00
< a id = "contributing" > < / a >
2018-12-05 13:25:33 +00:00
## Contributing
You are welcome to fork this repository, make your changes and submit a pull request — https://github.com/AdguardTeam/AdGuardHome/pulls
### How to update translations
If you want to help with AdGuard Home translations, please learn more about translating AdGuard products here: https://kb.adguard.com/en/general/adguard-translations
Here is a direct link to AdGuard Home project: http://translate.adguard.com/collaboration/project?id=153384
2018-11-19 16:23:57 +00:00
Before updating translations you need to install dependencies:
```
cd scripts/translations
npm install
```
Create file `oneskyapp.json` in `scripts/translations` folder.
Example of `oneskyapp.json`
```
{
"url": "https://platform.api.onesky.io/1/projects/",
"projectId": < PROJECT ID > ,
"apiKey": < API KEY > ,
"secretKey": < SECRET KEY >
}
```
#### Upload translations
```
node upload.js
```
#### Download translations
```
node download.js
```
2019-02-24 15:42:44 +00:00
< a id = "reporting-issues" > < / a >
2018-08-30 14:25:33 +00:00
## Reporting issues
2018-10-15 13:02:19 +00:00
If you run into any problem or have a suggestion, head to [this page ](https://github.com/AdguardTeam/AdGuardHome/issues ) and click on the `New issue` button.
2018-10-15 19:04:38 +00:00
2019-02-24 15:42:44 +00:00
< a id = "acknowledgments" > < / a >
2018-10-15 19:04:38 +00:00
## Acknowledgments
This software wouldn't have been possible without:
* [Go ](https://golang.org/dl/ ) and it's libraries:
* [packr ](https://github.com/gobuffalo/packr )
* [gcache ](https://github.com/bluele/gcache )
* [miekg's dns ](https://github.com/miekg/dns )
* [go-yaml ](https://github.com/go-yaml/yaml )
2019-02-04 10:57:35 +00:00
* [service ](https://godoc.org/github.com/kardianos/service )
2019-02-24 15:42:44 +00:00
* [dnsproxy ](https://github.com/AdguardTeam/dnsproxy )
2018-10-15 19:04:38 +00:00
* [Node.js ](https://nodejs.org/ ) and it's libraries:
* [React.js ](https://reactjs.org )
* [Tabler ](https://github.com/tabler/tabler )
* And many more node.js packages.
2018-10-15 19:21:42 +00:00
* [whotracks.me data ](https://github.com/cliqz-oss/whotracks.me )
2018-10-15 19:04:38 +00:00
2018-12-06 14:17:42 +00:00
You might have seen that [CoreDNS ](https://coredns.io ) was mentioned here before — we've stopped using it in AdGuardHome. While we still use it on our servers for [AdGuard DNS ](https://adguard.com/adguard-dns/overview.html ) service, it seemed like an overkill for Home as it impeded with Home features that we plan to implement.
2018-12-05 13:25:33 +00:00
2018-10-15 19:04:38 +00:00
For a full list of all node.js packages in use, please take a look at [client/package.json ](https://github.com/AdguardTeam/AdGuardHome/blob/master/client/package.json ) file.