Snapshot 3: Connectathon 32 Base

This is Snapshot #3 for FHIR R5, released to support Connectathon 32. For a full list of available versions, see the Directory of published versions.

Extension: oauth-uris

FHIR Infrastructure Work Group Maturity Level: 1Trial UseUse Context: Any
Official URL: http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris Version: 5.0.0-snapshot3
active as of 2018-02-15 Computable Name: oauth-uris
Flags: Non-Modifier OID: TBD

Context of Use: Use on Element ID CapabilityStatement.rest.security

Definition

Supports automated discovery of OAuth2 endpoints.

Extension Content

Summary

NameFlagsCard.TypeDescription & Constraintsdoco
.. oauth-uris0..1ExtensionURL = http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris
oauth-uris: Supports automated discovery of OAuth2 endpoints.


Use on Element ID CapabilityStatement.rest.security
... authorize1..1uriOAuth2 "authorize" endpoint

... token1..1uriOAuth2 "token" endpoint

... register0..1uriOAuth2 dynamic registration endpoint


doco Documentation for this format

Full Structure

NameFlagsCard.TypeDescription & Constraintsdoco
.. extension0..1ExtensionURL = http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris
oauth-uris: Supports automated discovery of OAuth2 endpoints.


Use on Element ID CapabilityStatement.rest.security
... Slices for extension 0..*ExtensionAdditional content defined by implementations
Slice: Unordered, Open by value:url
... extension:authorize 1..1ExtensionOAuth2 "authorize" endpoint
.... id 0..1idUnique id for inter-element referencing
.... extension 0..0
.... url 1..1uri"authorize"
.... value[x] 1..1uriValue of extension
... extension:token 1..1ExtensionOAuth2 "token" endpoint
.... id 0..1idUnique id for inter-element referencing
.... extension 0..0
.... url 1..1uri"token"
.... value[x] 1..1uriValue of extension
.... id 0..1idUnique id for inter-element referencing
.... extension 0..0
.... url 1..1uri"register"
.... value[x] 1..1uriValue of extension
... extension:manage 0..1ExtensionUser-facing authorization management entry point
.... id 0..1idUnique id for inter-element referencing
.... extension 0..0
.... url 1..1uri"manage"
.... value[x] 1..1uriValue of extension
... url 1..1uri"http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris"
... value[x] 0..0

doco Documentation for this format

XML Template

<!-- oauth-uris -->doco

<extension xmlns="http://hl7.org/fhir"
     url="http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris" >
 <-- extension sliced by value:url  in the specified orderOpen-->
 <extension url="authorize"> I 1..1 Extension  <!-- I 1..1 OAuth2 "authorize" endpoint -->
  <valueUri value="[uri]"/><!-- I 1..1 Value of extension -->
 </extension>
 <extension url="token"> I 1..1 Extension  <!-- I 1..1 OAuth2 "token" endpoint -->
  <valueUri value="[uri]"/><!-- I 1..1 Value of extension -->
 </extension>
 <extension url="register"> I 0..1 Extension  <!-- I 0..1 OAuth2 dynamic registration endpoint -->
  <valueUri value="[uri]"/><!-- I 1..1 Value of extension -->
 </extension>
 <extension url="manage"> I 0..1 Extension  <!-- I 0..1 User-facing authorization management entry point -->
  <valueUri value="[uri]"/><!-- I 1..1 Value of extension -->
 </extension>
</extension>

JSON Template

