/** * FHIR Version R5 * The following is auto generated resource definition. * * OpenAPI spec version: 3.0.1 * * * NOTE: This class is auto generated by the swagger code generator program. * https://github.com/swagger-api/swagger-codegen.git * Do not edit the class manually. */ import { Canonical } from './canonical'; import { Code } from './code'; import { CodeableConcept } from './codeableConcept'; import { Coding } from './coding'; import { ContactDetail } from './contactDetail'; import { DateTime } from './dateTime'; import { Extension } from './extension'; import { Id } from './id'; import { Identifier } from './identifier'; import { Markdown } from './markdown'; import { MessageDefinitionAllowedResponse } from './messageDefinitionAllowedResponse'; import { MessageDefinitionFocus } from './messageDefinitionFocus'; import { Meta } from './meta'; import { Narrative } from './narrative'; import { ResourceList } from './resourceList'; import { Uri } from './uri'; import { UsageContext } from './usageContext'; /** * Defines the characteristics of a message that can be shared between systems, including the type of event that initiates the message, the content to be transmitted and what response(s), if any, are permitted. */ export interface MessageDefinition { /** * This is a MessageDefinition resource */ resourceType: 'MessageDefinition'; id?: Id; meta?: Meta; implicitRules?: Uri; language?: Code; text?: Narrative; /** * These resources do not have an independent existence apart from the resource that contains them - they cannot be identified independently, nor can they have their own independent transaction scope. This is allowed to be a Parameters resource if and only if it is referenced by a resource that provides context/meaning. */ contained?: Array; /** * May be used to represent additional information that is not part of the basic definition of the resource. To make the use of extensions safe and managable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer can define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. */ extension?: Array; /** * May be used to represent additional information that is not part of the basic definition of the resource and that modifies the understanding of the element that contains it and/or the understanding of the containing element's descendants. Usually modifier elements provide negation or qualification. To make the use of extensions safe and managable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions. Modifier extensions SHALL NOT change the meaning of any elements on Resource or DomainResource (including cannot change the meaning of modifierExtension itself). */ modifierExtension?: Array; url?: Uri; /** * A formal identifier that is used to identify this message definition when it is represented in other formats, or referenced in a specification, model, design or an instance. */ identifier?: Array; version?: string; /** * Indicates the mechanism used to compare versions to determine which is more current. */ versionAlgorithmString?: string; versionAlgorithmCoding?: Coding; name?: string; title?: string; status?: Code; experimental?: boolean; date?: Date; publisher?: string; /** * Contact details to assist a user in finding and communicating with the publisher. */ contact?: Array; description?: Markdown; /** * The content was developed with a focus and intent of supporting the contexts that are listed. These contexts may be general categories (gender, age, ...) or may be references to specific programs (insurance plans, studies, ...) and may be used to assist with indexing and searching for appropriate message definition instances. */ useContext?: Array; /** * A legal or geographic region in which the message definition is intended to be used. */ jurisdiction?: Array; purpose?: Markdown; copyright?: Markdown; copyrightLabel?: string; /** * A MessageDefinition that is superseded by this definition. */ replaces?: Array; base?: Canonical; /** * Identifies a protocol or workflow that this MessageDefinition represents a step in. */ parent?: Array; eventCoding?: Coding; /** * Event code or link to the EventDefinition. */ eventUri?: string; category?: Code; /** * Identifies the resource (or resources) that are being addressed by the event. For example, the Encounter for an admit message or two Account records for a merge. */ focus?: Array; responseRequired?: Code; /** * Indicates what types of messages may be sent as an application-level response to this message. */ allowedResponse?: Array; graph?: Canonical; }