pub struct ConsentProvision {Show 14 fields
pub id: Option<String>,
pub extension: Option<Vec<Box<Extension>>>,
pub modifierExtension: Option<Vec<Box<Extension>>>,
pub type_: Option<Box<ConsentProvisionType>>,
pub period: Option<Box<Period>>,
pub actor: Option<Vec<ConsentProvisionActor>>,
pub action: Option<Vec<Box<CodeableConcept>>>,
pub securityLabel: Option<Vec<Box<Coding>>>,
pub purpose: Option<Vec<Box<Coding>>>,
pub class: Option<Vec<Box<Coding>>>,
pub code: Option<Vec<Box<CodeableConcept>>>,
pub dataPeriod: Option<Box<Period>>,
pub data: Option<Vec<ConsentProvisionData>>,
pub provision: Option<Vec<ConsentProvision>>,
}Expand description
An exception to the base policy of this consent. An exception can be an addition or removal of access permissions.
Fields§
§id: Option<String>Unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.
extension: Option<Vec<Box<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.
modifierExtension: Option<Vec<Box<Extension>>>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).
type_: Option<Box<ConsentProvisionType>>Action to take - permit or deny - when the rule conditions are met. Not permitted in root rule, required in all nested rules.
period: Option<Box<Period>>The timeframe in this rule is valid.
actor: Option<Vec<ConsentProvisionActor>>Who or what is controlled by this rule. Use group to identify a set of actors by some property they share (e.g. ‘admitting officers’).
action: Option<Vec<Box<CodeableConcept>>>Actions controlled by this Rule.
securityLabel: Option<Vec<Box<Coding>>>A security label, comprised of 0..* security label fields (Privacy tags), which define which resources are controlled by this exception.
purpose: Option<Vec<Box<Coding>>>The context of the activities a user is taking - why the user is accessing the data - that are controlled by this rule.
class: Option<Vec<Box<Coding>>>The class of information covered by this rule. The type can be a FHIR resource type, a profile on a type, or a CDA document, or some other type that indicates what sort of information the consent relates to.
code: Option<Vec<Box<CodeableConcept>>>If this code is found in an instance, then the rule applies.
dataPeriod: Option<Box<Period>>Clinical or Operational Relevant period of time that bounds the data controlled by this rule.
data: Option<Vec<ConsentProvisionData>>The resources controlled by this rule if specific resources are referenced.
provision: Option<Vec<ConsentProvision>>Rules which provide exceptions to the base rule or subrules.
Trait Implementations§
Source§impl Clone for ConsentProvision
impl Clone for ConsentProvision
Source§fn clone(&self) -> ConsentProvision
fn clone(&self) -> ConsentProvision
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for ConsentProvision
impl Debug for ConsentProvision
Source§impl Default for ConsentProvision
impl Default for ConsentProvision
Source§fn default() -> ConsentProvision
fn default() -> ConsentProvision
Source§impl FHIRJSONDeserializer for ConsentProvision
impl FHIRJSONDeserializer for ConsentProvision
fn from_json_str(s: &str) -> Result<Self, DeserializeError>
fn from_serde_value( obj: &Value, context: Context<'_>, ) -> Result<Self, DeserializeError>
Source§impl FHIRJSONSerializer for ConsentProvision
impl FHIRJSONSerializer for ConsentProvision
fn serialize_value( &self, writer: &mut dyn Write, ) -> Result<bool, SerializeError>
fn serialize_extension( &self, writer: &mut dyn Write, ) -> Result<bool, SerializeError>
fn serialize_field( &self, field: &str, writer: &mut dyn Write, ) -> Result<bool, SerializeError>
fn is_fp_primitive(&self) -> bool
Source§impl MetaValue for ConsentProvision
impl MetaValue for ConsentProvision
fn fields(&self) -> Vec<&'static str>
fn get_field<'a>(&'a self, field: &str) -> Option<&'a dyn MetaValue>
fn get_field_mut<'a>(&'a mut self, field: &str) -> Option<&'a mut dyn MetaValue>
fn get_index_mut<'a>( &'a mut self, index: usize, ) -> Option<&'a mut dyn MetaValue>
fn get_index<'a>(&'a self, _index: usize) -> Option<&'a dyn MetaValue>
fn typename(&self) -> &'static str
fn as_any(&self) -> &dyn Any
fn flatten(&self) -> Vec<&dyn MetaValue>
Auto Trait Implementations§
impl Freeze for ConsentProvision
impl RefUnwindSafe for ConsentProvision
impl Send for ConsentProvision
impl Sync for ConsentProvision
impl Unpin for ConsentProvision
impl UnwindSafe for ConsentProvision
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more