This data model communicates information about a patient’s office or other outpatient appointment. EHR systems can send Scheduling messages to update your system with the appointment status, date/time, scheduled providers, and scheduled resources.
Every appointment gets assigned a visit number and patient ID. Any changes to the appointment are made with the relevant visit number. If the appointment is canceled and later rescheduled, however, a new visit number is created. Also keep in mind that scheduling holds and blocks don’t have an associated patient ID.
This data model has event types that allow you to:
- receive a notification about appointment updates;
- push or receive a list of available appointment slots;
- query for and receive open appointment times; or
- query for and receive booked appointment times.
Query for booked times within a given time range. Results are returned in Scheduling.BookedResponse.
Request Body Schema
- Metarequired, object- DataModelrequired, stringReliableScheduling 
- EventTyperequired, stringReliableBooked 
- EventDateTimestring, nullReliableDisplays the UTC date and time that an outgoing request is delivered or an incoming request is received. 
 ISO 8601 Format
- Testboolean, nullReliableIndicates whether the request is a test or not. 
- SourceobjectContains the information for the system initiating the message, including the source ID and name. 
 Included in messages from Redox- IDstring, nullReliableIdentifies the system initiating the message. If you have multiple OAuth API keys per environment type, this value is required. If you have only one OAuth API key per environment type, or you're using legacy API keys, this value is optional. 
 UUID
- Namestring, nullReliableDisplays the name of the system initiating the message. 
 
- DestinationsArray of objectContains the information for the endpoint(s) receiving the request. A request must contain at least one destination, but asynchronous requests can have more than one destination. Synchronous requests like queries can only support one destination. 
 Required when sending data to Redox.- IDstring, nullReliableIdentifies the endpoint that the request is directed to. 
 UUID
- Namestring, nullReliableDisplays the name of the endpoint that the request is directed to. 
 
- LogsArray of objectContains the log identifier(s) for the request. - IDstring, nullReliableIdentifies the request log(s) that correspond to this request. You can use this value to locate the relevant log in the Redox dashboard for support and reference. 
 UUID
- AttemptIDstring, nullReliableIdentifies the request log attempt value, which is useful when retries are possible. 
 UUID
 
- FacilityCodestring, nullPossibleCode for the facility related to the message. 
 Only use this field if a health system indicates you should. The code is specific to the health system's EHR and might not be unique across health systems. In general, the facility fields within the data models (e.g. OrderingFacility) are more reliable and informative.
 
- StartDateTimerequired, stringReliableDefines the start of the time range to search for appointments. 
 ISO 8601 Format
- EndDateTimestring, nullPossibleDefines the end of the time range to search for appointments. 
 ISO 8601 Format
- Visitobject- Reasonstring, nullReliableIndicates the appointment reason to search for. 
- VisitNumberstring, nullPossibleDisplays the unique identifier for the patient visit. You must query for a specific booked appointment by a known VisitNumber. 
- AttendingProvidersArray of object- IDstring, nullProbableID of the provider. 
 This ID is often required for Inpatient Visits.
- IDTypestring, nullProbableID type of the ID for the provider 
- FirstNamestring, nullPossibleFirst name of the provider 
- LastNamestring, nullPossibleLast name of the provider 
- CredentialsArray of stringList of credentials for the provider. 
 e.g. MD, PhD
- AddressobjectProvider's address - StreetAddressstring, nullPossibleStreet address 
- Citystring, nullPossibleCity 
- Statestring, nullPossibleState 
- ZIPstring, nullPossibleZIP 
- Countystring, nullPossibleCounty 
- Countrystring, nullPossibleValue SetCountry 
 
- EmailAddressesArray of stringProvider's email address(es) 
- PhoneNumberobject- Officestring, nullPossibleProvider's office phone number. 
 In E. 164 Format. (e.g. +16085551234)
 
- LocationobjectProvider's location - Typestring, nullPossibleType of location. 
 Examples: Clinic, Department, Home, Nursing Unit, Provider's Office, Phone
- Facilitystring, nullPossibleFacility. 
 Example: Community Hospital
- FacilityIdentifiersArray of objectList of IDs specific to this facility - IDstring, nullPossibleAn ID specific to this facility 
- IDTypestring, nullPossibleThe source or system to which this ID pertains. 
 Could be an OID or a human-readable name
 
- Departmentstring, nullPossibleDepartment 
- DepartmentIdentifiersArray of objectList of IDs specific to this department - IDstring, nullPossibleAn ID specific to this department 
- IDTypestring, nullPossibleThe source or system to which this ID pertains. 
 Could be an OID or a human-readable name
 
- Roomstring, nullPossibleRoom. 
 Example: 136
 
 
- VisitProviderobject- IDstring, nullPossibleID of the visit provider. 
 This ID is often required for Inpatient Visits.
- IDTypestring, nullPossibleID type of the ID for the visit provider 
- FirstNamestring, nullPossibleFirst name of the visit provider 
- LastNamestring, nullPossibleLast name of the visit provider 
- CredentialsArray of stringList of credentials for the visit provider. 
 e.g. MD, PhD
- AddressobjectProvider's address - StreetAddressstring, nullPossibleStreet address 
- Citystring, nullPossibleCity 
- Statestring, nullPossibleState 
- ZIPstring, nullPossibleZIP 
- Countystring, nullPossibleCounty 
- Countrystring, nullPossibleValue SetCountry 
 
- EmailAddressesArray of stringProvider's email address(es) 
- PhoneNumberobject- Officestring, nullPossibleProvider's office phone number. 
 In E. 164 Format. (e.g. +16085551234)
 
- LocationobjectProvider's location - Typestring, nullPossibleType of location. 
 Examples: Clinic, Department, Home, Nursing Unit, Provider's Office, Phone
- Facilitystring, nullPossibleFacility. 
 Example: Community Hospital
- FacilityIdentifiersArray of objectList of IDs specific to this facility - IDstring, nullPossibleAn ID specific to this facility 
- IDTypestring, nullPossibleThe source or system to which this ID pertains. 
 Could be an OID or a human-readable name
 
- Departmentstring, nullPossibleDepartment 
- DepartmentIdentifiersArray of objectList of IDs specific to this department - IDstring, nullPossibleAn ID specific to this department 
- IDTypestring, nullPossibleThe source or system to which this ID pertains. 
 Could be an OID or a human-readable name
 
- Roomstring, nullPossibleRoom. 
 Example: 136
 
 
- LocationobjectDefines the location of the appointment. - Typestring, nullProbableType of location. 
 Examples: Clinic, Department, Home, Nursing Unit, Provider's Office, Phone
- Facilitystring, nullProbableFacility. 
 Example: Community Hospital
- FacilityIdentifiersArray of objectList of IDs specific to this facility - IDstring, nullProbableAn ID specific to this facility 
- IDTypestring, nullProbableThe source or system to which this ID pertains. 
 Could be an OID or a human-readable name
 
- Departmentstring, nullProbableDepartment 
- DepartmentIdentifiersArray of objectList of IDs specific to this department - IDstring, nullProbableAn ID specific to this department 
- IDTypestring, nullProbableThe source or system to which this ID pertains. 
 Could be an OID or a human-readable name
 
- Roomstring, nullProbableRoom. 
 Example: 136
 
- PatientsArray of objectIdentifies the patient(s) for the appointment. - IdentifiersArray of objectContains a list of identifiers and identifiers types that correlate to the patient. - IDstring, nullProbableContains an identifier for the patient. 
- IDTypestring, nullProbableDefines the type of the identifier used for the patient. 
 E.g. MRN, EPI