{ // oauth-uris
    "extension" : [ //  sliced by value:url  in the specified order, Open 
      { // OAuth2 "authorize" endpoint // I R! 
        // from Element: extension
        "extension" : [ //  sliced by value:url  in the specified order, Open ]
        "url" : "authorize", // R! 
        "valueUri" : "<uri>" // I R! Value of extension
      },
      { // OAuth2 "token" endpoint // I R! 
        // from Element: extension
        "extension" : [ //  sliced by value:url  in the specified order, Open ]
        "url" : "token", // R! 
        "valueUri" : "<uri>" // I R! Value of extension
      },
      { // OAuth2 dynamic registration endpoint // I
        // from Element: extension
        "extension" : [ //  sliced by value:url  in the specified order, Open ]
        "url" : "register", // R! 
        "valueUri" : "<uri>" // I R! Value of extension
      },
      { // User-facing authorization management entry point // I
        // from Element: extension
        "extension" : [ //  sliced by value:url  in the specified order, Open ]
        "url" : "manage", // R! 
        "valueUri" : "<uri>" // I R! Value of extension
      }
    ],
    "extension" : [{ Extension }], // IAdditional content defined by implementations
    "extension" : { Extension }, // I R! OAuth2 "authorize" endpoint
    "extension" : { Extension }, // I R! OAuth2 "token" endpoint
    "extension" : { Extension }, // IOAuth2 dynamic registration endpoint
    "extension" : { Extension }, // IUser-facing authorization management entry point
    "url" : "http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris" // R! 
  // value[x]: Value of extension: Prohibited
  }

Summary

NameFlagsCard.TypeDescription & Constraintsdoco
.. oauth-uris0..1ExtensionURL = http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris
oauth-uris: Supports automated discovery of OAuth2 endpoints.


Use on Element ID CapabilityStatement.rest.security
... authorize1..1uriOAuth2 "authorize" endpoint

... token1..1uriOAuth2 "token" endpoint

... register0..1uriOAuth2 dynamic registration endpoint


doco Documentation for this format

Full Structure

NameFlagsCard.TypeDescription & Constraintsdoco
.. extension0..1ExtensionURL = http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris
oauth-uris: Supports automated discovery of OAuth2 endpoints.


Use on Element ID CapabilityStatement.rest.security
... Slices for extension 0..*ExtensionAdditional content defined by implementations
Slice: Unordered, Open by value:url
... extension:authorize 1..1ExtensionOAuth2 "authorize" endpoint
.... id 0..1idUnique id for inter-element referencing
.... extension 0..0
.... url 1..1uri"authorize"
.... value[x] 1..1uriValue of extension
... extension:token 1..1ExtensionOAuth2 "token" endpoint
.... id 0..1idUnique id for inter-element referencing
.... extension 0..0
.... url 1..1uri"token"
.... value[x] 1..1uriValue of extension
.... id 0..1idUnique id for inter-element referencing
.... extension 0..0
.... url 1..1uri"register"
.... value[x] 1..1uriValue of extension
... extension:manage 0..1ExtensionUser-facing authorization management entry point
.... id 0..1idUnique id for inter-element referencing
.... extension 0..0
.... url 1..1uri"manage"
.... value[x] 1..1uriValue of extension
... url 1..1uri"http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris"
... value[x] 0..0

doco Documentation for this format

XML Template

<!-- oauth-uris -->doco

<extension xmlns="http://hl7.org/fhir"
     url="http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris" >
 <-- extension sliced by value:url  in the specified orderOpen-->
 <extension url="authorize"> I 1..1 Extension  <!-- I 1..1 OAuth2 "authorize" endpoint -->
  <valueUri value="[uri]"/><!-- I 1..1 Value of extension -->
 </extension>
 <extension url="token"> I 1..1 Extension  <!-- I 1..1 OAuth2 "token" endpoint -->
  <valueUri value="[uri]"/><!-- I 1..1 Value of extension -->
 </extension>
 <extension url="register"> I 0..1 Extension  <!-- I 0..1 OAuth2 dynamic registration endpoint -->
  <valueUri value="[uri]"/><!-- I 1..1 Value of extension -->
 </extension>
 <extension url="manage"> I 0..1 Extension  <!-- I 0..1 User-facing authorization management entry point -->
  <valueUri value="[uri]"/><!-- I 1..1 Value of extension -->
 </extension>
</extension>

JSON Template

{ // oauth-uris
    "extension" : [ //  sliced by value:url  in the specified order, Open 
      { // OAuth2 "authorize" endpoint // I R! 
        // from Element: extension
        "extension" : [ //  sliced by value:url  in the specified order, Open ]
        "url" : "authorize", // R! 
        "valueUri" : "<uri>" // I R! Value of extension
      },
      { // OAuth2 "token" endpoint // I R! 
        // from Element: extension
        "extension" : [ //  sliced by value:url  in the specified order, Open ]
        "url" : "token", // R! 
        "valueUri" : "<uri>" // I R! Value of extension
      },
      { // OAuth2 dynamic registration endpoint // I
        // from Element: extension
        "extension" : [ //  sliced by value:url  in the specified order, Open ]
        "url" : "register", // R! 
        "valueUri" : "<uri>" // I R! Value of extension
      },
      { // User-facing authorization management entry point // I
        // from Element: extension
        "extension" : [ //  sliced by value:url  in the specified order, Open ]
        "url" : "manage", // R! 
        "valueUri" : "<uri>" // I R! Value of extension
      }
    ],
    "extension" : [{ Extension }], // IAdditional content defined by implementations
    "extension" : { Extension }, // I R! OAuth2 "authorize" endpoint
    "extension" : { Extension }, // I R! OAuth2 "token" endpoint
    "extension" : { Extension }, // IOAuth2 dynamic registration endpoint
    "extension" : { Extension }, // IUser-facing authorization management entry point
    "url" : "http://fhir-registry.smarthealthit.org/StructureDefinition/oauth-uris" // R! 
  // value[x]: Value of extension: Prohibited
  }

 

Constraints

  • ele-1: All FHIR elements must have a @value or children (xpath: hasValue() or (children().count() > id.count()))
  • ext-1: Must have either extensions or value[x], not both (xpath: extension.exists() != value.exists())
  • ele-1: On Extension.extension: All FHIR elements must have a @value or children (xpath on Extension.extension: hasValue() or (children().count() > id.count()))
  • ext-1: On Extension.extension: Must have either extensions or value[x], not both (xpath on Extension.extension: extension.exists() != value.exists())
  • ele-1: On Extension.extension: All FHIR elements must have a @value or children (xpath on Extension.extension: hasValue() or (children().count() > id.count()))
  • ext-1: On Extension.extension: Must have either extensions or value[x], not both (xpath on Extension.extension: extension.exists() != value.exists())
  • ele-1: On Extension.extension.extension: All FHIR elements must have a @value or children (xpath on Extension.extension.extension: hasValue() or (children().count() > id.count()))
  • ext-1: On Extension.extension.extension: Must have either extensions or value[x], not both (xpath on Extension.extension.extension: extension.exists() != value.exists())
  • ele-1: On Extension.extension.value[x]: All FHIR elements must have a @value or children (xpath on Extension.extension.value[x]: hasValue() or (children().count() > id.count()))
  • ele-1: On Extension.extension: All FHIR elements must have a @value or children (xpath on Extension.extension: hasValue() or (children().count() > id.count()))
  • ext-1: On Extension.extension: Must have either extensions or value[x], not both (xpath on Extension.extension: extension.exists() != value.exists())
  • ele-1: On Extension.extension.extension: All FHIR elements must have a @value or children (xpath on Extension.extension.extension: hasValue() or (children().count() > id.count()))
  • ext-1: On Extension.extension.extension: Must have either extensions or value[x], not both (xpath on Extension.extension.extension: extension.exists() != value.exists())
  • ele-1: On Extension.extension.value[x]: All FHIR elements must have a @value or children (xpath on Extension.extension.value[x]: hasValue() or (children().count() > id.count()))
  • ele-1: On Extension.extension: All FHIR elements must have a @value or children (xpath on Extension.extension: hasValue() or (children().count() > id.count()))
  • ext-1: On Extension.extension: Must have either extensions or value[x], not both (xpath on Extension.extension: extension.exists() != value.exists())
  • ele-1: On Extension.extension.extension: All FHIR elements must have a @value or children (xpath on Extension.extension.extension: hasValue() or (children().count() > id.count()))
  • ext-1: On Extension.extension.extension: Must have either extensions or value[x], not both (xpath on Extension.extension.extension: extension.exists() != value.exists())
  • ele-1: On Extension.extension.value[x]: All FHIR elements must have a @value or children (xpath on Extension.extension.value[x]: hasValue() or (children().count() > id.count()))
  • ele-1: On Extension.extension: All FHIR elements must have a @value or children (xpath on Extension.extension: hasValue() or (children().count() > id.count()))
  • ext-1: On Extension.extension: Must have either extensions or value[x], not both (xpath on Extension.extension: extension.exists() != value.exists())
  • ele-1: On Extension.extension.extension: All FHIR elements must have a @value or children (xpath on Extension.extension.extension: hasValue() or (children().count() > id.count()))
  • ext-1: On Extension.extension.extension: Must have either extensions or value[x], not both (xpath on Extension.extension.extension: extension.exists() != value.exists())
  • ele-1: On Extension.extension.value[x]: All FHIR elements must have a @value or children (xpath on Extension.extension.value[x]: hasValue() or (children().count() > id.count()))
  • ele-1: On Extension.value[x]: All FHIR elements must have a @value or children (xpath on Extension.value[x]: hasValue() or (children().count() > id.count()))

Search

No Search Extensions defined for this resource

Examples of this extension

No examples found.