Voici notre article que nous avons écrit pour le blog de Planete domotique
Ma eedomus possédant un RFXCOM Lan (Cf. cet article pour plus d’information), j’ai orienté mes recherches sur le protocole xPL. Si vous ne connaissez pas trop le protocole xPL je vous invite à lire cet article d’explications !
Voici le but de mon article : je vais vous expliquer comment mettre en place sur Asterisk et sur la Eedomus la possibilité de les faire dialoguer, afin de rendre mes appels entrants et sortants plus parlants à ma box domotique !
Bon, je ne vais pas vous faire le coup du «c’est simple !», car j’ai bien cherché pour trouver la solution…
Je me suis bien inspiré du post de GuiguiABloc, et je le remercie d’avoir mis à dispo son script !
Première étape : Mettre en place AGI sur Asterisk
C’est quoi un AGI (Asterisk Gateway Interface) ?
AGI est une interface permettant de faire communiquer le plan de numérotation (extensions.conf) avec des programmes extérieurs à Asterisk, écrits avec des langages de programmation aussi divers que PHP, Perl,Python, C, shell Linux.
Le principe
AGI est matérialisé par l’écriture de scripts qui sont exécutés dans le plan de numérotation.
À chaque lancement d’un script AGI, Asterisk envoie au script un ensemble de variables avec leurs valeurs. Lorsque toutes les variables sont émises, Asterisk envoie une ligne vide pour préciser au script qu’il peut commencer ce pourquoi il a été écrit (suite d’instructions).
Comment appeller un script AGI ?
Par défaut, les scripts sont créés et stockés dans /var/lib/asterisk/agi-bin# (cela permet de ne pas mentionner le chemin complet d’appel des scripts). Il faudra toujours que les scripts disposent du droit d’exécution.
Mise en place du script
Je vais vous mettre à dispo mon script qui est le même utilisé par les appels entrants et sortants. La base est le même script que GuiGuiabloc.
Il faut le recopier dans un fichier Asterisk2xPL.agi.
Attention il faudra faire une modification :
À if outgoingnumber == « Mettre son numéro de téléphone Freebox » (ligne 29), vous devez mettre votre numéro de téléphone fixe commençant par 09.
voici le script
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | #!/usr/bin/python # -*- coding: ISO-8859-1 -*- # # Asterisk2xPL # By Kragg import sys , os , socket hostname = socket.gethostname ( ) # On défini un broadcast sur tout le réseau (tous les périphériques recevrons l'information) xpladdr = ( "255.255.255.255" , 3865 ) xplport = 3865 UDPSock = socket.socket ( socket.AF_INET , socket.SOCK_DGRAM ) UDPSock.setsockopt ( socket.SOL_SOCKET , socket.SO_BROADCAST , 1 ) AGIENV = { } env = "" while ( env ! = "\n" ) : env = sys.stdin.readline ( ) envdata = env.split ( ":" ) if len ( envdata ) = = 2 : AGIENV[envdata[ 0 ].strip ( ) ] = envdata[ 1 ].strip ( ) incomingnumber = AGIENV['agi_callerid'] outgoingnumber = AGIENV['agi_extension'] if outgoingnumber = = "mettresonnumérodetelephone" : body = 'device = telephone\ntype = AppelEntrant\ncurrent = N' + incomingnumber msg = "xpl-trig\n{\nhop=1\nsource=rfxcom-lan-asterisk." + hostname + "\ntarget=*\n}\nsensor.basic\n{\n" + body + "\n}\n" UDPSock.sendto ( msg , xpladdr ) else : body = 'device = telephone\ntype = AppelSortant\ncurrent = N' + outgoingnumber msg = "xpl-trig\n{\nhop=1\nsource=rfxcom-lan-asterisk." + hostname + "\ntarget=*\n}\nsensor.basic\n{\n" + body + "\n}\n" UDPSock.sendto ( msg , xpladdr ) |
Avant de faire quoi que ce soit, il faut rendre le scripts exécutables et aussi changer le propriétaire
Pour rendre le script exécutable :
1 | chmod u+x Asterisk2xPL.agi |
Pour changer le propriétaire :
1 | chown -R asterisk:asterisk /var/lib/asterisk/agi-bin/Asterisk2xPL .agi |
Le script est la, il est exécutable, son propriétaire est Asterisk …maintenant il faut l’intégrer dans votre plan de numérotation…
Intégration du script dans le plan de numérotation
Pour cela nous passons dans le dossier /etc/asterisk#. Dans ce dossier vous avez l’ensemble des fichiers de configuration de votre Asterisk.
Nous allons nous intéresser au fichier suivant : extensions_custom.conf
En rentrant dedans, vous allez vous apercevoir qu’il est peut être vide. Du coup, il faut faire une copie du fichier extensions_custom.conf.sample (le fichier d’exemple) vers le fichiers custom.
Voici la commande :
1 | cp extensions_custom.conf.sample extensions_custom.conf |
Maintenant il faut éditer le fichier et y rajouter en dessous de :
1 2 3 4 5 | [from-internal-custom] exten => 1234,1,Playback(demo-congrats) ; extensions can dial 1234 exten => 1234,2,Hangup() exten => h,1,Hangup() include => custom-recordme ; extensions can also dial 5678 |
Ceci, l’appel de notre script AGI !
1 2 | [from-pstn-custom] exten => _X.,1,AGI( /usr/bin/python ," /var/lib/asterisk/agi-bin/Asterisk2xPL .agi) |
L’ajout des capteurs côté eedomus
Voila maintenant, si on passait sur la eedomus ?
Pour cela je vous invite a lire la suite de l’article sur le blog de planete domotique.
4.5