Package com.ibm.fhir.model.resource
Class Subscription.Channel.Builder
- java.lang.Object
-
- com.ibm.fhir.model.builder.AbstractBuilder<Element>
-
- com.ibm.fhir.model.type.Element.Builder
-
- com.ibm.fhir.model.type.BackboneElement.Builder
-
- com.ibm.fhir.model.resource.Subscription.Channel.Builder
-
- Enclosing class:
- Subscription.Channel
public static class Subscription.Channel.Builder extends BackboneElement.Builder
-
-
Field Summary
-
Fields inherited from class com.ibm.fhir.model.type.BackboneElement.Builder
modifierExtension
-
Fields inherited from class com.ibm.fhir.model.type.Element.Builder
extension, id
-
Fields inherited from class com.ibm.fhir.model.builder.AbstractBuilder
validating
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Subscription.Channel
build()
Build theSubscription.Channel
Subscription.Channel.Builder
endpoint(Url endpoint)
The url that describes the actual end-point to send messages to.Subscription.Channel.Builder
extension(Extension... extension)
May be used to represent additional information that is not part of the basic definition of the element.Subscription.Channel.Builder
extension(Collection<Extension> extension)
May be used to represent additional information that is not part of the basic definition of the element.protected Subscription.Channel.Builder
from(Subscription.Channel channel)
Subscription.Channel.Builder
header(String... header)
Additional headers / information to send as part of the notification.Subscription.Channel.Builder
header(Collection<String> header)
Additional headers / information to send as part of the notification.Subscription.Channel.Builder
id(String id)
Unique id for the element within a resource (for internal references).Subscription.Channel.Builder
modifierExtension(Extension... modifierExtension)
May be used to represent additional information that is not part of the basic definition of the element and that modifies the understanding of the element in which it is contained and/or the understanding of the containing element's descendants.Subscription.Channel.Builder
modifierExtension(Collection<Extension> modifierExtension)
May be used to represent additional information that is not part of the basic definition of the element and that modifies the understanding of the element in which it is contained and/or the understanding of the containing element's descendants.Subscription.Channel.Builder
payload(Code payload)
The mime type to send the payload in - either application/fhir+xml, or application/fhir+json.Subscription.Channel.Builder
type(SubscriptionChannelType type)
The type of channel to send notifications on.protected void
validate(Subscription.Channel channel)
-
Methods inherited from class com.ibm.fhir.model.type.BackboneElement.Builder
from, validate
-
Methods inherited from class com.ibm.fhir.model.type.Element.Builder
from, validate
-
Methods inherited from class com.ibm.fhir.model.builder.AbstractBuilder
isValidating, setValidating
-
-
-
-
Method Detail
-
id
public Subscription.Channel.Builder id(String id)
Unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.- Overrides:
id
in classBackboneElement.Builder
- Parameters:
id
- Unique id for inter-element referencing- Returns:
- A reference to this Builder instance
-
extension
public Subscription.Channel.Builder extension(Extension... extension)
May be used to represent additional information that is not part of the basic definition of the element. To make the use of extensions safe and manageable, 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.Adds new element(s) to the existing list
- Overrides:
extension
in classBackboneElement.Builder
- Parameters:
extension
- Additional content defined by implementations- Returns:
- A reference to this Builder instance
-
extension
public Subscription.Channel.Builder extension(Collection<Extension> extension)
May be used to represent additional information that is not part of the basic definition of the element. To make the use of extensions safe and manageable, 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.Replaces the existing list with a new one containing elements from the Collection
- Overrides:
extension
in classBackboneElement.Builder
- Parameters:
extension
- Additional content defined by implementations- Returns:
- A reference to this Builder instance
-
modifierExtension
public Subscription.Channel.Builder modifierExtension(Extension... modifierExtension)
May be used to represent additional information that is not part of the basic definition of the element and that modifies the understanding of the element in which it is contained 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 manageable, 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. 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).
Adds new element(s) to the existing list
- Overrides:
modifierExtension
in classBackboneElement.Builder
- Parameters:
modifierExtension
- Extensions that cannot be ignored even if unrecognized- Returns:
- A reference to this Builder instance
-
modifierExtension
public Subscription.Channel.Builder modifierExtension(Collection<Extension> modifierExtension)
May be used to represent additional information that is not part of the basic definition of the element and that modifies the understanding of the element in which it is contained 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 manageable, 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. 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).
Replaces the existing list with a new one containing elements from the Collection
- Overrides:
modifierExtension
in classBackboneElement.Builder
- Parameters:
modifierExtension
- Extensions that cannot be ignored even if unrecognized- Returns:
- A reference to this Builder instance
-
type
public Subscription.Channel.Builder type(SubscriptionChannelType type)
The type of channel to send notifications on.This element is required.
- Parameters:
type
- rest-hook | websocket | email | sms | message- Returns:
- A reference to this Builder instance
-
endpoint
public Subscription.Channel.Builder endpoint(Url endpoint)
The url that describes the actual end-point to send messages to.- Parameters:
endpoint
- Where the channel points to- Returns:
- A reference to this Builder instance
-
payload
public Subscription.Channel.Builder payload(Code payload)
The mime type to send the payload in - either application/fhir+xml, or application/fhir+json. If the payload is not present, then there is no payload in the notification, just a notification. The mime type "text/plain" may also be used for Email and SMS subscriptions.- Parameters:
payload
- MIME type to send, or omit for no payload- Returns:
- A reference to this Builder instance
-
header
public Subscription.Channel.Builder header(String... header)
Additional headers / information to send as part of the notification.Adds new element(s) to the existing list
- Parameters:
header
- Usage depends on the channel type- Returns:
- A reference to this Builder instance
-
header
public Subscription.Channel.Builder header(Collection<String> header)
Additional headers / information to send as part of the notification.Replaces the existing list with a new one containing elements from the Collection
- Parameters:
header
- Usage depends on the channel type- Returns:
- A reference to this Builder instance
-
build
public Subscription.Channel build()
- Specified by:
build
in interfaceBuilder<Element>
- Specified by:
build
in classBackboneElement.Builder
- Returns:
- An immutable object of type
Subscription.Channel
- Throws:
IllegalStateException
- if the current state cannot be built into a valid Channel per the base specification
-
validate
protected void validate(Subscription.Channel channel)
-
from
protected Subscription.Channel.Builder from(Subscription.Channel channel)
-
-