Oui, je suis d'accord !
Ma sollution, un peu cascadeuse malgré tout, pourrait tout à fait fonctionner dans ton cas aussi...
A toi de voir en tout cas !
Oui, je suis d'accord !
Ma sollution, un peu cascadeuse malgré tout, pourrait tout à fait fonctionner dans ton cas aussi...
A toi de voir en tout cas !
Nabil,
Après avoir écumer le net pour configurer et installer phpagi : j'ai de bons réusltats :
Voici mes testes :
1. On appelle le 100 avec le tel avec le callerid(num)=714
2. On lance l'agi qui va chercher si en base de donnée le numéro 714 correspond.
Et on renvoie la valeur : le nom ou le message 714 non présent en base de donnée :
extensions.conf
[Test]
exten => 100,1,agi(test.php,${CALLERID(num)})
exten => 100,2,Set(__Identifiant=${Identifiant})
exten => 100,3,noop("C'est un test d'affichage de variable ${Identifiant})
test.php
#!/usr/bin/php
<?php
REQUIRE("phpagi-2.20/phpagi.php");
$agi = new AGI();
$Num = $agi->request[agi_callerid];
///requete SQL
///resultat
$Identifiant = $Num;
$agi->set_variable("Identifiant", $Identifiant);
?>
Adaptes tout ça pour ton cas !
Vive asterisk !
etann38, j'ai un gros gros soucis mes script php simples ne s'executent pas sous asterisk 1.8 je ne sais pas pourquoi ! je galère grave ! je voudrais que tu m'explique succintement comment t'a pu faire fonctionner tes scripts à toi ! de la config jusqu'a la mise en oeuvre et l'execution ! Mil merci d'avance .........................
"Votre Atitude determinera votre Altitude dans la vie !"
Euh, je ne vais pas te détailler l'installation complète d'asterisk ici... Y'a plein de tuto sur le net et ce serait trop long !
Mais peut-être que tu devrais vérifier si sur ta machine qui execute asterisk le phpcli est bien installé.
Et vérifer dans ton script php si le chemin d'exécution php est bon...
Je suis en train de réaliser une documentation pour toute mon installation asterisk, si tu passiente un peut je te l'enverrai !
Etann38 je t'explique !
J'ai une BD sous Mysql qui a 3 tables : client(code_clt,nom_clt), compte(code_cpt,solde_courant, solde_debiteur) et phone(numero,code_pin,code_clt,code_cpt)
J'ai écris un script agi qui doit permettre de récupérer la valeur du solde courant de l'appellant (Callerid(num)) lorsqu'il sollicite cela comme je vais l'indiquer dans mon Dialplan , mais je coince grave ! regarde mon script : solde.agi
#!/usr/bin/php5
<?php
/*
//temps limite d'execution du script 30 secondes
set_time_limit(60);
// supprime le "buffering" sur les sorties
ob_implicit_flush(false);
// supprime l'affichage des erreurs pour éviter que celles-ci interferent avec Asterisk
error_reporting(0);
// creation des log avec droit d'écriture
$stdlog= fopen("/var/log/asterisk/infosolde.log", "w");
// creation des fichiers STDIN, STDOUT et STDERR qui se chargera de toutes les communications
//entre Asterisk et notre script php
if(!defined('STDIN')) define('STDIN', fopen('php://stdin', 'r'));
if(!defined('STDOUT')) define('STDOUT', fopen('php://stdout', 'w'));
if(!defined('STDERR')) define('STDERR', fopen('php://stderr', 'w'));
$pdo_options [PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
$bdd = new PDO('mysql:host=localhost;dbname=blalla', 'admin', 'admin', $pdo_options);
//On fait une requete du numero
$req = $bdd->prepare('SELECT numero FROM phone WHERE numero = :callid');
// va verifier s'il existe
$donnees = $req->fetch();
// $reqsolde=$bdd->prepare("SELECT solde_courant as sd FROM phone,compte WHERE phone.code_cpt=compte.code_cpt AND numero=$callid");
$reqsolde->execute(array(':numero'=>$[callid]));
$reqsolde->execute();
$row= $reqsolde ->fetch();
$result_solde='<tr><td>Le solde du numero </td>'.$callid.'<td> est de </td>'.$row['sd'].'<td> FCFA</td></tr>';
echo $result_solde;
fclose($stdlog);
$bdd =null;
?>
Mon dialplan :
exten => s,1,Festival(Please enter your phone number to check your request, thanks you)
exten => s,2,Read(callid)
exten => s,3,Gotoif($[${callid} = CALLERID(num)]?5:2)
exten => s,4,Festival(You have enter the correct number)
exten => s,5,agi(/usr/share/asterisk/agi-bin/solde.agi, ${callid})
exten => s,6,Festival(you are welcome)
exten => s,7,Hangup()
Ce que je voudrais savoir c'est comment faire pour passer en paramètre le numero de l'appellant pour que le script puisse réssir son execution, car vous tu peux le constater à la ligne 5 j'ai passé ${callid} en paramètre mais lorsque j'ouvre la CLI je n'ai aucun resulat mais en revanche tout le dialplan ci-dessus s'execute jusqu'au Hangup()...
En passant lorsque j'ouvre le fichier solde.agi et que je fixe le callid ($callid=23) et que j'execute le dialplan je vois apparaitre dans la CLI la valeur exacte qui se trouve dans ma BD du solde courant pour ce numero
J'aimerais un coup de main, Merci l'ami..........
"Votre Atitude determinera votre Altitude dans la vie !"
#!/usr/bin/php
<?php
///REQUIRE("phpagi.php");
INCLUDE("ConnexionSql.php");
$agi = new AGI();
$Num = $_SERVER['argv'][1]; /// c ça qui permet de récupérer une variable en paramètre
///$Num= preg_replace("#[^0-9]#","",$agi->request[agi_callerid]);
IF(STRLEN($Num)>=10):
$REQSelection = "SELECT CONCAT(prenom,' ',nom) AS Contact FROM $TBLC WHERE TelPort LIKE '%$Num%' OR TelPerso LIKE '%$Num%'";
$RESSelection = MYSQL_QUERY($REQSelection,$Connexion);
IF(MYSQL_NUM_ROWS($RESSelection)==1):
$Identifiant = MYSQL_RESULT($RESSelection,0,"Contact");
ELSE:
$Identifiant = UTF8_DECODE(CHUNK_SPLIT($Num,2," ").' non présent dans la base de donnée');
ENDIF;
ELSE:
$Identifiant = UTF8_DECODE(CHUNK_SPLIT($Num,2," ").' non présent dans la base de donnée');
ENDIF;
$agi->set_variable("Identifiant", $Identifiant);
?>
Met le Noop(${callid}) avant pour voir si c'est ton read() qui fonctionne mal.
Etann38 !
Merci bien mais je serai heureux que tu puisse mieux commenter ton code !
"Votre Atitude determinera votre Altitude dans la vie !"
Sur internet, il y a tout... Renvoyer quelqu'un sur le net est une absurdité, tout n'est pas juste, bien au contraire, sur internet!
Il y a des très jolis scripts, et possibilités avec Asterisk, seulement c'est à chacun de bricoler pour faire fonctionner, or c'est normalement à Asterisk qui propose une solution, de s'assurer que tout va fonctionner au mieux, et poser des questions simples aux administrateurs, pour savoir comment exploiter au mieux les composants présents sur le réseau, les extensions, les scripts, les fonctionnalités supplémentaires, ... La version 2.0.0. d'Asterisk est la seule possibilité, et hélas Medical Technologies devra peut-être retirer les droits à Digium, pour les céder à une autre société, probablement ErgoSum Operating Systems qui a déjà repris les droits de Microsoft Corporation... Il faut simplifier, afin de permettre à chacun de faire que le meilleur, sans configuration, sans aucun problème, sans se poser de question... Pour le reste, les améliorations, là oui, il faut se poser des questions, et SDC++ et SMC++ permettent de trouver les moyens de réaliser tout ce qu'il manque, à qui a un peu de temps à consacrer... Merci pour votre volonté de faire fonctionner cet outil de malheur, mélange de paramètres, produits, standards, besoins, idées, problèmes, solutions, scripts, faux outils, mensonges, ... Il y a pour lînstant aucun serveur vocal qui respecten les standards d'EJFJ Coproration (C.D.M.) datant de 1996! Il faut simplifier, comme en justice, comme en politique, comme en tout! L'humain est trop compliqué, pas parfait, les machines doivent au contraire simplifier en rendre effective tout ce qui doit être fait, sans aucun problème (ou alors ils n'ont qu'à être réglés automatiquement!). L'économie, c'est ça! De plus, ça permet de faire beaucoup plus de choses utiles, plus vite, plus simplement, avec plus de satisfaction!