From 6aa2e4834dbe309b99f8aa9dbce5c960ba0c34f3 Mon Sep 17 00:00:00 2001 From: JaZahn Date: Wed, 5 Jul 2023 13:51:44 -0400 Subject: [PATCH] adding a README --- README.md | 100 +++++++++++++++++++++++++++++++++++++++++++++ pds/__version__.py | 4 +- 2 files changed, 102 insertions(+), 2 deletions(-) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 0000000..2e663e3 --- /dev/null +++ b/README.md @@ -0,0 +1,100 @@ +## Person Data Service Python Library + +This library is meant to serve as a convenience library to using the PDS. This came about from me rewriting the same code over and over. + +### Installation + +Currently this can be installed directly from this repository with: + +``` +pip install git+https://github.huit.harvard.edu/HUIT/py-pds.git@v1.0.0 +``` + +### Usage + +Create a People object using an apikey and what you want your batch size to be (if you're paginating). + +```py +import pds + +pds_api = pds.People(apikey='12345', batch=50) +``` + +Default batch is 50 and this won't work without a valid apikey, so if you don't have one, head over here: https://portal.apis.huit.harvard.edu/docs/ats-person-v3/1/overview + +Once that object is created, there are only a couple of methods for it. + +#### search + +This is the core function. It takes a dict `query` and an optional boolean `paginate`, + +```py +import pds + +pds_api = pds.People(apikey-'12345', batch=50) +people = pds_api.search(query={ + "fields": [ + "univid" + ], + "conditions": { + "names.name": "jazahn" + } +}) + +total_results = people['total_results'] +results = people['results'] +``` + + +#### make_people + +This just converts some results into dotmaps, which can _sometimes_ make referencing values easier. + +```py +import pds + +pds_api = pds.People(apikey-'12345', batch=50) +people = pds_api.search(query={ + "fields": [ + "univid" + ], + "conditions": { + "names.name": "jazahn" + } +}) + +total_results = people['total_results'] +results = people['results'] + +dotmapped_people = pds_api.make_people(results) +print(dotmapped_people[0].univid) +``` + +#### next + +Next is probably the reason you're using this library. This helps simplify pagination. Simply make a search call with the `paginate` boolean set to true and then you can call `next()` to get the next set. + +```py +import pds + +pds_api = pds.People(apikey-'12345', batch=50) +response = pds_api(query={ + "fields": [ + "univid" + ], + "conditions": { + "names.name": "jazahn" + } +}) + +total_results = response['total_results'] +results = response['results'] + +while(True): + response = pds_api.next() + if not response: + break + + results = response['results'] + # do something with results +``` \ No newline at end of file diff --git a/pds/__version__.py b/pds/__version__.py index 969c595..6684010 100644 --- a/pds/__version__.py +++ b/pds/__version__.py @@ -1,11 +1,11 @@ -"""Version details for simple-salesforce +"""Version details for pds This file shamelessly taken from the simple-salesforce library, which in turn took it from the requests library""" __title__ = 'pds' __description__ = 'A basic PDS REST API client.' __url__ = 'https://github.huit.harvard.edu/HUIT/py-pds' -__version__ = '0.1.0' +__version__ = '1.0.0' __author__ = 'JaZahn Clevenger' __author_email__ = 'jcleveng@fas.harvard.edu' __license__ = 'MIT'