2015-12-13 17:46:24 +07:00
# PowerDNS-Admin
2018-04-01 16:07:41 +07:00
A PowerDNS web interface with advanced features.
2018-09-07 14:58:16 +07:00
2022-04-11 12:21:34 +03:00
[![Language grade: Python ](https://img.shields.io/lgtm/grade/python/g/PowerDNS-Admin/PowerDNS-Admin.svg?logo=lgtm&logoWidth=18 )](https://lgtm.com/projects/g/PowerDNS-Admin/PowerDNS-Admin/context:python)
[![Language grade: JavaScript ](https://img.shields.io/lgtm/grade/javascript/g/PowerDNS-Admin/PowerDNS-Admin.svg?logo=lgtm&logoWidth=18 )](https://lgtm.com/projects/g/PowerDNS-Admin/PowerDNS-Admin/context:javascript)
2015-12-13 17:46:24 +07:00
2015-12-13 18:07:10 +07:00
#### Features:
2015-12-13 18:07:59 +07:00
- Multiple domain management
2018-04-01 16:07:41 +07:00
- Domain template
2015-12-13 18:07:10 +07:00
- User management
2016-05-27 00:03:59 -06:00
- User access management based on domain
2015-12-13 18:07:10 +07:00
- User activity logging
2018-10-26 08:43:25 +07:00
- Support Local DB / SAML / LDAP / Active Directory user authentication
2019-12-05 13:52:30 +13:00
- Support Google / Github / Azure / OpenID OAuth
2018-04-01 16:07:41 +07:00
- Support Two-factor authentication (TOTP)
2015-12-13 18:07:10 +07:00
- Dashboard and pdns service statistics
2016-06-21 16:22:02 -06:00
- DynDNS 2 protocol support
2016-08-19 23:28:59 +00:00
- Edit IPv6 PTRs using IPv6 addresses directly (no more editing of literal addresses!)
2019-12-08 18:23:36 +07:00
- Limited API for manipulating zones and records
2021-03-16 14:37:05 -04:00
- Full IDN/Punycode support
2015-12-13 18:07:10 +07:00
2020-04-20 18:23:57 -04:00
## Running PowerDNS-Admin
There are several ways to run PowerDNS-Admin. The easiest way is to use Docker.
2022-04-11 12:21:34 +03:00
If you are looking to install and run PowerDNS-Admin directly onto your system check out the [Wiki ](https://github.com/PowerDNS-Admin/PowerDNS-Admin/wiki#installation-guides ) for ways to do that.
2020-04-20 18:23:57 -04:00
### Docker
This are two options to run PowerDNS-Admin using Docker.
To get started as quickly as possible try option 1. If you want to make modifications to the configuration option 2 may be cleaner.
#### Option 1: From Docker Hub
The easiest is to just run the latest Docker image from Docker Hub:
```
$ docker run -d \
2021-05-07 23:40:54 +02:00
-e SECRET_KEY='a-very-secret-key' \
2020-09-16 08:43:41 +02:00
-v pda-data:/data \
2020-04-20 18:23:57 -04:00
-p 9191:80 \
ngoduykhanh/powerdns-admin:latest
```
This creates a volume called `pda-data` to persist the SQLite database with the configuration.
#### Option 2: Using docker-compose
2021-05-07 23:40:54 +02:00
1. Update the configuration
2020-04-20 18:23:57 -04:00
Edit the `docker-compose.yml` file to update the database connection string in `SQLALCHEMY_DATABASE_URI` .
2022-04-11 12:21:34 +03:00
Other environment variables are mentioned in the [legal_envvars ](https://github.com/PowerDNS-Admin/PowerDNS-Admin/blob/master/configs/docker_config.py#L5-L46 ).
2021-05-07 23:40:54 +02:00
To use the Docker secrets feature it is possible to append `_FILE` to the environment variables and point to a file with the values stored in it.
Make sure to set the environment variable `SECRET_KEY` to a long random string (https://flask.palletsprojects.com/en/1.1.x/config/#SECRET_KEY )
2020-04-20 18:23:57 -04:00
2. Start docker container
```
$ docker-compose up
```
You can then access PowerDNS-Admin by pointing your browser to http://localhost:9191.
## Screenshots
2018-08-14 09:36:26 +07:00
![dashboard ](https://user-images.githubusercontent.com/6447444/44068603-0d2d81f6-9fa5-11e8-83af-14e2ad79e370.png )
2020-05-17 14:37:15 +07:00
## LICENSE
2022-04-11 12:21:34 +03:00
MIT. See [LICENSE ](https://github.com/PowerDNS-Admin/PowerDNS-Admin/blob/master/LICENSE )
2020-05-17 14:37:15 +07:00