/** * 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 { CapabilityStatementDocument } from './capabilityStatementDocument'; import { CapabilityStatementImplementation } from './capabilityStatementImplementation'; import { CapabilityStatementMessaging } from './capabilityStatementMessaging'; import { CapabilityStatementRest } from './capabilityStatementRest'; import { CapabilityStatementSoftware } from './capabilityStatementSoftware'; 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 { Meta } from './meta'; import { Narrative } from './narrative'; import { ResourceList } from './resourceList'; import { Uri } from './uri'; import { UsageContext } from './usageContext'; /** * A Capability Statement documents a set of capabilities (behaviors) of a FHIR Server or Client for a particular version of FHIR that may be used as a statement of actual server functionality or a statement of required or desired server implementation. */ export interface CapabilityStatement { /** * This is a CapabilityStatement resource */ resourceType: 'CapabilityStatement'; 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 CapabilityStatement 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 capability statement instances. */ useContext?: Array; /** * A legal or geographic region in which the capability statement is intended to be used. */ jurisdiction?: Array; purpose?: Markdown; copyright?: Markdown; copyrightLabel?: string; kind?: Code; /** * Reference to a canonical URL of another CapabilityStatement that this software implements. This capability statement is a published API description that corresponds to a business service. The server may actually implement a subset of the capability statement it claims to implement, so the capability statement must specify the full capability details. */ instantiates?: Array; /** * Reference to a canonical URL of another CapabilityStatement that this software adds to. The capability statement automatically includes everything in the other statement, and it is not duplicated, though the server may repeat the same resources, interactions and operations to add additional details to them. */ imports?: Array; software?: CapabilityStatementSoftware; implementation?: CapabilityStatementImplementation; fhirVersion?: Code; /** * A list of the formats supported by this implementation using their content types. */ format?: Array; /** * A list of the patch formats supported by this implementation using their content types. */ patchFormat?: Array; /** * A list of the languages supported by this implementation that are usefully supported in the ```Accept-Language``` header. */ acceptLanguage?: Array; /** * A list of implementation guides that the server does (or should) support in their entirety. */ implementationGuide?: Array; /** * A definition of the restful capabilities of the solution, if any. */ rest?: Array; /** * A description of the messaging capabilities of the solution. */ messaging?: Array; /** * A document definition. */ document?: Array; }