Data Commons Reconciliation Service provides Knowledge Graph entity reconciliation services. It gets deployed in a Kubernetes cluster.
Data Commons is an Open Knowledge Graph that provides a unified view across multiple public data sets and statistics. It includes APIs and visual tools to easily explore and analyze data across different datasets without data cleaning or joining.
Apache 2.0
In https://github.com/datacommonsorg/reconciliation, click on "Fork" button to fork the repo.
Clone your forked repo to your desktop.
Add datacommonsorg/reconciliation repo as a remote:
git remote add dc https://github.com/datacommonsorg/reconciliation.git
Every time when you want to send a Pull Request, do the following steps:
git checkout master
git pull dc master
git checkout -b new_branch_name
# Make some code change
git add .
git commit -m "commit message"
git push -u origin new_branch_name
Then in your forked repo, you can send a Pull Request. If this is your first time contributing to a Google Open Source project, you may need to follow the steps in contributing.md.
Wait for approval of the Pull Request and merge the change.
Example curl command (entity described by subgraph):
curl -X POST https://autopush.recon.datacommons.org/entity/resolve -d '{"entities":{"source_id":"newId/SantaClaraCountyId","sub_graph":{"nodes":{"newId/SantaClaraCountyId":{"pvs":{"wikidataId":{"typed_values":{"type":"TEXT","value":"Q110739"}}}}}}}}'
Example curl command (entity described by IDs):
curl -X POST https://autopush.recon.datacommons.org/entity/resolve -d '{"entities":{"source_id":"newId/SantaClaraCountyId","entity_ids":{"ids":{"prop":"geoId","val":"06085"}}}}'
Example curl command:
curl -X POST https://autopush.recon.datacommons.org/coordinate/resolve -d '{"coordinates": [{"latitude":"37.42","longitude":"-122.08"},{"latitude":"32.41","longitude":"-102.11"}]}'
Example curl command:
curl -X POST https://autopush.recon.datacommons.org/id/resolve -d '{"in_prop":"wikidataId","out_prop":"dcid","ids":["Q110739","Q30"]}'
Install command line tools: protoc
, protoc-gen-go
, protoc-gen-go-grpc
. Then run the following command in root directory:
protoc \
--proto_path=proto \
--go_out=internal \
--go-grpc_out=internal \
--go-grpc_opt=require_unimplemented_servers=false \
proto/*.proto
Firstly, ensure appropriate GCP credentials:
gcloud auth login
gcloud auth application-default login
Then, run all unit tests and integration tests from the root directory:
go test ./...
To update golden files for the integration tests, use the generate_golden
flag in ./test/integration/setup.go
.
For general questions or issues about tool development, please open an issue
on our issues page. For all
other questions, please send an email to [email protected]
.
Note - This is not an officially supported Google product.