This extension is built to represent a basic information about the running CKAN Application accessible only to admins.
On CKAN admin page /ckan-admin/selfinfo
, admin can see such information as:
- System Information
- System name
- Python version
- RAM
- RAM Usage in %
- RAM Usage in GB
- Disk Space
- Path
- Disk Usage in %
- Disk Total
- Disk Free
- CKAN Information
- Site Title
- CKAN Version
- Default Language
- Extensions that enabled on the portal
- GIT Information (Optional, see Config Settings section)
- Project
- Head
- Based on
- Commit
- Remotes
- PIP Freeze
- List of modules that are installed.
- Python Information
- Provides information about CKAN Core, CKAN Extensions, Python installed packages. It shows their current version and latest version.
Having CKAN Core version 2.10+
Installing the packages mentioned in requirements.txt
file.
To install ckanext-selfinfo:
-
Activate your CKAN virtual environment, for example:
. /usr/lib/ckan/default/bin/activate
-
Clone the source and install it on the virtualenv
git clone https://github.com//ckanext-selfinfo.git cd ckanext-selfinfo pip install -e .
-
Add
selfinfo
to theckan.plugins
setting in your CKAN config file (by default the config file is located at/etc/ckan/default/ckan.ini
). -
Restart CKAN. For example if you've deployed CKAN with Apache on Ubuntu:
sudo service apache2 reload
To install ckanext-selfinfo for development, activate your CKAN virtualenv and do:
git clone https://github.com//ckanext-selfinfo.git
cd ckanext-selfinfo
python setup.py develop
ckan.selfinfo.ckan_repos_path
- Path to the src folder where CKAN and CKAN Extensions stored at the environment. While provided, additional GIT Infromation will be granted. Make sure that there no other folders and files that are not related to CKAN are stored there. Example: /usr/lib/ckan/default/src
ckan.selfinfo.ckan_repos
- List of CKAN Extension folders separated by space (ckanext-scheming ckanext-spatial ckanext-xloader). By default, if ckan.selfinfo.ckan_repos_path
is provided, it will look into the directory and gather the extensions from there. Make sure to read the Note under this options before adding it, as it may cause 500 error, if not configured right.
For Linux, keep in mind that the added folder in ckan.selfinfo.ckan_repos_path
should have the same owner as the one that runs the application (e.g. if the application runs from ckan
User in the system, then ckanext-scheming folder owner should be ckan
), otherwise there will be an error related to ownership of the repository.
ckan.selfinfo.partitions
- Used for representing disk space. The value is comma separated paths. By default the value is /
, which is usually the root.
Example: /path/to/partition /path/to/partition2 /path/to/partition3
To run the tests, do:
pytest --ckan-ini=test.ini
If ckanext-selfinfo should be available on PyPI you can follow these steps to publish a new version:
-
Update the version number in the
setup.py
file. See PEP 440 for how to choose version numbers. -
Make sure you have the latest version of necessary packages:
pip install --upgrade setuptools wheel twine
-
Create a source and binary distributions of the new version:
python setup.py sdist bdist_wheel && twine check dist/*
Fix any errors you get.
-
Upload the source distribution to PyPI:
twine upload dist/*
-
Commit any outstanding changes:
git commit -a git push
-
Tag the new release of the project on GitHub with the version number from the
setup.py
file. For example if the version number insetup.py
is 0.0.1 then do:git tag 0.0.1 git push --tags