Skip to main content

Smart on fhir python client

Project description

smart-on-fhir-client 🔥

Package allowing to request a fhir server with the smart-on-fhir protocol.

ℹ Warning

It is not a webserver providing a webserver with a callback url usually involved in the smart-on-fhir procedure

Tutorial

First, we will need to create a partner. We can do this easily subclassing the Partner class.

import os
from smart_on_fhir_client.partner import Partner
from smart_on_fhir_client.strategy import Strategy

class OauthFHIRProvider(Partner):
    name = 'PROVIDER'
    supported_strategies: set[Strategy] = {Strategy.M2M}
    client_id: str = os.getenv("PROVIDER_CLIENT_ID")
    client_secret: str = os.getenv("PROVIDER_CLIENT_SECRET")
    token_url: str = ... # set the token url
    fhir_url: str = ... # set the fhir url

    # additional information
    audience: str = ... # audience
    database_reference: str = ... # optional 
    grant_type: str = "client_credentials" # set the credentials

FHIR_PROVIDER = OauthFHIRProvider()
from smart_on_fhir_client.client import smart_client_factory
from smart_on_fhir_client.requester.fhir_requester import fhir_client_manager
from smart_on_fhir_client.strategy import Strategy

# set up your own fhir server url
fhir_client_manager.set_own_fhir_url("http://localhost:8080/fhir")


async def register():
    async with smart_client_factory:
        await fhir_client_manager.register_fhir_client_async(
            smart_client_factory.builder()
            .for_partner(FHIR_PROVIDER)
            .for_strategy(Strategy.M2M)
            # you can register special classes for specific fhir resources
            .register_cls_for('Patient', CustomPatientResource)
        )
        first_patient = await fhir_client_manager.patient.search().limit(10).first()
        await first_patient.pipe_to_target_fhir_server()

Features

Allow to send some fetched fhir resources to another fhir server via the pipe_to_target_fhir_server, making data transfer between two fhir servers easier.

Notes

Work based heavily on fhir-py and fhir-resources python packages

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

smart_on_fhir_client-1.0.4.tar.gz (12.3 kB view details)

Uploaded Source

Built Distribution

smart_on_fhir_client-1.0.4-py3-none-any.whl (14.5 kB view details)

Uploaded Python 3

File details

Details for the file smart_on_fhir_client-1.0.4.tar.gz.

File metadata

  • Download URL: smart_on_fhir_client-1.0.4.tar.gz
  • Upload date:
  • Size: 12.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for smart_on_fhir_client-1.0.4.tar.gz
Algorithm Hash digest
SHA256 7422a89278d73503e64b2992a3f864c9651a52981bb8c4732a1d5dacf5bfae43
MD5 5b04a5cae193469087222b7cbdd87a3d
BLAKE2b-256 a72e4c0371c0e639b758a4eecc3753d5b97954d94a21b175668c01245cd1c29a

See more details on using hashes here.

File details

Details for the file smart_on_fhir_client-1.0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for smart_on_fhir_client-1.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 7ab677e20fa2d76cc6ffd160cc6cf1e922f8073261bb2acf2deeb12095b0ccd5
MD5 71a638a3dfe3b359725d4807ae69b9b3
BLAKE2b-256 15ade9839f9f56caea424741d1ff39564c57b5b7deb08dad205a3ee6d1cf99c4

See more details on using hashes here.

Supported by

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