OpenJAUS SAE SDK  6.0.0
Public Member Functions | Static Public Member Functions | List of all members
openjaus::core_v1_1::AccessControlInterface Class Referenceabstract

Provides an abstract interface for the AccessControl service. More...

#include <AccessControlInterface.h>

Inherits openjaus::core_v1_1::EventsInterface.

Inherited by openjaus::core_v1_1::ManagementInterface [virtual], openjaus::core_v1_1::services::AccessControl [virtual], openjaus::core_v1_1::TimeInterface [virtual], openjaus::environment_v1_0::RangeSensorInterface [virtual], openjaus::environment_v1_0::VisualSensorInterface [virtual], openjaus::manipulator_v1_0::ManipulatorEndEffectorPoseSensorInterface [virtual], openjaus::manipulator_v1_0::ManipulatorEndEffectorVelocityStateSensorInterface [virtual], openjaus::mobility_v1_0::GlobalPoseSensorInterface [virtual], openjaus::mobility_v1_0::LocalPoseSensorInterface [virtual], openjaus::ugv_v1_0::AnnunciatorInterface [virtual], openjaus::ugv_v1_0::IlluminationInterface [virtual], openjaus::ugv_v1_0::OdometryInterface [virtual], and openjaus::ugv_v1_0::PowerPlantManagerInterface [virtual].

Public Member Functions

virtual ~AccessControlInterface ()
 
virtual void init ()=0
 
virtual ReportControl getReportControl (QueryControl *queryControl)=0
 Send a Report Control message with the specified control value Send a Report Control message with the specified control value. More...
 
virtual ReportAuthority getReportAuthority (QueryAuthority *queryAuthority)=0
 Send a Report Authority message to querying client reporting the current authority value of this service Send a Report Authority message to querying client reporting the current authority value of this service. More...
 
virtual ReportTimeout getReportTimeout (QueryTimeout *queryTimeout)=0
 Send a Report Timeout message specifying the timeout period of this service Send a Report Timeout message specifying the timeout period of this service. More...
 
virtual bool setAuthority (RequestControl *requestControl)=0
 Set the current authority value of this service to the specified authority Set the current authority value of this service to the specified authority. More...
 
virtual bool setAuthority (SetAuthority *setAuthority)=0
 Set the current authority value of this service to the specified authority Set the current authority value of this service to the specified authority. More...
 
virtual bool resetTimer (RequestControl *requestControl)=0
 Reset the timer Reset the timer. More...
 
virtual bool sendConfirmControlInsufficientAuthority (RequestControl *requestControl)=0
 Send a confirm control message with the specified response code to requesting client Send a confirm control message with the specified response code to requesting client. More...
 
virtual bool sendConfirmControlAccepted (RequestControl *requestControl)=0
 Send a confirm control message with the specified response code to requesting client Send a confirm control message with the specified response code to requesting client. More...
 
virtual bool sendRejectControlToController (RequestControl *requestControl)=0
 SendRejectControlToController action with input RequestControl. More...
 
virtual bool sendRejectControlReleased (ReleaseControl *releaseControl)=0
 SendRejectControlReleased action with input ReleaseControl. More...
 
virtual bool sendRejectControlReleased (AccessControlTimeout *accessControlTimeout)=0
 SendRejectControlReleased action with input AccessControlTimeout. More...
 
virtual bool storeAddress (RequestControl *requestControl)=0
 StoreAddress action with input RequestControl. More...
 
virtual bool updateControlledList (ConfirmControl *confirmControl)=0
 Modifies list of controlled components based on confirm or reject messages Modifies list of controlled components based on confirm or reject messages. More...
 
virtual bool updateControlledList (RejectControl *rejectControl)=0
 Modifies list of controlled components based on confirm or reject messages Modifies list of controlled components based on confirm or reject messages. More...
 
virtual bool isDefaultAuthorityGreater (RequestControl *requestControl)=0
 True if the default authority code of this service is greater than the authority code of the client service that triggered the corresponding transition True if the default authority code of this service is greater than the authority code of the client service that triggered the corresponding transition. More...
 
virtual bool isCurrentAuthorityLess (RequestControl *requestControl)=0
 True if the current authority value of this service is less than the authority code of the client service that triggered the corresponding transition True if the current authority value of this service is less than the authority code of the client service that triggered the corresponding transition. More...
 
