| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | # pgAdmin 4 
 | 
					
						
							| 
									
										
										
										
											2013-06-16 14:17:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | pgAdmin 4 is a rewrite of the popular pgAdmin3 management tool for the | 
					
						
							|  |  |  | PostgreSQL (http://www.postgresql.org) database.  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | In the following documentation and examples, *$PGADMIN4_SRC/* is used to denote | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | the top-level directory of a copy of the pgAdmin source tree, either from a | 
					
						
							|  |  |  | tarball or a git checkout. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | ## Architecture
 | 
					
						
							| 
									
										
										
										
											2013-06-16 14:17:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | pgAdmin 4 is written as a web application in Python, using jQuery and Bootstrap | 
					
						
							|  |  |  | for the client side processing and UI. On the server side, Flask is being | 
					
						
							|  |  |  | utilised. | 
					
						
							| 
									
										
										
										
											2013-06-16 14:17:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | Although developed using web technologies, pgAdmin 4 can be deployed either on | 
					
						
							|  |  |  | a web server using a browser, or standalone on a workstation. The runtime/ | 
					
						
							| 
									
										
										
										
											2021-01-29 13:38:27 +05:30
										 |  |  | subdirectory contains an NWjs based runtime application intended to allow this, | 
					
						
							|  |  |  | which will execute the Python server and display the UI. | 
					
						
							| 
									
										
										
										
											2013-06-16 14:17:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | ## Building the Runtime
 | 
					
						
							| 
									
										
										
										
											2013-06-16 14:17:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | To build the runtime, the following packages must be installed: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | * NodeJS 12+ | 
					
						
							|  |  |  | * Yarn | 
					
						
							| 
									
										
										
										
											2013-06-16 14:17:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | Change into the runtime directory, and run *yarn install*. This will install the | 
					
						
							| 
									
										
										
										
											2021-01-29 13:38:27 +05:30
										 |  |  | dependencies required. | 
					
						
							| 
									
										
										
										
											2020-05-04 10:20:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-29 13:38:27 +05:30
										 |  |  | In order to use the runtime in a development environment, you'll need to copy | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | *dev_config.json.in* file to *dev_config.json*, and edit the paths to the Python | 
					
						
							|  |  |  | executable and *pgAdmin.py* file, otherwise the runtime will use the default | 
					
						
							| 
									
										
										
										
											2021-01-29 13:38:27 +05:30
										 |  |  | paths it would expect to find in the standard package for your platform. | 
					
						
							| 
									
										
										
										
											2020-05-04 10:20:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-29 13:38:27 +05:30
										 |  |  | You can then execute the runtime by running something like: | 
					
						
							| 
									
										
										
										
											2020-05-04 10:20:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | ```bash | 
					
						
							|  |  |  | node_modules/nw/nwjs/nw . | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2020-05-04 10:20:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-29 13:38:27 +05:30
										 |  |  | or on macOS: | 
					
						
							| 
									
										
										
										
											2016-05-19 09:33:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | ```bash | 
					
						
							|  |  |  | node_modules/nw/nwjs/nwjs.app/Contents/MacOS/nwjs . | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2017-04-24 08:36:55 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | # Configuring the Python Environment
 | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-09 12:53:44 +00:00
										 |  |  | In order to run the Python code, a suitable runtime environment is required. | 
					
						
							| 
									
										
										
										
											2021-03-08 11:33:00 +00:00
										 |  |  | Python version 3.6 and later are currently supported. It is recommended that a | 
					
						
							| 
									
										
										
										
											2020-04-30 14:17:00 +05:30
										 |  |  | Python Virtual Environment is setup for this purpose, rather than using the | 
					
						
							|  |  |  | system Python environment. On Linux and Mac systems, the process is fairly | 
					
						
							|  |  |  | simple - adapt as required for your distribution: | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | 1. Create a virtual environment in an appropriate directory. The last argument is | 
					
						
							|  |  |  |    the name of the environment; that can be changed as desired: | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  |    ```bash | 
					
						
							|  |  |  |    $ python3 -m venv venv | 
					
						
							|  |  |  |    ``` | 
					
						
							|  |  |  |     | 
					
						
							|  |  |  | 2. Now activate the virtual environment: | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  |    ```bash | 
					
						
							|  |  |  |    $ source venv/bin/activate | 
					
						
							|  |  |  |    ``` | 
					
						
							|  |  |  |     | 
					
						
							|  |  |  | 3. Some of the components used by pgAdmin require a very recent version of *pip*, | 
					
						
							|  |  |  |    so update that to the latest: | 
					
						
							|  |  |  |     | 
					
						
							|  |  |  |    ```bash | 
					
						
							|  |  |  |    $ pip install --upgrade pip | 
					
						
							|  |  |  |    ``` | 
					
						
							|  |  |  |     | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | 4. Ensure that a PostgreSQL installation's bin/ directory is in the path (so | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  |    pg_config can be found for building psycopg2), and install the required | 
					
						
							|  |  |  |    packages: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  |    ```bash | 
					
						
							|  |  |  |    (venv) $ PATH=$PATH:/usr/local/pgsql/bin pip install -r $PGADMIN4_SRC/requirements.txt | 
					
						
							|  |  |  |    ``` | 
					
						
							|  |  |  |     | 
					
						
							| 
									
										
										
										
											2017-02-26 09:06:17 +00:00
										 |  |  |    If you are planning to run the regression tests, you also need to install | 
					
						
							|  |  |  |    additional requirements from web/regression/requirements.txt: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  |    ```bash | 
					
						
							|  |  |  |    (venv) $ pip install -r $PGADMIN4_SRC/web/regression/requirements.txt | 
					
						
							|  |  |  |    ``` | 
					
						
							|  |  |  |     | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | 5. Create a local configuration file for pgAdmin. Edit | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  |    $PGADMIN4_SRC/web/config_local.py and add any desired configuration options | 
					
						
							|  |  |  |    (use the config.py file as a reference - any settings duplicated in | 
					
						
							|  |  |  |    config_local.py will override those in config.py). A typical development | 
					
						
							|  |  |  |    configuration may look like: | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  |     | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  |     ```python | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  |     from config import * | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Debug mode | 
					
						
							|  |  |  |     DEBUG = True | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # App mode | 
					
						
							|  |  |  |     SERVER_MODE = True | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Enable the test module | 
					
						
							|  |  |  |     MODULE_BLACKLIST.remove('test') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Log | 
					
						
							|  |  |  |     CONSOLE_LOG_LEVEL = DEBUG | 
					
						
							|  |  |  |     FILE_LOG_LEVEL = DEBUG | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     DEFAULT_SERVER = '127.0.0.1' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     UPGRADE_CHECK_ENABLED = True | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Use a different config DB for each server mode. | 
					
						
							|  |  |  |     if SERVER_MODE == False: | 
					
						
							|  |  |  |         SQLITE_PATH = os.path.join( | 
					
						
							|  |  |  |             DATA_DIR, | 
					
						
							|  |  |  |             'pgadmin4-desktop.db' | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |     else: | 
					
						
							|  |  |  |         SQLITE_PATH = os.path.join( | 
					
						
							|  |  |  |             DATA_DIR, | 
					
						
							|  |  |  |             'pgadmin4-server.db' | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  |    ``` | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  |     | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  |    This configuration allows easy switching between server and desktop modes | 
					
						
							|  |  |  |    for testing. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | 6. The initial setup of the configuration database is interactive in server | 
					
						
							|  |  |  |    mode, and non-interactive in desktop mode. You can run it either by | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  |    running: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  |    ```bash | 
					
						
							|  |  |  |    (venv) $ python3 $PGADMIN4_SRC/web/setup.py | 
					
						
							|  |  |  |    ``` | 
					
						
							|  |  |  |     | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  |    or by starting pgAdmin 4: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  |    ```bash | 
					
						
							|  |  |  |    (venv) $ python3 $PGADMIN4_SRC/web/pgAdmin4.py | 
					
						
							|  |  |  |    ``` | 
					
						
							|  |  |  |     | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  |    Whilst it is possible to automatically run setup in desktop mode by running | 
					
						
							|  |  |  |    the runtime, that will not work in server mode as the runtime doesn't allow | 
					
						
							|  |  |  |    command line interaction with the setup program. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | At this point you will be able to run pgAdmin 4 from the command line in either | 
					
						
							|  |  |  | server or desktop mode, and access it from a web browser using the URL shown in | 
					
						
							|  |  |  | the terminal once pgAdmin has started up. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Setup of an environment on Windows is somewhat more complicated unfortunately, | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | please see *pkg/win32/README.txt* for complete details. | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | # Building the Web Assets
 | 
					
						
							| 
									
										
										
										
											2017-12-01 15:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | pgAdmin is dependent on a number of third party Javascript libraries. These, | 
					
						
							|  |  |  | along with it's own Javascript code, SCSS/CSS code and images must be | 
					
						
							|  |  |  | compiled into a "bundle" which is transferred to the browser for execution | 
					
						
							|  |  |  | and rendering. This is far more efficient than simply requesting each | 
					
						
							|  |  |  | asset as it's needed by the client. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | To create the bundle, you will need the 'yarn' package management tool to be | 
					
						
							|  |  |  | installed. Then, you can run the following commands on a *nix system to | 
					
						
							|  |  |  | download the required packages and build the bundle: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | ```bash | 
					
						
							|  |  |  | (venv) $ cd $PGADMIN4_SRC | 
					
						
							|  |  |  | (venv) $ make install-node | 
					
						
							|  |  |  | (venv) $ make bundle | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2017-12-01 15:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | On Windows systems (where "make" is not available), the following commands | 
					
						
							| 
									
										
										
										
											2017-12-01 15:01:15 +00:00
										 |  |  | can be used: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | ``` | 
					
						
							|  |  |  | C:\> cd $PGADMIN4_SRC\web | 
					
						
							|  |  |  | C:\$PGADMIN4_SRC\web> yarn install | 
					
						
							|  |  |  | C:\$PGADMIN4_SRC\web> yarn run bundle | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2017-12-01 15:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | # Creating pgAdmin themes
 | 
					
						
							| 
									
										
										
										
											2019-11-07 18:51:03 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 14:13:22 +00:00
										 |  |  | To create a pgAdmin theme, you need to create a directory under | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | *web/pgadmin/static/scss/resources*. | 
					
						
							|  |  |  | Copy the sample file *_theme.variables.scss.sample* to the new directory and | 
					
						
							|  |  |  | rename it to *_theme.variables.scss*. Change the desired hexadecimal values of | 
					
						
							| 
									
										
										
										
											2019-11-07 14:13:22 +00:00
										 |  |  | the colors and bundle pgAdmin. You can also add a preview image in the theme | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | directory with the name as *\<dir name>_preview.png*. It is recommended that the | 
					
						
							| 
									
										
										
										
											2019-11-07 14:13:22 +00:00
										 |  |  | preview image should not be larger in size as it may take time to load on slow | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | networks. Run the *yarn run bundle* and you're good to go. No other changes are | 
					
						
							| 
									
										
										
										
											2019-11-07 14:13:22 +00:00
										 |  |  | required, pgAdmin bundle will read the directory and create other required | 
					
						
							|  |  |  | entries to make them available in preferences. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The name of the theme is derived from the directory name. Underscores (_) and | 
					
						
							|  |  |  | hyphens (-) will be replaced with spaces and the result will be camel cased. | 
					
						
							| 
									
										
										
										
											2019-11-07 18:51:03 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | # Building the documentation
 | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | In order to build the docs, an additional Python package is required in the | 
					
						
							|  |  |  | virtual environment. This can be installed with the pip package manager: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | ```bash | 
					
						
							|  |  |  | $ source venv/bin/activate | 
					
						
							|  |  |  | (venv) $ pip install Sphinx | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | The docs can then be built using the Makefile in *$PGADMIN4_SRC*, e.g. | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | ```bash | 
					
						
							|  |  |  | (venv) $ make docs | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | The output can be found in *$PGADMIN4_SRC/docs/en_US/_build/html/index.html* | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | # Building packages
 | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | Most packages can be built using the Makefile in $PGADMIN4_SRC, provided all | 
					
						
							|  |  |  | the setup and configuration above has been completed. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | To build a source tarball: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | ```bash | 
					
						
							|  |  |  | (venv) $ make src | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | To build a PIP Wheel, activate either a Python 3 virtual environment, configured  | 
					
						
							|  |  |  | with all the required packages, and then run: | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | ```bash | 
					
						
							|  |  |  | (venv) $ make pip | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | To build the macOS AppBundle, please see *pkg/mac/README*. | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:18:50 +00:00
										 |  |  | To build the Windows installer, please see *pkg/win32/README.txt*. | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | # Create Database Migrations
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | In order to make changes to the SQLite DB, navigate to the 'web' directory: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```bash | 
					
						
							|  |  |  | (venv) $ cd $PGADMIN4_SRC/web | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Create a migration file with the following command: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```bash | 
					
						
							|  |  |  | (venv) $ FLASK_APP=pgAdmin4.py flask db revision | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This will create a file in: $PGADMIN4_SRC/web/migrations/versions/ . | 
					
						
							|  |  |  | Add any changes to the 'upgrade' function. | 
					
						
							|  |  |  | Increment the SCHEMA_VERSION in $PGADMIN4_SRC/web/pgadmin/model/__init__.py file. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | There is no need to increment the SETTINGS_SCHEMA_VERSION. | 
					
						
							| 
									
										
										
										
											2016-10-26 12:40:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | # Support
 | 
					
						
							| 
									
										
										
										
											2013-06-16 14:17:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-27 12:41:29 +01:00
										 |  |  | See https://www.pgadmin.org/support/ for support options. | 
					
						
							| 
									
										
										
										
											2013-06-16 14:17:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-19 13:48:06 +01:00
										 |  |  | # Project info
 | 
					
						
							| 
									
										
										
										
											2013-06-16 14:17:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | The source code repository can be found here: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | http://git.postgresql.org/gitweb/?p=pgadmin4.git;a=summary | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | A Redmine project for pgAdmin 4 can be found at the address below. A PostgreSQL | 
					
						
							|  |  |  | community account is required to access this site. Please note that at present | 
					
						
							|  |  |  | only project developers can log bug and feature requests: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | https://redmine.postgresql.org/projects/pgadmin4 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If you wish to discuss pgAdmin 4, or contribute to the project, please use the | 
					
						
							|  |  |  | pgAdmin Hackers mailing list: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | pgadmin-hackers@postgresql.org |