Skip to content

phpPgAdmin Docker image, phpPgAdmin is a web-based administration tool for PostgreSQL.

License

Notifications You must be signed in to change notification settings

snimshchikov/phppgadmin-docker

 
 

Repository files navigation

phpPgAdmin Docker Pulls Docker Stars Docker Automated build

phpPgAdmin is a web-based administration tool for PostgreSQL. It is perfect for PostgreSQL DBAs, newbies, and hosting services.

This repository is a fork

Improvements:

  • Latest phppgadmin by ReimuHakurei with support of postgres 15
  • PHP 8.1
  • Add multiple postgres servers
  • Better security

Contributing

If you find this image useful here's how you can help:

  • Send a pull request with your awesome features and bug fixes
  • Help users resolve their issues.

Issues

Before reporting your issue please try updating Docker to the latest version and check if it resolves the issue. Refer to the Docker installation guide for instructions.

SELinux users should try disabling SELinux using the command setenforce 0 to see if it resolves the issue.

If the above recommendations do not help then report your issue along with the following information:

  • Output of the docker vers6 and docker info commands
  • The docker run command or docker-compose.yml used to start the image. Mask out the sensitive bits.
  • Please state if you are using Boot2Docker, VirtualBox, etc.

Getting started

Installation

Pull the image from the docker index. This is the recommended method of installation as it is easier to update image. These builds are performed by the Docker Trusted Build service.

docker pull snimshchikov/phppgadmin:latest

Alternately you can build the image locally.

git clone https://github.com/snimshchikov/phppgadmin-docker.git
cd phppgadmin-docker
docker build --tag="$USER/phppgadmin" .

Quick Start

The quickest way to get started is using docker-compose.

wget https://raw.githubusercontent.com/snimshchikov/phppgadmin-docker/master/docker-compose.yml
docker-compose up

Alternately, you can manually launch the phppgadmin container.

docker run --name='phppgadmin' -d \
  --publish=80:80 \
snimshchikov/phppgadmin:latest

Available Configuration Parameters

Please refer the docker run command options for the --env-file flag where you can specify all required environment variables in a single file. This will save you from writing a potentially long docker run command. Alternatively you can use docker-compose.

Below is the complete list of available options that can be used to customize your phppgadmin installation.

Parameter Description
PHP_PG_ADMIN_SERVER_DESC Display name for the server on the login screen. Defaults to PostgreSQL.
PHP_PG_ADMIN_SERVER_HOST Hostname or IP address for server. Use '' for UNIX domain socket. Defaults to ``.
PHP_PG_ADMIN_SERVER_PORT Database port on server. Defaults to 5432.
PHP_PG_ADMIN_SERVER_SSL_MODE Database SSL mode. Possible options: disable, allow, prefer, require. To require SSL on older servers use option: legacy. To ignore the SSL mode, use option: unspecified. Defaults to allow
PHP_PG_ADMIN_SERVER_DEFAULT_DB Change the default database only if you cannot connect to 'postgres'. For servers with versions before PostgreSQL 8.1, you can set this to 'template1'. Defaults to postgres.
PHP_PG_ADMIN_SERVER_PG_DUMP_PATH Specify the path to the database dump utilities for this server. Defaults to /usr/bin/pg_dump.
PHP_PG_ADMIN_SERVER_PG_DUMPALL_PATH Specify the path to the database dump utilities for this server. Defaults to /usr/bin/pg_dumpall.
PHP_PG_ADMIN_DEFAULT_LANG Default language. E.g.: english, polish, etc. See lang directory for all possibilities. If you specify auto it will use your browser preference. Defaults to auto.
PHP_PG_ADMIN_AUTO_COMPLETE AutoComplete uses AJAX interaction to list foreign key values on insert fields. It currently only works on single column foreign keys. You can choose one of the following values: default on enables AutoComplete and turns it on by default. default off enables AutoComplete but turns it off by default. disable disables AutoComplete. Defaults to default on.
PHP_PG_ADMIN_EXTRA_LOGIN_SECURITY If extra login security is true, then logins via phpPgAdmin with no password or certain usernames (pgsql, postgres, root, administrator) will be denied. Only set this false once you have read the FAQ and understand how to change PostgreSQL's pg_hba.conf to enable passworded local connections. Defaults to true.
PPA_EXTRA_SESSION_SECURITY If extra session security is true, then PHP's session cookies will have SameSite cookie flags set to prevent CSRF attacks. Defaults to true.
PHP_PG_ADMIN_OWNED_ONLY Only show owned databases? Note: This will simply hide other databases in the list - this does not in any way prevent your users from seeing other database by other means. (e.g. Run SELECT * FROM pg_database in the SQL area.). Defaults to false.
PHP_PG_ADMIN_SHOW_COMMENTS Display comments on objects? Comments are a good way of documenting a database, but they do take up space in the interface. Defaults to true.
PHP_PG_ADMIN_SHOW_ADVANCED Display "advanced" objects? Setting this to true will show aggregates, types, operators, operator classes, conversions, languages and casts in phpPgAdmin. These objects are rarely administered and can clutter the interface. Defaults to false.
PHP_PG_ADMIN_SHOW_SYSTEM Display "system" objects? Defaults to false.
PHP_PG_ADMIN_MIN_PASSWORD_LENGTH Minimum length users can set their password to. Defaults to 10.
PPA_SHOW_REPORTS Display reports feature? Defaults to true.
PPA_REPORTS_DB Database for reports. Defaults to phppgadmin.
PPA_REPORTS_SCHEMA Reports schema. Defaults to public.
PPA_REPORTS_TABLE Table for reports. Defaults to ppa_reports.
PPA_OWNED_REPORTS_ONLY Only show owned reports? Note: This does not prevent people from accessing other reports by other means. Defaults to false.
PHP_PG_ADMIN_LEFT_WIDTH Width of the left frame in pixels (object browser). Defaults to 200.
PHP_PG_ADMIN_THEME Which look & feel theme to use. Defaults to default.
PHP_PG_ADMIN_SHOW_OIDS Show OIDs when browsing tables? Defaults to false.
PHP_PG_ADMIN_MAX_ROWS Max rows to show on a page when browsing record sets. Defaults to 50.
PHP_PG_ADMIN_MAX_CHARS Max chars of each field to display by default in browse mode. Defaults to 50.
PHP_PG_ADMIN_USE_XHTML_STRICT Send XHTML strict headers? Defaults to false.
PHP_PG_ADMIN_HELP_BASE Base URL for PostgreSQL documentation. '%s', if present, will be replaced with the PostgreSQL version (e.g. 8.4). Defaults to http://www.postgresql.org/docs/%s/interactive/.
PHP_PG_ADMIN_AJAX_REFRESH Configuration for ajax scripts. Time in seconds. If set to 0, refreshing data using ajax will be disabled (locks and activity pages). Defaults to 3.

Upgrading

To upgrade to newer phppgadmin releases, simply follow this 3 step upgrade procedure.

  • Step 1: Update the docker image.
docker pull snimshchikov/phppgadmin:latest
  • Step 2: Stop and remove the currently running image
docker stop phppgadmin
docker rm phppgadmin
  • Step 3: Start the image
docker run --name=phppgadmin -d [OPTIONS] snimshchikov/phppgadmin:latest

Quick reference

About

phpPgAdmin Docker image, phpPgAdmin is a web-based administration tool for PostgreSQL.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • PHP 67.5%
  • Shell 21.7%
  • Dockerfile 10.8%