Interface CyclicTimePeriodSmartCalendarSession

All Superinterfaces:
AutoCloseable, Closeable, OsidSession, OsidSession

public interface CyclicTimePeriodSmartCalendarSession extends OsidSession

This session manages queries and sequencing to create "smart" dynamic catalogs. A CyclicTimePeriodQuery can be retrieved from this session and mapped to this Calendar to create a virtual collection of TomePeriods . The entries may be sequenced using the CyclicTimePeriodSearchOrder from this session.

This Calendar has a default query that matches any cyclic time period and a default search order that specifies no sequencing. The queries may be examined using a CyclicTimePeriodQueryInspector . The query may be modified by converting the inspector back to a CyclicTimePeriodQuery .

  • Method Details

    • getCalendarId

      Id getCalendarId()
      Gets the Calendar Id associated with this session.
      Returns:
      the Calendar Id associated with this session
      Compliance:
      mandatory - This method must be implemented.
    • getCalendar

      Gets the Calendar associated with this session.
      Returns:
      the Calendar associated with this session
      Throws:
      OperationFailedException - unable to complete request
      PermissionDeniedException - authorization failure
      Compliance:
      mandatory - This method must be implemented.
    • canManageSmartCalendars

      boolean canManageSmartCalendars()
      Tests if this user can manage smart calendars. A return of true does not guarantee successful authorization. A return of false indicates that it is known all methods in this session will result in a PERMISSION_DENIED . This is intended as a hint to an application that may opt not to offer smart operations.
      Returns:
      false if smart calendar methods are not authorized, true otherwise
      Compliance:
      mandatory - This method must be implemented.
    • getCyclicTimePeriodQuery

      CyclicTimePeriodQuery getCyclicTimePeriodQuery()
      Gets a cyclic time period query.
      Returns:
      the cyclic time period query
      Compliance:
      mandatory - This method must be implemented.
    • getCyclicTimePeriodSearchOrder

      CyclicTimePeriodSearchOrder getCyclicTimePeriodSearchOrder()
      Gets a cyclic time period search order.
      Returns:
      the cyclic time period search order
      Compliance:
      mandatory - This method must be implemented.
    • applyCyclicTimePeriodQuery

      void applyCyclicTimePeriodQuery(CyclicTimePeriodQuery cyclicTimePeriodQuery) throws OperationFailedException, PermissionDeniedException
      Applies a cyclic time period query to this calendar.
      Parameters:
      cyclicTimePeriodQuery - the cyclic time period query
      Throws:
      NullArgumentException - cyclicTimePeriodQuery is null
      OperationFailedException - unable to complete request
      PermissionDeniedException - authorization failure occurred
      UnsupportedException - cyclicTimePeriodQuery not of this service
      Compliance:
      mandatory - This method must be implemented.
    • inspectCyclicTimePeriodQuery

      Gets a cyclic time period query inspector for this calendar.
      Returns:
      the cyclic time period query inspector
      Throws:
      OperationFailedException - unable to complete request
      PermissionDeniedException - authorization failure occurred
      Compliance:
      mandatory - This method must be implemented.
    • applyCyclicTimePeriodSequencing

      void applyCyclicTimePeriodSequencing(CyclicTimePeriodSearchOrder cyclicTimePeriodSearchOrder) throws OperationFailedException, PermissionDeniedException
      Applies a cyclic time period search order to this calendar.
      Parameters:
      cyclicTimePeriodSearchOrder - the cyclic time period search order
      Throws:
      NullArgumentException - cyclicTimePeriodSearchOrder is null
      OperationFailedException - unable to complete request
      PermissionDeniedException - authorization failure occurred
      UnsupportedException - cyclicTimePeriodSearchOrder not of this service
      Compliance:
      mandatory - This method must be implemented.
    • getCyclicTimePeriodQueryFromInspector

      CyclicTimePeriodQuery getCyclicTimePeriodQueryFromInspector(CyclicTimePeriodQueryInspector cyclicTimePeriodQueryInspector)
      Gets a cyclic time period query from an inspector.
      Parameters:
      cyclicTimePeriodQueryInspector - a cyclic time period query inspector
      Returns:
      the cyclic time period query interface
      Throws:
      NullArgumentException - cyclicTimePeriodQueryInspector is null
      UnsupportedException - cyclicTimePeriodQueryInspector is not of this service
      Compliance:
      mandatory - This method must be implemented.