virtual bool isAuthorityValid (SetAuthority *setAuthority)=0
 True if the value of the authority code received from the client is less than or equal to the current authority value of this service, but greater than or equal to the receiving component’s default authority True if the value of the authority code received from the client is less than or equal to the current authority value of this service, but greater than or equal to the receiving component’s default authority. More...
 
virtual bool isControllingClient (model::Message *message)=0
 True if the message that triggered the transition is received from the client that is in control of this service True if the message that triggered the transition is received from the client that is in control of this service. More...
 
- Public Member Functions inherited from openjaus::core_v1_1::EventsInterface
virtual ~EventsInterface ()
 
virtual bool createEvent (CreateEvent *createEvent)=0
 CreateEvent action with input CreateEvent. More...
 
virtual bool processEvent (ProcessEventRequest *processEventRequest)=0
 ProcessEvent action with input ProcessEventRequest. More...
 
virtual bool resetEventTimer (CreateEvent *createEvent)=0
 ResetEventTimer action with input CreateEvent. More...
 
virtual bool resetEventTimer (UpdateEvent *updateEvent)=0
 ResetEventTimer action with input UpdateEvent. More...
 
virtual bool updateEvent (CreateEvent *createEvent)=0
 UpdateEvent action with input CreateEvent. More...
 
virtual bool updateEvent (UpdateEvent *updateEvent)=0
 UpdateEvent action with input UpdateEvent. More...
 
virtual bool cancelEvent (CancelEvent *cancelEvent)=0
 CancelEvent action with input CancelEvent. More...
 
virtual bool stopEventTimer (CancelEvent *cancelEvent)=0
 StopEventTimer action with input CancelEvent. More...
 
virtual RejectEventRequest getRejectEventRequest (CreateEvent *createEvent)=0
 Send action for RejectEventRequest with input message CreateEvent. More...
 
virtual RejectEventRequest getRejectEventRequest (UpdateEvent *updateEvent)=0
 Send action for RejectEventRequest with input message UpdateEvent. More...
 
virtual RejectEventRequest getRejectEventRequest (CancelEvent *cancelEvent)=0
 Send action for RejectEventRequest with input message CancelEvent. More...
 
virtual ConfirmEventRequest getConfirmEventRequest (CreateEvent *createEvent)=0
 Send action for ConfirmEventRequest with input message CreateEvent. More...
 
virtual ConfirmEventRequest getConfirmEventRequest (UpdateEvent *updateEvent)=0
 Send action for ConfirmEventRequest with input message UpdateEvent. More...
 
virtual ConfirmEventRequest getConfirmEventRequest (CancelEvent *cancelEvent)=0
 Send action for ConfirmEventRequest with input message CancelEvent. More...
 
virtual ReportEvents getReportEvents (QueryEvents *queryEvents)=0
 Send action for ReportEvents with input message QueryEvents. More...
 
virtual ReportEventTimeout getReportEventTimeout (QueryEventTimeout *queryEventTimeout)=0
 Send action for ReportEventTimeout with input message QueryEventTimeout. More...
 
virtual bool confirmEvent (ConfirmEventRequest *confirmEventRequest)=0
 ConfirmEvent action with input ConfirmEventRequest. More...
 
virtual bool rejectEvent (RejectEventRequest *rejectEventRequest)=0
 RejectEvent action with input RejectEventRequest. More...
 
virtual bool handleIncomingEvent (Event *event)=0
 HandleIncomingEvent action with input Event. More...
 
virtual bool handleReportEvents (ReportEvents *reportEvents)=0
 HandleReportEvents action with input ReportEvents. More...
 
virtual bool isSupported (CreateEvent *createEvent)=0
 isSupported condition. More...
 
virtual bool isSupported (UpdateEvent *updateEvent)=0
 isSupported condition. More...
 
virtual bool eventExists (CreateEvent *createEvent)=0
 eventExists condition. More...
 
virtual bool eventExists (UpdateEvent *updateEvent)=0
 eventExists condition. More...
 
virtual bool eventExists (CancelEvent *cancelEvent)=0
 eventExists condition. More...
 
- Public Member Functions inherited from openjaus::core_v1_1::TransportInterface
virtual ~TransportInterface ()
 
virtual bool enqueue (model::Trigger *trigger)=0
 Convert the destination address into an unsigned integer such that the ComponentID maps to the least significant byte, NodeID to the next least significant byte and SubsystemID maps onto the remaining two bytes of the integer. More...
 
virtual bool broadcastLocalEnqueue (model::Trigger *trigger)=0
 Package the message as specified by the transport layer specification and send it to all endpoints in the local subsystem. More...
 
