FHIRClient

extension FHIRClient
  • Convenience function for requesting a certain task by ID

    Declaration

    Swift

    public func fetchTask(by id: ErxTask.ID,
                          accessCode: String?) -> AnyPublisher<ErxTask?, FHIRClient.Error>

    Parameters

    id

    The ID of the task to be requested

    accessCode

    code to access the given id or nil when not required due to (previous|other) authorization

    Return Value

    AnyPublisher that emits the task or nil when not found

  • Convenience function for requesting all tasks

    Note

    the simplifier (and the gematik specification) documentation is not clear as how to handle multiple tasks in one bundle/requests

    Declaration

    Swift

    public func fetchAllTasks(after referenceDate: String?)
        -> AnyPublisher<PagedContent<[ErxTask]>, FHIRClient.Error>

    Parameters

    referenceDate

    Tasks with modification date greater or equal referenceDate will be fetched

    Return Value

    AnyPublisher that emits all sparse tasks

  • Convenience function for requesting all tasks of a next page from a previous page.

    Declaration

    Swift

    public func fetchTasksNextPage(for url: URL?)
        -> AnyPublisher<PagedContent<[ErxTask]>, FHIRClient.Error>

    Parameters

    previousPage

    The previous page retrieved from the service

  • Convenience function for deleting a task

    Declaration

    Swift

    public func deleteTask(by id: ErxTask.ID,
                           accessCode: String?) -> AnyPublisher<Bool, FHIRClient.Error>

    Parameters

    id

    The ID of the task to be requested

    accessCode

    code to access the given id or nil when not required due to (previous|other) authorization

    Return Value

    AnyPublisher that emits the task or nil when not found

  • Convenience function for requesting a certain audit event by ID

    Declaration

    Swift

    public func fetchAuditEvent(by id: ErxAuditEvent.ID) -> AnyPublisher<ErxAuditEvent?, FHIRClient.Error>

    Parameters

    id

    The ID of the audit event to be requested

    accessCode

    code to access the given id or nil when not required due to (previous|other) authorization

    Return Value

    AnyPublisher that emits the audit event or nil when not found

  • Convenience function for requesting audit events

    Declaration

    Swift

    public func fetchAllAuditEvents(
        after referenceDate: String? = nil,
        for locale: String? = nil
    ) -> AnyPublisher<PagedContent<[ErxAuditEvent]>, FHIRClient.Error>

    Parameters

    referenceDate

    Audit-Events with date greater or equal referenceDate will be fetched. Pass nil for fetching all audit events

    locale

    Locale key for which language the audit events will be fetched. Nil if all languages should be fetched

    Return Value

    AnyPublisher that emits the audit events

  • Convenience function for requesting audit events

    Declaration

    Swift

    public func fetchAuditEventsNextPage(from url: URL, locale: String?)
        -> AnyPublisher<PagedContent<[ErxAuditEvent]>, FHIRClient.Error>

    Parameters

    url

    Link to load next page

    locale

    Location type of the language in which the result should be returned

    Return Value

    AnyPublisher that emits the audit events

  • Convenience function for redeeming an ErxTask in a pharmacy

    Declaration

    Swift

    public func redeem(order: ErxTaskOrder) -> AnyPublisher<ErxTaskOrder, FHIRClient.Error>

    Parameters

    order

    The information relevant for placing the order

    Return Value

    true if the server responds without error and parsing has been successful, otherwise error

  • Requests all communication Resources for the logged in user

    [REQ:gemSpec_eRp_FdV:A_19984] validate pharmacy data format conforming to FHIR

    Declaration

    Swift

    public func communicationResources(
        after referenceDate: String?
    ) -> AnyPublisher<[ErxTask.Communication], FHIRClient.Error>

    Parameters

    referenceDate

    Communications with timestamp greater or equal referenceDate will be fetched

    Return Value

    Array of all loaded communication resources

  • Requests medication dispenses for a specific Prescription

    Declaration

    Swift

    public func fetchMedicationDispenses(
        for id: ErxTask.ID
    ) -> AnyPublisher<[ErxMedicationDispense], FHIRClient.Error>

    Parameters

    id

    MedicationDispense for the corresponding ErxTask.ID will be fetched.

    Return Value

    AnyPublisher that emits MedicationDispenses

  • Convenience function for requesting a certain charge item by ID

    Declaration

    Swift

    public func fetchChargeItem(by id: ErxChargeItem.ID)
        -> AnyPublisher<ErxChargeItem?, FHIRClient.Error>

    Parameters

    id

    The ID of the charge item to be requested

    Return Value

    AnyPublisher that emits the charge item or nil when not found

  • Convenience function for requesting all charge item ids

    Declaration

    Swift

    public func fetchAllChargeItemIDs(after referenceDate: String?) -> AnyPublisher<[String], FHIRClient.Error>

    Parameters

    referenceDate

    Charge items with entered date greater or equal referenceDate will be fetched

    Return Value

    AnyPublisher that emits the ids for the found charge items

  • Convenience function for deleting a charge item

    Declaration

    Swift

    public func deleteChargeItem(
        by id: ErxChargeItem.ID,
        accessCode: String?
    ) -> AnyPublisher<Bool, FHIRClient.Error>

    Parameters

    id

    The ID of the charge item to be deleted

    accessCode

    code to access the given id or nil when not required due to (previous/other) authorisation

    Return Value

    AnyPublisher that emits true if the item was deleted

  • Loads All consents of a given profile Uses the request headers ACCESS_TOKEN with the containing insurance id

    Declaration

    Swift

    public func fetchConsents() -> AnyPublisher<[ErxConsent], FHIRClient.Error>

    Return Value

    Array of all loaded ErxConsent

  • Send a grant consent request of an ErxConsent

    Declaration

    Swift

    public func grantConsent(_ consent: ErxConsent) -> AnyPublisher<ErxConsent?, FHIRClient.Error>

    Parameters

    consent

    Consent that contains information about the type of consent and insurance id which the consent will be granted for

    Return Value

    The ErxConsent that was granted or nil when not found

  • Delete an consent of ErxConsent to revoke it

    Declaration

    Swift

    public func revokeConsent(_ category: ErxConsent.Category) -> AnyPublisher<Bool, FHIRClient.Error>

    Parameters

    category

    the ErxConsent.Categoryof the consent to be revoked

    Return Value

    Publisher for the load request