mirror of https://github.com/asterisk/asterisk
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
207 lines
8.2 KiB
207 lines
8.2 KiB
\section{Introduction}
|
|
|
|
The Asterisk Calendaring API aims to be a generic interface for integrating
|
|
Asterisk with various calendaring technologies. The goal is to be able to
|
|
support reading and writing of calendar events as well as allowing notification
|
|
of pending events through the Asterisk dialplan.
|
|
|
|
There are three calendaring modules that ship with Asterisk that provide support
|
|
for iCalendar, CalDAV, and Microsoft Exchange Server calendars. All three
|
|
modules support event notification. Both CalDAV and Exchange support reading
|
|
and writing calendars, while iCalendar is a read-only format.
|
|
|
|
\section{Configuring Asterisk Calendaring}
|
|
|
|
All asterisk calendaring modules are configured through calender.conf. Each
|
|
calendar module can define its own set of required parameters in addition to the
|
|
parameters available to all calendar types. An effort has been made to keep all
|
|
options the same in all calendaring modules, but some options will diverge over
|
|
time as features are added to each module.
|
|
|
|
An example calendar.conf might look like:
|
|
\begin{astlisting}
|
|
\begin{verbatim}
|
|
[calendar_joe]
|
|
type = ical
|
|
url = https://example.com/home/jdoe/Calendar
|
|
user = jdoe
|
|
secret = mysecret
|
|
refresh = 15
|
|
timeframe = 600
|
|
autoreminder = 10
|
|
channel = SIP/joe
|
|
context = calendar_event_notify
|
|
extension = s
|
|
waittime = 30
|
|
\end{verbatim}
|
|
\end{astlisting}
|
|
|
|
\subsection{Module-independent settings}
|
|
|
|
The settings related to calendar event notification are handled by the core
|
|
calendaring API. These settings are:
|
|
\begin{description}
|
|
\item[autoreminder] This allows the overriding of any alarms that may or may not
|
|
be set for a calendar event. It is specified in minutes.
|
|
\item[refresh] How often to refresh the calendar data; specified in minutes.
|
|
\item[timeframe] How far into the future each calendar refresh should look. This
|
|
is the amount of data that will be visible to queries from the dialplan. This
|
|
setting should always be greater than or equal to the refresh setting or events
|
|
may be missed. It is specified in minutes.
|
|
\item[channel] The channel that should be used for making the notification
|
|
attempt.
|
|
\item[waittime] How long to wait, in seconds, for the channel to answer a notification
|
|
attempt.
|
|
\end{description}
|
|
|
|
There are two ways to specify how to handle a notification. One option is
|
|
providing a context and extension, while the other is providing an application
|
|
and the arguments to that application. One (and only one) of these options
|
|
should be provided.
|
|
|
|
\begin{description}
|
|
\item[context] The context of the extension to connect to the notification
|
|
channel
|
|
\item[extension] The extension to connect to the notification. Note that the
|
|
priority will always be 1.
|
|
\end{description}
|
|
|
|
or
|
|
|
|
\begin{description}
|
|
\item[app] The dialplan application to execute upon the answer of a notification
|
|
\item[appdata] The data to pass to the notification dialplan application
|
|
\end{description}
|
|
|
|
\subsection{Module-dependent settings}
|
|
|
|
Connection-related options are specific to each module. Currently, all modules
|
|
take a url, user, and secret for configuration and no other module-specific
|
|
settings have been implemented. At this time, no support for HTTP redirects has
|
|
been implemented, so it is important to specify the correct URL--paying attention
|
|
to any trailing slashes that may be necessary.
|
|
|
|
\section{Dialplan functions}
|
|
\subsection{Read functions}
|
|
|
|
The simplest dialplan query is the CALENDAR\_BUSY query. It takes a single
|
|
option, the name of the calendar defined, and returns "1" for busy (including
|
|
tentatively busy) and "0" for not busy.
|
|
|
|
For more information about a calendar event, a combination of CALENDAR\_QUERY
|
|
and CALENDAR\_QUERY\_RESULT is used. CALENDAR\_QUERY takes the calendar name
|
|
and optionally a start and end time in "unix time" (seconds from unix epoch). It
|
|
returns an id that can be passed to CALENDAR\_QUERY\_RESULT along with a field
|
|
name to return the data in that field. If multiple events are returned in the
|
|
query, the number of the event in the list can be specified as well. The available
|
|
fields to return are:
|
|
\begin{description}
|
|
\item[summary] A short summary of the event
|
|
\item[description] The full description of the event
|
|
\item[organizer] Who organized the event
|
|
\item[location] Where the event is located
|
|
\item[calendar] The name of the calendar from calendar.conf
|
|
\item[uid] The unique identifier associated with the event
|
|
\item[start] The start of the event in seconds since Unix epoch
|
|
\item[end] The end of the event in seconds since Unix epoch
|
|
\item[busystate] The busy state 0=Free, 1=Tentative, 2=Busy
|
|
\item[attendees] A comma separated list of attendees as stored in the event and
|
|
may include prefixes such as "mailto:".
|
|
\end{description}
|
|
|
|
When an event notification is sent to the dial plan, the CALENDAR\_EVENT
|
|
function may be used to return the information about the event that is causing
|
|
the notification. The fields that can be returned are the same as those from
|
|
CALENDAR\_QUERY\_RESULT.
|
|
\subsection{Write functions}
|
|
|
|
To write an event to a calendar, the CALENDAR\_WRITE function is used. This
|
|
function takes a calendar name and also uses the same fields as
|
|
CALENDAR\_QUERY\_RESULT. As a write function, it takes a set of comma-separated
|
|
values that are in the same order as the specified fields. For example:
|
|
\begin{astlisting}
|
|
\begin{verbatim}
|
|
CALENDAR_WRITE(mycalendar,summary,organizer,start,end,busystate)=
|
|
"My event","mailto:jdoe@example.com",228383580,228383640,1)
|
|
\end{verbatim}
|
|
\end{astlisting}
|
|
|
|
\section{Dialplan Examples}
|
|
\subsection{Office hours}
|
|
A common business PBX scenario is would be executing dialplan logic based on
|
|
when the business is open and the phones staffed. If the business is closed for
|
|
holidays, it is sometimes desirable to play a message to the caller stating why
|
|
the business is closed.
|
|
|
|
The standard way to do this in asterisk has been doing a series of GotoIfTime
|
|
statements or time-based include statements. Either way can be tedious and
|
|
requires someone with access to edit asterisk config files.
|
|
|
|
With calendaring, the adminstrator only needs to set up a calendar that contains
|
|
the various holidays or even recurring events specifying the office hours. A
|
|
custom greeting filename could even be contained in the description field for
|
|
playback. For example:
|
|
\begin{astlisting}
|
|
\begin{verbatim}
|
|
[incoming]
|
|
exten => 5555551212,1,Answer
|
|
exten => 5555551212,n,GotoIf(${CALENDAR_BUSY(officehours)}?closed:attendant,s,1)
|
|
exten => 5555551212,n(closed),Set(id=${CALENDAR_QUERY(office,${EPOCH},${EPOCH})})
|
|
exten => 5555551212,n,Set(soundfile=${CALENDAR_QUERY_RESULT(${id},description)})
|
|
exten => 5555551212,n,Playback($[${ISNULL(soundfile)} ? generic-closed :: ${soundfile}])
|
|
exten => 5555551212,n,Hangup
|
|
\end{verbatim}
|
|
\end{astlisting}
|
|
|
|
\subsection{Meeting reminders}
|
|
One useful application of Asterisk Calendaring is the ability to execute
|
|
dialplan logic based on an event notification. Most calendaring technologies
|
|
allow a user to set an alarm for an event. If these alarms are set on a calendar
|
|
that Asterisk is monitoring and the calendar is set up for event notification
|
|
via calendar.conf, then Asterisk will execute notify the specified channel at
|
|
the time of the alarm. If an overrided notification time is set with the
|
|
autoreminder setting, then the notification would happen at that time instead.
|
|
|
|
The following example demonstrates the set up for a simple event notification
|
|
that plays back a generic message followed by the time of the upcoming meeting.
|
|
calendar.conf.
|
|
\begin{astlisting}
|
|
\begin{verbatim}
|
|
[calendar_joe]
|
|
type = ical
|
|
url = https://example.com/home/jdoe/Calendar
|
|
user = jdoe
|
|
secret = mysecret
|
|
refresh = 15
|
|
timeframe = 600
|
|
autoreminder = 10
|
|
channel = SIP/joe
|
|
context = calendar_event_notify
|
|
extension = s
|
|
waittime = 30
|
|
\end{verbatim}
|
|
\end{astlisting}
|
|
|
|
\begin{astlisting}
|
|
\begin{verbatim}
|
|
[calendar_event_notify]
|
|
exten => s,1,Answer
|
|
exten => s,n,Playback(you-have-a-meeting-at)
|
|
exten => s,n,SayUnixTime(${CALENDAR_EVENT(start)})
|
|
exten => s,n,Hangup
|
|
\end{verbatim}
|
|
\end{astlisting}
|
|
|
|
\subsection{Writing an event}
|
|
Both CalDAV and Exchange calendar servers support creating new events. The
|
|
following example demonstrates writing a log of a call to a calendar.
|
|
\begin{astlisting}
|
|
\begin{verbatim}
|
|
[incoming]
|
|
exten => 6000,1,Set(start=${EPOCH})
|
|
exten => 6000,n,Dial(SIP/joe)
|
|
exten => h,1,Set(end=${EPOCH})
|
|
exten => h,n,Set(CALENDAR_WRITE(calendar_joe,summary,start,end)=Call from ${CALLERID(all)},${start},${end})
|
|
\end{verbatim}
|
|
\end{astlisting}
|