virtual bool broadcastGlobalEnqueue (model::Trigger *trigger)=0
 Package the message as specified by the transport layer specification and send it to all endpoints on all subsystems. More...
 
virtual bool sendMessage (model::Trigger *trigger)=0
 SendMessage action with input SendMessage. More...
 
virtual bool broadcastToNode (model::Trigger *trigger)=0
 Broadcasts message to all components within the local node Broadcasts message to all components within the local node. More...
 
virtual bool broadcastToSubsystem (model::Trigger *trigger)=0
 Broadcasts a given message to all nodes in the local subsystem (equivalent to broadcast local enqueue) Broadcasts a given message to all nodes in the local subsystem (equivalent to broadcast local enqueue) More...
 
virtual bool broadcastToSystem (model::Trigger *trigger)=0
 Broadcasts the message to all subsystems on the JAUS network (equivalent to broadcast global enqueue) Broadcasts the message to all subsystems on the JAUS network (equivalent to broadcast global enqueue) More...
 
virtual bool checkTransportPolicy (model::Trigger *trigger)=0
 CheckTransportPolicy action with input CheckTransportPolicy. More...
 
virtual ReportTransportPolicy getReportTransportPolicy (QueryTransportPolicy *queryTransportPolicy)=0
 Send action for ReportTransportPolicy with input message QueryTransportPolicy. More...
 
virtual bool storeTransportPolicy (ReportTransportPolicy *reportTransportPolicy)=0
 StoreTransportPolicy action with input ReportTransportPolicy. More...
 

Static Public Member Functions

static OPENJAUS_DEPRECATED model::Service AccessControlService ()
 Builds a default instance of the AccessControl Service and populates the URI and Version numbers. More...
 
static OPENJAUS_DEPRECATED std::string AccessControlUri ()
 Static accessor for Service URI. More...
 
- Static Public Member Functions inherited from openjaus::core_v1_1::EventsInterface
static OPENJAUS_DEPRECATED model::Service EventsService ()
 Builds a default instance of the Events Service and populates the URI and Version numbers. More...
 
static OPENJAUS_DEPRECATED std::string EventsUri ()
 Static accessor for Service URI. More...
 
- Static Public Member Functions inherited from openjaus::core_v1_1::TransportInterface
static OPENJAUS_DEPRECATED model::Service TransportService ()
 Builds a default instance of the Transport Service and populates the URI and Version numbers. More...
 
static OPENJAUS_DEPRECATED std::string TransportUri ()
 Static accessor for Service URI. More...
 

Detailed Description

The Access Control service offers a basic interface for acquiring preemptable exclusive control to one or more related services that utilize this function. Once the exclusive control is established, the related services shall only execute commands originating from the controlling component. The authority code parameter of this service is used for preemption and is to be set equal to that of its controlling client. This service always grants control to the highest authority client that is requesting exclusive control. Commands from all other clients are ignored unless from a client with higher authority. service maintains two values, a default value and a current value of a field called authority code. The default value is the value that the service is pre-configured with. Access is provided to clients based on the value of their authority code in comparison to the current value of this service. transitions between the Available and NotAvailable nested states are behaviors that are deferred to service definitions that derive from this service.



URI: urn:jaus:jss:core:AccessControl

Version: 1.1

Inherits From:

Constructor & Destructor Documentation

◆ ~AccessControlInterface()

virtual openjaus::core_v1_1::AccessControlInterface::~AccessControlInterface ( )
inlinevirtual

Member Function Documentation

◆ AccessControlService()

static OPENJAUS_DEPRECATED model::Service openjaus::core_v1_1::AccessControlInterface::AccessControlService ( )
inlinestatic
Returns
model::Service - The populated service.

◆ AccessControlUri()

static OPENJAUS_DEPRECATED std::string openjaus::core_v1_1::AccessControlInterface::AccessControlUri ( )
inlinestatic
Returns
std::string - Service URI

◆ getReportAuthority()

virtual ReportAuthority openjaus::core_v1_1::AccessControlInterface::getReportAuthority ( QueryAuthority queryAuthority)
pure virtual
Parameters
[in]queryAuthority- Input Trigger.
Returns
ReportAuthority Output Message.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ getReportControl()

virtual ReportControl openjaus::core_v1_1::AccessControlInterface::getReportControl ( QueryControl queryControl)
pure virtual
Parameters
[in]queryControl- Input Trigger.
Returns
ReportControl Output Message.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ getReportTimeout()

