Skip to main content

No project description provided

Project description

Github Actions PyPI version

Data.gov

Data.gov is an open data website created by the U.S. General Services Administration that is based on two robust open source projects: CKAN and WordPress. The data catalog at catalog.data.gov is powered by CKAN, while the content seen at Data.gov is powered by WordPress.

For all code, bugs, and feature requests related to Data.gov, see the project wide Data.gov issue tracker.

Currently this repository is only used for source version control on the code for the CKAN extension for geospatial data, but you can see all of the Data.gov relevant repos listed in the GSA Data.gov README file.

CKAN Extension for Geospatial Data

Most Data.gov specific CKAN customizations are contained within this extension, but the extension also provides additional geospatial capabilities.

Customization

Due to CKAN 2.3 and 2.8 migrations, some features should be removed or moved to the official community versions:

Requirements

Package Notes
ckanext-spatial --
PyZ3950 --
werkzeug This only effects the tests. For all intents and purposes, this should be tracking upstream

This extension is compatible with these versions of CKAN.

CKAN version Compatibility
<=2.8 no
2.9 0.1.37 (last supported)
2.10 >=0.2.0

Tests

All the tests live in the /ckanext/geodatagov/tests folder. Github actions is configured to run the tests against CKAN 2.10 when you open a pull request.

Using the Docker Dev Environment

Build Environment

To start environment, run: docker compose build docker compose up

CKAN will start at localhost:5000

To shut down environment, run:

docker compose down

To docker exec into the CKAN image, run:

docker compose exec app /bin/bash

Testing

They follow the guidelines for testing CKAN extensions.

To run the extension tests, start the containers with make up, then:

$ make test

Lint the code.

$ make lint

Debugging

We have not determined a good way for most IDE native debugging, however you can use the built in Python pdb debugger. Simply run make debug, which will run docker with an interactive shell. Add import pdb; pdb.set_trace() anywhere you want to start debugging, and if the code is triggered you should see a command prompt waiting in the shell. Use a pdb cheat sheet when starting to learn like this.

When you edit/add/remove code, the server is smart enough to restart. If you are editing logic that is not part of the webserver (ckan command, etc) then you should be able to run the command after edits and get the same debugger prompt.

Matrix builds

The existing development environment assumes a full catalog.data.gov test setup. This makes it difficult to develop and test against new versions of CKAN (or really any dependency) because everything is tightly coupled and would require us to upgrade everything at once which doesn't really work. A new make target test-new is introduced with a new docker-compose file.

The "new" development environment drops as many dependencies as possible. It is not meant to have feature parity with GSA/catalog.data.gov. Tests should mock external dependencies where possible.

In order to support multiple versions of CKAN, or even upgrade to new versions of CKAN, we support development and testing through the CKAN_VERSION environment variable.

$ make CKAN_VERSION=2.11 test

Command line interface

The following operations can be run from the command line as described underneath::

  geodatagov sitemap-to-s3 [{upload_to_s3}] [{page_size}] [{max_per_page}]
    - Generates sitemap and uploads to s3

  geodatagov db-solr-sync [{dryrun}] [{cleanup_solr}] [{update_solr}]
    - DB Solr sync. 

  geodatagov tracking-update [{start_date}]
    - ckan tracking update with customized options and output

Credit / Copying

Original work written by the HealthData.gov team. It has been modified in support of Data.gov.

As a work of the United States Government, this package is in the public domain within the United States. Additionally, we waive copyright and related rights in the work worldwide through the CC0 1.0 Universal public domain dedication (which can be found at http://creativecommons.org/publicdomain/zero/1.0/).

Ways to Contribute

We're so glad you're thinking about contributing to ckanext-datajson!

Before contributing to ckanext-datajson we encourage you to read our CONTRIBUTING guide, our LICENSE, and our README (you are here), all of which should be in this repository. If you have any questions, you can email the Data.gov team at datagov@gsa.gov.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ckanext-geodatagov-0.4.2.tar.gz (131.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ckanext_geodatagov-0.4.2-py3-none-any.whl (163.5 kB view details)

Uploaded Python 3

File details

Details for the file ckanext-geodatagov-0.4.2.tar.gz.

File metadata

  • Download URL: ckanext-geodatagov-0.4.2.tar.gz
  • Upload date:
  • Size: 131.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ckanext-geodatagov-0.4.2.tar.gz
Algorithm Hash digest
SHA256 388e7f3e3e125656fca65f4893a835496805bdb3e675d5b5d7efdb0f25692e41
MD5 ccd1340112fcfa4ac4d86ba2c8cb2400
BLAKE2b-256 eac9c1c6af4ef6a1deae962ff819dd7badacfd6b397351367d48b1edc6ee41ff

See more details on using hashes here.

File details

Details for the file ckanext_geodatagov-0.4.2-py3-none-any.whl.

File metadata

File hashes

Hashes for ckanext_geodatagov-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 8e173b2f81f13c6692982760bdb052dafa4e7757bb88eeac7397b4ac4d3aa684
MD5 55f8f67e5ca254d972d16752d7af00d6
BLAKE2b-256 272493fb8ef83e362e8c9be81d9600e4cef21ee5f6849bcaa8a14f26e9e5569c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page