AdGuard Home Scripts
hooks/
: Git Hooks
Usage
Run make init
from the project root.
querylog/
: Query Log Helpers
Usage
npm install
: install dependencies. Run this first.
npm run anonymize <source> <dst>
: read the query log from the <source>
and write anonymized version to <dst>
.
make/
: Makefile Scripts
The release channels are: development
(the default), edge
, beta
, and
release
. If verbosity levels aren't documented here, there are only two: 0
,
don't print anything, and 1
, be verbose.
build-docker.sh
: Build A Multi-Architecture Docker Image
Required environment:
CHANNEL
: release channel, see above.
COMMIT
: current Git revision.
DIST_DIR
: the directory where a release has previously been built.
VERSION
: release version.
Optional environment:
DOCKER_IMAGE_NAME
: the name of the resulting Docker container. By default
it's adguardhome-dev
.
DOCKER_OUTPUT
: the --output
parameters. By default they are
type=image,name=${DOCKER_IMAGE_NAME},push=false
.
SUDO
: allow users to use sudo
or doas
with docker
. By default none
is used.
Required environment:
CHANNEL
: release channel, see above.
GPG_KEY
and GPG_KEY_PASSPHRASE
: data for gpg
. Only required if SIGN
is 1
.
Optional environment:
clean.sh
: Cleanup
Optional environment:
GO
: set an alternative name for the Go compiler.
Required environment:
DIST_DIR
: the directory where a release has previously been built.
go-build.sh
: Build The Backend
Optional environment:
GOARM
: ARM processor options for the Go compiler.
GOMIPS
: ARM processor options for the Go compiler.
GO
: set an alternative name for the Go compiler.
OUT
: output binary name.
PARALLELISM
: set the maximum number of concurrently run build commands
(that is, compiler, linker, etc.).
SOURCE_DATE_EPOCH
: the standardized environment variable for the
Unix epoch time of the latest commit in the repository. If set, overrides
the default obtained from Git. Useful for reproducible builds.
VERBOSE
: verbosity level. 1
shows every command that is run and every
Go package that is processed. 2
also shows subcommands and environment.
The default value is 0
, don't be verbose.
VERSION
: release version. Will be set by version.sh
if it is unset or
if it has the default Makefile
value of v0.0.0
.
Required environment:
CHANNEL
: release channel, see above.
go-deps.sh
: Install Backend Dependencies
Optional environment:
GO
: set an alternative name for the Go compiler.
VERBOSE
: verbosity level. 1
shows every command that is run and every
Go package that is processed. 2
also shows subcommands and environment.
The default value is 0
, don't be verbose.
go-lint.sh
: Run Backend Static Analyzers
Don't forget to run make go-tools
once first!
Optional environment:
EXIT_ON_ERROR
: if set to 0
, don't exit the script after the first
encountered error. The default value is 1
.
GO
: set an alternative name for the Go compiler.
VERBOSE
: verbosity level. 1
shows every command that is run. 2
also
shows subcommands. The default value is 0
, don't be verbose.
go-test.sh
: Run Backend Tests
Optional environment:
GO
: set an alternative name for the Go compiler.
RACE
: set to 0
to not use the Go race detector. The default value is
1
, use the race detector.
TIMEOUT_FLAGS
: set timeout flags for tests. The default value is
--timeout 30s
.
VERBOSE
: verbosity level. 1
shows every command that is run and every
Go package that is processed. 2
also shows subcommands. The default
value is 0
, don't be verbose.
Installs the Go static analysis and other tools into ${PWD}/bin
. Either add
${PWD}/bin
to your $PATH
before all other entries, or use the commands
directly, or use the commands through make
(for example, make go-lint
).
Optional environment:
GO
: set an alternative name for the Go compiler.
version.sh
: Generate And Print The Current Version
Required environment:
CHANNEL
: release channel, see above.
snap/
: Snap GUI Files
App icons (see https://github.com/AdguardTeam/AdGuardHome/pull/1836), Snap
manifest file templates, and helper scripts.
translations/
: Twosky Integration Script
Usage
-
go run main.go help
: print usage.
-
go run main.go download [-n <count>]
: download and save all translations.
n
is optional flag where count is a number of concurrent downloads.
-
go run main.go upload
: upload the base en
locale.
-
go run main.go summary
: show the current locales summary.
-
go run main.go unused
: show the list of unused strings.
-
go run main.go auto-add
: add locales with additions to the git and
restore locales with deletions.
After the download you'll find the output locales in the client/src/__locales/
directory.
Optional environment:
-
UPLOAD_LANGUAGE
: set an alternative language for upload
.
-
TWOSKY_URI
: set an alternative URL for download
or upload
.
-
TWOSKY_PROJECT_ID
: set an alternative project ID for download
or
upload
.
companiesdb/
: Whotracks.me Database Converter
A simple script that downloads and updates the companies DB in the client
code from the repo.
Usage
sh ./scripts/companiesdb/download.sh
blocked-services/
: Blocked Services Updater
A simple script that downloads and updates the blocked services index from
AdGuard's Hostlists Registry.
Optional environment:
URL
: the URL of the index file. By default it's
https://adguardteam.github.io/HostlistsRegistry/assets/services.json
.
Usage
go run ./scripts/blocked-services/main.go
vetted-filters/
: Vetted Filters Updater
Similar to the one above, a script that downloads and updates the vetted
filtering list data from AdGuard's Hostlists Registry.
Optional environment:
URL
: the URL of the index file. By default it's
https://adguardteam.github.io/HostlistsRegistry/assets/filters.json
.
Usage
go run ./scripts/vetted-filters/main.go