virtual ReportTimeout openjaus::core_v1_1::AccessControlInterface::getReportTimeout ( QueryTimeout queryTimeout)
pure virtual
Parameters
[in]queryTimeout- Input Trigger.
Returns
ReportTimeout Output Message.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ init()

virtual void openjaus::core_v1_1::AccessControlInterface::init ( )
pure virtual

◆ isAuthorityValid()

virtual bool openjaus::core_v1_1::AccessControlInterface::isAuthorityValid ( SetAuthority setAuthority)
pure virtual
Parameters
[in]setAuthority- Input Trigger.
Returns
Whether the condition is true.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ isControllingClient()

virtual bool openjaus::core_v1_1::AccessControlInterface::isControllingClient ( model::Message message)
pure virtual
Parameters
[in]message- Input Trigger.
Returns
Whether the condition is true.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ isCurrentAuthorityLess()

virtual bool openjaus::core_v1_1::AccessControlInterface::isCurrentAuthorityLess ( RequestControl requestControl)
pure virtual
Parameters
[in]requestControl- Input Trigger.
Returns
Whether the condition is true.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ isDefaultAuthorityGreater()

virtual bool openjaus::core_v1_1::AccessControlInterface::isDefaultAuthorityGreater ( RequestControl requestControl)
pure virtual
Parameters
[in]requestControl- Input Trigger.
Returns
Whether the condition is true.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ resetTimer()

virtual bool openjaus::core_v1_1::AccessControlInterface::resetTimer ( RequestControl requestControl)
pure virtual
Parameters
[in]requestControl- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::ManagementInterface, openjaus::core_v1_1::services::Management, and openjaus::core_v1_1::services::AccessControl.

◆ sendConfirmControlAccepted()

virtual bool openjaus::core_v1_1::AccessControlInterface::sendConfirmControlAccepted ( RequestControl requestControl)
pure virtual
Parameters
[in]requestControl- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ sendConfirmControlInsufficientAuthority()

virtual bool openjaus::core_v1_1::AccessControlInterface::sendConfirmControlInsufficientAuthority ( RequestControl requestControl)
pure virtual
Parameters
[in]requestControl- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ sendRejectControlReleased() [1/2]

virtual bool openjaus::core_v1_1::AccessControlInterface::sendRejectControlReleased ( ReleaseControl releaseControl)
pure virtual

SendRejectControlReleased action with input ReleaseControl.

Parameters
[in]releaseControl- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ sendRejectControlReleased() [2/2]

virtual bool openjaus::core_v1_1::AccessControlInterface::sendRejectControlReleased ( AccessControlTimeout accessControlTimeout)
pure virtual

SendRejectControlReleased action with input AccessControlTimeout.

Parameters
[in]accessControlTimeout- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ sendRejectControlToController()

virtual bool openjaus::core_v1_1::AccessControlInterface::sendRejectControlToController ( RequestControl requestControl)
pure virtual

SendRejectControlToController action with input RequestControl.

Parameters
[in]requestControl- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::ManagementInterface, openjaus::core_v1_1::services::Management, and openjaus::core_v1_1::services::AccessControl.

◆ setAuthority() [1/2]

virtual bool openjaus::core_v1_1::AccessControlInterface::setAuthority ( RequestControl requestControl)
pure virtual
Parameters
[in]requestControl- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ setAuthority() [2/2]

virtual bool openjaus::core_v1_1::AccessControlInterface::setAuthority ( SetAuthority setAuthority)
pure virtual
Parameters
[in]setAuthority- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ storeAddress()

virtual bool openjaus::core_v1_1::AccessControlInterface::storeAddress ( RequestControl requestControl)
pure virtual

StoreAddress action with input RequestControl.

Parameters
[in]requestControl- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ updateControlledList() [1/2]

virtual bool openjaus::core_v1_1::AccessControlInterface::updateControlledList ( ConfirmControl confirmControl)
pure virtual
Parameters
[in]confirmControl- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::services::AccessControl.

◆ updateControlledList() [2/2]

virtual bool openjaus::core_v1_1::AccessControlInterface::updateControlledList ( RejectControl rejectControl)
pure virtual
Parameters
[in]rejectControl- Input Trigger.
Returns
Whether the message was properly processed by this action.

Implemented in openjaus::core_v1_1::services::AccessControl.


The documentation for this class was generated from the following file: