Zusammenfassung:
Ab der SwyxWare v4.00 ist es möglich eigenen Skript Code in den Grafischen Skript Editor (GSE) einzufügen. Die Funktionalität des GSE steht Ihnen nur zur Verfügung, wenn Sie das Option Pack - Extended Call Routing lizensiert haben.
Dieser Artikel beschreibt wie man eine einfache Anruferüberprüfung in einer Datenbank (z.B. MS Access)implementiert.
Weitere Artikel dieser Serie:
- Eigener VBScript Code - Call Logging in Textdatei
- Eigener VBScript Code - Call Logging in Datenbank
- Eigener VBScript Code - Auf Feiertag überprüfen
Weitere Informationen zu den Neuerungen im Grafischen Skript Editor finden Sie in dem Artikel:
Information:
Installation der Beispielregeln
Laden Sie alle Beispielregeln über den unten angegebenen Link herunter und kopieren Sie die Datein in das Verzeichnis
c:\gse_demo
Um die Datei CheckCaller.rse in den Call Routing Manager (CRM) bzw. Grafischen Skript Editor (GSE) zu laden, gehen Sie bitte wie folgt vor:
- Starten Sie den Call Routing Manager.
- Klicken Sie auf Neu...
- Wählen Sie den Grafischen Skript Editor und klicken Sie auf Ok.
- Öffnen Sie das Menü Datei | Impotieren... im GSE.
- Wählen Sie die Datei CheckCaller.rse. Die Regel wird nun importiert und sieht wie folgt aus:
Grafischer Skript Editor
- Speichern Sie die Regel über das Menü Datei | Speichern.
- Schliessen Sie den GSE.
- Aktivieren Sie die neue Regel durch Verschieben in die rechte Liste im CRM.
Call Routing Manager
Wie das Skript funktioniert:
Eigener Skriptcode kann nur in dem Regel Start Block hinzugefügt werden. Alle Konstanten, Variablen und Funktionen die Sie hier definieren stehen Ihnen in allen Blöcken dieses Skriptes zur Verfügung, z.B. im Auswerten Block. Bitte beachten Sie, dass der GSE dem finalen Skript das VBScript Statement option explicit hinzufügt. Dies hat zur Folge, dass Sie alle Variablen innerhalb des Skriptes vor der Benutzung definieren müssen.
Eigenschaften - Regel Start
Um die Rufnummer des ankommenden Rufes in der Datenbank zu überprüfen, verwenden wir einen Auswerten Block. Als Vergleich geben wir lediglich den Name unserer Funktion KnownCallerId mit der Rufnummer der Anrufers an.
Eigenschaften - Check Caller in DB
Diese Funktion liefert Wahr falls die Rufnummer in der Datenbank bekannt ist, andernfalls liefert Sie Falsch. Damit ist sie auch direkt in dem Auswerten Block verwendbar, denn ein Vergleich x = y liefert auch nur Wahr oder Falsch. Für den Fall, dass Wahr zurück geliefert wird, geht es weiter zu dem Ansage abspielen Block welcher einfach nur die Datei Beep.wav abspielt. Andernfalls geht es direkt an das Ende der Regel. Und so sieht der Sktipt Code aus
- ' CursorTypeEnum Values
- Const adOpenForwardOnly = 0
- Const adOpenKeyset = 1
- Const adOpenDynamic = 2
- Const adOpenStatic = 3
- ' LockTypeEnum Values
- Const adLockReadOnly = 1
- Const adLockPessimistic = 2
- Const adLockOptimistic = 3
- Const adLockBatchOptimistic = 4
- ' CommandTypeEnum Values
- Const adCmdUnknown = &H0008
- Const adCmdText = &H0001
- Const adCmdTable = &H0002
- Const adCmdStoredProc = &H0004
- Function KnownCallerId ( callerID )
- Dim bReturn
- bReturn = false
- Dim sDsn
- sDsn = "Provider=Microsoft.Jet.OLEDB.4.0;" & _
- "Data Source=c:\gse_demo\demo.mdb"
- ' open connection to database
- Dim db
- Set db = CreateObject("ADODB.Connection")
- db.Open sDsn
- ' open recordset
- Dim sSQL
- Dim rs
- sSQL = "select * from callers where callerid = '" & _
- callerID & "'"
- Set rs = CreateObject("ADODB.Recordset")
- rs.Open sSQL, db, adOpenDynamic, adLockOptimistic, _
- adCmdText
- ' if there are records in recordset,
- ' this caller seems to be known
- bReturn = not rs.EOF
- rs.Close
- Set rs = Nothing
- db.Close
- Set db = Nothing
- KnownCallerId = bReturn
- End Function
Nachdem die Regel aktiviert wurde wird immer wenn ein bekannter Anrufer anruft (in diesem Beispiel ist es der Benutzer mit der Durchwahl 100) ein Piep abgespielt. Andernfalls geschieht nichts. Bitte beachten Sie, dass wir die Regel über den Aufgang Regel übersprungen verlassen. Dies ermöglicht es uns im Anschluss noch weitere Regeln in unserem Callrouting auszuführen.
Hinweise
- Alle Callrouting Skripte, und somit auch der eigene Skript Code, werden unter dem SwyxWare Service Accountausgeführt. Achten Sie also bitte darauf, dass dieser Account die nötigen Rechte hat, die Datei/Datenbank an dem gewünschten Ort zu bearbeiten.
- In diesem Beispiel wird eine MS Access Datenbank verwendet. Für Demonstrationszwecke ist diese durchaus geeignet, nicht jedoch für Produktionsumgebungen! Verwenden Sie in einer Produktionsumgebung ausschliesslich vollwertige Datenbank wie z.B. den MS SQL Server!
-
Das Skript in diesem Beispiel enthält um es übersichtlich zu halten, keine Fehlerbehandlung. Das heisst, wenn z.B. bei dem Zugriff auf die Datei/Datenbank ein Fehler auftritt, wird dieser nicht abgefangen, sondern führt statt dessen dazu, dass das Skript beendet wird, und der Ruf verloren geht. Sollten Sie das Server Tracing für SvrScript auf Info3 gesetzt haben, so wird die originale Fehlermeldung der Microsoft Script Engine dort protokolliert.
Um eine eigene Fehlerbehandlung einzufügen müssen Sie zunächst die Standard-Fehlerbehandlung der Script Engine ausschalten:
On Error Resume Next Diese Zeile fügen Sie am Besten als erste Zeile in Ihren Funktionen einen. Nun muss nach jedem Aufruf der Potentiell zu einem Fehler führen kann, eine Fehlerabfrage erfolgen:
' Open connection to Database db.Open sDsn If Err <> 0 then 'do something, e.g.: FunctionName = False Exit Function End If -
Neben der in diesem Beispiel gezeigten, sogenannten DSN-less Connection zur Datenbank
kann natürlich jede beliebige Datenbank über ODBC angesprochen werden, sofern eine
entsprechende ODBC Datenquelle auf dem SwyxServer Rechner konfiguriert wurde. Die
nötigen Äderungen im Skript beschränkten sich auf eine einzige Zeile. Anstelle vonsDsn = "Provider=Microsoft.Jet.OLEDB.4.0;" & _
"Data Source=c:\gse_demo\demo.mdb"ist lediglich der Name der ODBC Datenquelle anzugeben
sDsn = "dsn=MyDatabase"
Sollte die Datenbank eine Anmeldung erfordern, so können die Zugangsdaten ebenfalls in
diesem sogenannten Connection String angegeben werden:sDsn = "dsn=MyDatabase;uid=MyName;pwd=MyPassword"
Weitere Beispiele finden Sie über den unter den Referenzen angegebenen Link.
Referenzen:
- Eigener VBScript Code - Auf Feiertag überprüfen
kb2285-Bank_Holiday_Check.zip
Dieser Swyx Forum Wiki Artikel dokumentiert die im GSE eingebauten Funktionen.
- Swyx Forum - GSE build in functions
https://www.swyx-forum.com/forum/151-gse-build-in-functions/
Dieser Swyx Forum Wiki Artikel dokumentiert die SwyxServer Script API.
- Swyx Forum - Server Script API
https://www.swyx-forum.com/forum/150-server-script-api/
Dieser Swyx Forum Wiki Artikel dokumentiert alle in VBScript vorhandenen Funktionen.
- Swyx Forum - VBScript functions
https://www.swyx-forum.com/forum/152-vbscript-build-in-functions/
Informationen anderer Anbieter, die in diesem Artikel zur Verfügung gestellt werden, sollen bei der Suche nach technischen Informationen helfen. Die Inhalte können ohne weitere Ankündigung geändert werden. Swyx garantiert nicht für die Güte von Inhalten anderer Anbieter, noch ist Swyx für diese verantwortlich.
Kommentare
0 Kommentare
Zu diesem Beitrag können keine Kommentare hinterlassen werden.