TAPI, aber richtig!

Die TAPI-Schnittstelle bietet auch die Variante, einen Wählvorgang asynchron (im Hintergrund) durchzuführen. Hinsichtlich dieser Funktionalität wurde die TAPI-Schnittstelle um eine neue Möglichkeit erweitert.

Einleitung

Mit der TAPI-Schnittstelle in CONZEPT 16 kann eine bestehende Anwendung leicht um Telefoniefunktionen erweitert werden. Die API bietet dabei sowohl Befehle zum Herstellen von Verbindungen, wie auch zur Überwachung von Leitungen zur Registrierung eingehender Anrufe. Darüber hinaus bietet die TAPI-Schnittstelle noch erweiterte Funktionen, wie z.B. Konferenzschaltungen und Weiterleitungen. Für eine Einführung in die TAPI-Schnittstelle empfehle ich dem interessierten Leser die Blog-Artikel TAPI Ereignisse und TAPI Monitoring.

TapiDial

Für die Durchführung eines Wählvorgangs bietet die TAPI-Schnittstelle den Befehl TapiDial(). Neben der zu wählenden Telefonnummer kann hier auch eine zusätzliche Option übergeben werden. Wird diese nicht angegeben, wird auf die Herstellung der Verbindung mit dem Gesprächspartner gewartet. Durch die Angabe von _TapiAsyncDial wird der Wählvorgang hingegen nur gestartet. Der Befehl kehrt also bereits zurück, während die Verbindung asynchron aufgebaut wird. Dies ermöglicht es dem Anrufer Ereignisse der TAPI-Schnittstelle zu überwachen und darauf zu reagieren.

TapiListen

Das Überwachen von Ereignissen geschieht durch den Befehl TapiListen(). Daraus ergibt sich die Problematik, dass zum einen durch den Befehl TapiDial() Ereignisse ausgelöst werden, die auch wiederum durch das Monitoring über TapiListen() erfasst werden. Die Ereignisse werden somit doppelt ausgelöst: einmal für die ausgehende Leitung (TapiDial()) und einmal für die überwachte Leitung (TapiListen()). Da die Call-ID der durch TapiDial() generierten Verbindung nicht bekannt ist, kann hier nicht unterschieden werden, welche Ereignisse sich auf die ausgehende bzw. auf die eingehende Leitung beziehen.

Sag mir wer du bist…

Das Problem kann ab der kommenden Version 5.7.07 durch eine weitere Option bei TapiDial() gelöst werden. Mit der Angabe von _TapiReturnCallID wird ein asynchroner Wählvorgang gestartet, wie dies bereits mit _TapiAsyncDial möglich ist. Jedoch liefert TapiDial() im erfolgreichen Fall die Call-ID des generierten Anrufs zurück.

// Asynchroner Wählvorgang mit Rückgabe der Call-ID.
gCallID # TapiDial('123456',_TapiReturnCallID). 

Da die Call-ID des ausgehenden Anrufes nun bekannt ist, können die Ereignisse im EvtTapi entsprechend gefiltert werden.

sub EvtTapi
(
  aEvt           : event;
  aTapiDevice    : handle;
  aCallID        : int;
  ...
)
: logic;
{
   if (gCallID > 0 and aCallID = gCallID)
   {
       // Ereignis wurde durch asynchrones TapiDial ausgelöst.
      ...
   }
   else
   {
       // Monitoring-Ereignis
      ...
   }
   ...
}

Klicken Sie hier, um die Nutzungsbedingungen für unseren Blog zu lesen.

Eine Antwort

Schreiben Sie einen Kommentar

Ihre E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert

Leave the field below empty!

Wünsche, Fragen oder Feedback sind willkommen:

Nutzungsbedingungen der Kommentarfunktion im Blog

1. Allgemeines

Vectorsoft AG („Anbieter“) stellt für Internetnutzer („Nutzer“) auf der Website
vectorsoft.de einen öffentlichen Blog bereit. Der öffentliche Blog dient dem
Informations- und Gedankenaustausch. Die Nutzer, welche sich mit Beiträgen und
Kommentaren beteiligen, verpflichten sich dazu, die Blog-Nutzungsbedingungen
einzuhalten und tragen die Verantwortung für die Richtigkeit und Angemessenheit
sowie Freiheit von Rechtsverletzungen ihrer Beiträge. Mit Nutzung der
Kommentarfunktion in unserem Blog akzeptieren Sie diese Nutzungsbedingungen.

2. Netiquette

Wir bitten Sie von persönlichen Angriffen und Provokationen aufgrund anderer
Meinungen abzusehen. Bitte argumentieren Sie sachlich und bewegen Sie sich auf
der Basis einer konstruktiven Diskussionskultur. Ihr Kommentar sollte stets im
Zusammenhang mit dem jeweiligen Thema sein, um Ausschweifungen in andere
Themenbereiche zu vermeiden. Das mehrmalige Posten desselben Kommentars
oder mehrerer ähnlicher Kommentare ist nicht erlaubt.

3. Verbot rechtswidriger Inhalte

Mit Absenden Ihres Kommentars bestätigen Sie, dass Sie keine Urheberrechte oder andere Rechte Dritter verletzen. Volksverhetzende, rassistische Äußerungen, Anleitungen zu Straftaten und deren Verherrlichung, Gewaltdarstellungen, pornografische Inhalte und Äußerungen, die Persönlichkeitsrechte verletzen sind untersagt.

4. Keine Werbung

Die Nutzung der Kommentarfunktion ist für kommerzielle oder parteipolitische
Zwecke nicht erlaubt. Werbliche Beiträge aller Art werden von uns umgehend
gelöscht.

5. Angaben zum Namen

Bei der Eingabe Ihres Namens achten Sie auf die zuvor genannten Grundsätze.

6. Quellenangaben

Bitte geben Sie bei der beabsichtigten Veröffentlichung von Zitaten oder Beiträgen
Dritter die jeweiligen Quellen an und erläutern dessen Bezug zum Blogbeitrag.

7. Verstoß gegen die Nutzungsbedingungen

Beiträge, die gegen diese Richtlinie verstoßen werden umgehend gelöscht. Sollten
Sie selbst Verstöße bemerken, so senden Sie uns bitte den Link des betreffenden
Kommentars per E-Mail an . Wir weisen ausdrücklich daraufhin, dass wir einzelne Nutzer bei wiederholten oder schweren Verstößen gegen diese
Nutzungsbedingungen ausschließen werden.

Stand: Sept. 2024

Deine Trial Version - jetzt anfordern!

Teste yeet - unverbindlich und kostenfrei

IHRE EVALUIERUNGSLIZENZ - JETZT ANFORDERN!

TESTEN SIE DIE CONZEPT 16 VOLLVERSION - UNVERBINDLICH und KOSTENFREI

Melden Sie sich bei unserem Newsletter an

Anrede*
     
Zustimmung zur Datenverarbeitung gem. DSGVO*



WordPress Cookie-Hinweis von Real Cookie Banner