Mise en place d'une plate-forme SMS avec
exemple de traitement automatique de contenu
Sommaire
Introduction
1- Installation
** Nos besoins matériels
** Aménageons notre environnement de travail
** Configurons notre modem
2- Mise en place de notre serveur sms
** La configuration du Daemon de gammu
** Envoi de sms
** Réception et stockage des messages
3- Traitement automatique des sms
** Modification de la base de données
** Création des fichiers nécessaires à l'exécution automatique
** Modification du daemon de gammu
** Modification du fichier ''connexion.php''
** Modification du fichier ''bonheur.php''
4- Tirage au sort automatique des gagnants
** Création du fichier ''gagnant.php''
** Exécution automatique: tous les jours à 18h 00mn 00s
5- Conclusion
Erreur courantes
- RunOnReceive ne fonctionne pas
- Messages en ligne de commande ne passe pas
-------------------------------------------------------------------------
Télécharger le fichier pdf ici.
Introduction
Depuis
l'envoi du premier sms, le 03 Décembre 1992, par Neil Papworth, la
technologie des messages à 160 caractères a connue un fulgurant
essor.
L'envoi
d'un sms est devenu un fait ordinaire et courant à tous les niveaux
de l'échelle social.
Simple
d'utilisation et pratique, il se revêt être un outil efficient pour
une campagne à grande échelle.
Le
tutoriel ci-dessous vise à permettre à toute personne l'appliquant
de posséder une base solide dans la conception de serveur sms avec
traitement du contenu des messages, ce avec la conception d'une
plate-forme sms simulant un jeux simple par sms.
Notre
jeux durera juste une semaine et consistera à envoyer par sms
« jeu*bonheur » afin de participer à un jeu qui donne
des millions.
Et
disons que quotidiennement on tirera au sort un participant à qui on
enverra via notre plate-forme un message pour qu'il récupère son
lot.
Et
le vendredi, on tire au sort un participant qui remportera la grande
cagnotte de 5.000.000 FCFA, (faisons lui une fleur pour son week-end,
dans tous les cas on y perd rien en fait!!!).
1- Installation
Afin
de réaliser notre application, des pré-requis s'imposent.
Tout
d'abord précisons que nous travaillerons sur des logiciels libres.
Donc vous n'aurez rien à débourser.
Voilà
qui nous réjouit, maintenant !
Ces
derniers sont les suivants :
-
Gammu : Pour gérer le modem (l'envoi
de
SMS, la gestion du répertoire , la gestion des appels, la création
de sauvegardes des messages, et répertoire…)
-
Wammu : Interface graphique pour Gammu
-
Apache : Notre serveur web
-
PHP 5 : Notre langage de programmation
-
MySQL : Notre système de gestion de bases de données
-
PhpMyAdmin : l'interface web pour la gestion graphique de notre
base de données
-
Gammu-smsd : Le Daemon de Gammu, il permet le stockage, la
réception et l'envoi des SMS.
**
Nos besoins matériels
Bref !
De quoi à t-on besoin pour commencer ?
Ok !
Au niveau du matériel, pas grand-chose juste :
-
un ordinateur avec une distribution GNU/Linux
(ici,
afin que nous ayons le même rendu, je préconise Ubuntu 14.04 LTS,
sur lequel se fera ledit tutoriel.
Bon !
Chacun est libre de choisir sa distribution à ses risques et
périls ! Beuf!)
-
Un téléphone portable pouvant servir de modem ou
une clé internet avec une carte SIM.
(Juste
un coucou à nos friands des téléphones « Chine-toc »,
veuillez vous abstenir SVP! Sinon essayez pour voir, c'est peut-être
votre jour de chance !)
-
Un câble USB pour relier le modem ou téléphone à l'ordinateur.
-
Créditer votre carte SIM d'au moins 5 sms pour les testes.
Voilà
juste ça pour le matériel.
**
Aménageons notre environnement de travail
Ensuite
nous déployons notre environnement de travail avec les instructions
suivantes :
-
On met à jour nos paquets
serenite@Serenity:~$
sudo apt-get update
-
On met à jour notre distribution
serenite@Serenity:~$
sudo apt-get upgrade
-
On déploie notre environnement web (apache, serveur mysql, php5 et
phpmyadmin)
serenite@Serenity:~$
sudo apt-get install apache2 libapache2
mod-php5 php5 mysql-server
php5-mysql phpmyadmin
-
On installe Gammu, Wammu, Wvdial, Gammu-smsd
serenite@Serenity:~$
sudo apt-get install gammu
serenite@Serenity:~$
sudo apt-get install wammu
serenite@Serenity:~$
sudo apt-get install wvdial
serenite@Serenity:~$
sudo apt-get install gammu-smsd
Ouf !
Enfin, fini les longues attentes, on peut commencer à travailler !!!
Configurons
notre modem
NB :
j'utiliserais le terme « modem » pour désigner votre
téléphone portable ou votre clé.
Connectez
votre modem à votre ordinateur.
1-
On lance l'assistant de configuration de wammu
serenite@Serenity:~$
sudo wammu-configure
-
Alors, on obtient cette fenêtre
-
cliquer sur « Next > »
-
choisissez l'option "recherche automatique de téléphones" et cliquez sur "Next".
-
choisissez l'option « recherche de connexion » et patientez pendant 10 à 15 minutes.
-
Cette fenêtre s'ouvre avec la dernière ligne indiquant le nombre de
téléphones détectés. Si au moins un modem est détecté, cliquer
sur « Next » sinon reprenez le processus de recherche
(fenêtre « recherche automatique de téléphones) en
choisissant d'autre option.
-
Ici on choisi un modem, tout en mentionnant au brouillon les parties
« /dev/tty… utilisant at... », puis on valide.
-
Vérifions que notre modem a bien été détecté par gammu
Deux
possibilités s'offrent à nous :
*
serenite@Serenity:~$ sudo gammu --identify
Périphérique
: /dev/ttyUSB0
Fabricant
: Huawei
Modèle
: unknown (EG162G)
Firmware
: 11.001.10.00.000
IMEI
: 353474023727472
SIM
IMSI : 612030207358750
*
serenite@Serenity:~$ sudo wvdialconf
Editing
`/etc/wvdial.conf'.
Scanning
your serial ports for a modem.
ttyS0<*1>:
ATQ0 V1 E1 -- failed with 2400 baud, next try: 9600 baud
ttyS0<*1>:
ATQ0 V1 E1 -- failed with 9600 baud, next try: 115200 baud
ttyS0<*1>:
ATQ0 V1 E1 -- and failed too at 115200, giving up.
Modem
Port Scan<*1>: S1 S2 S3 S4 S5 S6 S7 S8
Modem
Port Scan<*1>: S9 S10 S11 S12 S13 S14 S15 S16
Modem
Port Scan<*1>: S17 S18 S19 S20 S21 S22 S23 S24
Modem
Port Scan<*1>: S25 S26 S27 S28 S29 S30 S31
ttyUSB0<*1>:
ATQ0 V1 E1 -- OK
ttyUSB0<*1>:
ATQ0 V1 E1 Z -- OK
ttyUSB0<*1>:
ATQ0 V1 E1 S0=0 -- OK
ttyUSB0<*1>:
ATQ0 V1 E1 S0=0 &C1 -- OK
ttyUSB0<*1>:
ATQ0 V1 E1 S0=0 &C1 &D2 -- OK
ttyUSB0<*1>:
ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0 -- OK
ttyUSB0<*1>:
Modem Identifier: ATI -- Manufacturer: huawei
ttyUSB0<*1>:
Speed 9600: AT -- OK
ttyUSB0<*1>:
Max speed is 9600; that should be safe.
ttyUSB0<*1>:
ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0 -- OK
ttyUSB1<*1>:
ATQ0 V1 E1 -- failed with 2400 baud, next try: 9600 baud
ttyUSB1<*1>:
ATQ0 V1 E1 -- failed with 9600 baud, next try: 9600 baud
ttyUSB1<*1>:
ATQ0 V1 E1 -- and failed too at 115200, giving up.
ttyUSB2<*1>:
ATQ0 V1 E1 -- OK
ttyUSB2<*1>:
ATQ0 V1 E1 Z -- OK
ttyUSB2<*1>:
ATQ0 V1 E1 S0=0 -- OK
ttyUSB2<*1>:
ATQ0 V1 E1 S0=0 &C1 -- OK
ttyUSB2<*1>:
ATQ0 V1 E1 S0=0 &C1 &D2 -- OK
ttyUSB2<*1>:
ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0 -- OK
ttyUSB2<*1>:
Modem Identifier: ATI -- Manufacturer: huawei
ttyUSB2<*1>:
Speed 9600: AT -- OK
ttyUSB2<*1>:
Max speed is 9600; that should be safe.
ttyUSB2<*1>:
ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0 -- OK
Found
a modem on /dev/ttyUSB0.
Modem
configuration written to /etc/wvdial.conf.
ttyUSB0<Info>:
Speed 9600; init "ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0"
ttyUSB2<Info>:
Speed 9600; init "ATQ0 V1 E1 S0=0 &C1 &D2 +FCLASS=0"
Nous
constatons que notre modem est bien détecté.
2- Mise en place de notre serveur sms
La configuration du Daemon de gammu
La configuration du Daemon de gammu
Nous allons, maintenant configurer le Daemon de gammu (gammu-smsd)
serenite@Serenity:~$ sudo gedit /etc/gammu-smsdrc
Voici la configuration de notre fichier
il est composé de deux grandes parties
1- [gammu] : pour la configuration de la librairie de gammu (le modem)
2- [smsd] : partie des instructions à réaliser par le daemon
*********** debut du fichier gammu-smsdrc **********
Voici la configuration de notre fichier
il est composé de deux grandes parties
1- [gammu] : pour la configuration de la librairie de gammu (le modem)
2- [smsd] : partie des instructions à réaliser par le daemon
*********** debut du fichier gammu-smsdrc **********
# Configuration file for Gammu SMS Daemon
# Gammu library configuration, see gammurc(5)
[gammu]
# Please configure this!
//modifier en fonction des données renvoyées par gammu – - identify ou wvdialconf
port = /dev/ttyUSB0
connection = at19200
# Debugging
#logformat = textall
# SMSD configuration, see gammu-smsdrc(5)
[smsd]
Service = SQL
Driver = native_mysql // Driver de la base de données MySql
logfile = /var/log/gammu.log // fichier journal
#pin = 0000 // code pin de la SIM
#Accès à la base de données Mysql
User = root // identifiant administrateur pour phpmyadmin
Password = JdEElaor14789 // mot de passe pour phpmyadmin
PC = localhost // indique la station ou est installé notre serveur
Database = jeu // la base de données
#Gestion des temps de connexion
MaxRetries = 3 // nombre d'essai
checksecurity = 0
PhoneID = Huawei // nom du modem
transmitformat = auto
# Increase for debugging information
debuglevel = 1
# Paths where messages are stored
inboxpath = /var/spool/gammu/inbox/
outboxpath = /var/spool/gammu/outbox/
sentsmspath = /var/spool/gammu/sent/
errorsmspath = /var/spool/gammu/error/
************ fin gammu-smsdrc **********************
Pour plus d'info sur les possibilités pour la configuration de ce fichier, visitez la page détaillant la configuration du daemon de gammu à cette adresse (c'est en anglais, mais assez compréhensible.):
SMSD Configuration File
Pour approfondir vos connaissances sur gammu, visitez le manuel de gammu, ici.
A ce niveau gammu à plein accès à notre modem.
On peut déjà
Pour approfondir vos connaissances sur gammu, visitez le manuel de gammu, ici.
A ce niveau gammu à plein accès à notre modem.
On peut déjà
- Lister les messages stockés, dans la boîte de reception avec :
« gammu --getallsms »
- Lister les numéros de notre répertoire téléphonique avec :
« gammu --getallmemory SM »
« gammu --getallmemory SM »
Et bien d'autres encore… Si vous en voulez plus, n'hésitezz pas de vous reférer au manuel de gammu. Ou dans votre terminal, entrez '' man gammu ''.
** Envoi de sms
Notre système est maintenant prêt à envoyer des sms. En ce qui concerne la réception de sms, on n'est pas tout à fait prêt, car il nous faudra créer une base de données avec les schemas de gammu, ce qu'on fera dans peu de temps.
Pour l'instant testons l'envoie de sms à partir de notre terminal,
avec la commande suivante :
avec la commande suivante :
serenite@Serenity:~$ echo "bonsoir test d'envoi par cmd" | gammu --sendsms TEXT +22507xxxxxx If you want break, press Ctrl+C...
Sending SMS 1/1....waiting for network answer..OK, message reference=66
Formidable !!! Message bien envoyé.
Cette ligne « Sending SMS 1/1....waiting for network answer..OK, message reference=66 »
Nous donne le nombre de message transmis et nous indique la réponse du réseaux à notre requête, qui est ici, « OK ».
** Réception et stockage des messages
Maintenant, que notre système peut envoyer des sms, nous allons créer notre base de données afin de stocker les messages que nous recevrons.
Pour cela, allons un peu en mode graphique. Cela ne veut en aucun cas dire que ce n'est pas possible de le faire en ligne de commande. A bon entendeur… salut !
Bien, ouvrons Firefox, et dans la barre d'adresse, entrons : « localhost/phpmyadmin », ce qui nous ouvre cette page.
Ensuite entrons notre mot de passe et validons, pour accéder à cette page.
Entrons le nom de notre base de données à créer. Dans notre cas, entrons « jeux », et cliquons sur créer.
Cool ! Notre base de données est créée.
Maintenant importons les schemas de gammu pour la base de données.
Cliquez sur l'onglet « importer », ensuite sur le boutons parcourir et importons le fichier ''mysql.sql.gz'' dans /usr/share/doc/gammu/examples/sql/, puis cliquez sur exécuter.
Maintenant importons les schemas de gammu pour la base de données.
Cliquez sur l'onglet « importer », ensuite sur le boutons parcourir et importons le fichier ''mysql.sql.gz'' dans /usr/share/doc/gammu/examples/sql/, puis cliquez sur exécuter.
Notre base de données « jeux » est enfin prête. Testons, maintenant la sauvegarde de nos messages reçus dans cette dernière.
C'est simple, envoyez juste un message au numéro de la puce se trouvant dans votre modem. Ensuite actualiser la page de PhpMyAdmin (si vous ne l'aviez pas fermée), sinon ouvrez la à nouveau. Et vérifier que votre message se trouve bien dans la table ''inbox'' de votre base de données ''jeux''.
Si votre message ne s'y trouve pas, prière de vérifier à nouveau la configuration de votre fichier '' gammu-smsdrc '', principalement dans la partie '' Accès à la base de données MySql ''.
Ok ! Ici, tous marche bien.
En somme notre système est capable d'envoyer, de recevoir et de stocker dans une base de données nos sms.
Notre serveur sms est fin prêt et opérationnel.
C'est simple, envoyez juste un message au numéro de la puce se trouvant dans votre modem. Ensuite actualiser la page de PhpMyAdmin (si vous ne l'aviez pas fermée), sinon ouvrez la à nouveau. Et vérifier que votre message se trouve bien dans la table ''inbox'' de votre base de données ''jeux''.
Si votre message ne s'y trouve pas, prière de vérifier à nouveau la configuration de votre fichier '' gammu-smsdrc '', principalement dans la partie '' Accès à la base de données MySql ''.
Ok ! Ici, tous marche bien.
En somme notre système est capable d'envoyer, de recevoir et de stocker dans une base de données nos sms.
Notre serveur sms est fin prêt et opérationnel.
Dans la partie suivante nous verrons comment automatiser un traitement du contenu des messages reçus, afin de générer des messages prédéfinis.
3- Traitement
automatique des sms
C'est
à ce niveau que comment les choses amusantes et sérieuses aussi.
C'est là que notre jeux ou notre système prend toute son
importance.
Dans
cette partie nous automatiserons l'exécution d'un script, nous
créerons la ou les tables adéquates dans notre base de données et
configurerons notre script selon notre convenance, afin de réaliser
notre objectif.
** Modification
de la base de données
Pour notre jeu, on aura juste
besoin d'une seule table qu'on nommera '' bonheur '' avec les champ
suivants :
id : identifiant du sms
numero : Numéro du
participant
jour : la date de
réception du sms
Ouvrez votre table dans
PhpMyAdmin et cliquez sur l'onglet ''SQL'', puis collez-y le code sql
suivant et exécutez.
Code sql :
CREATE TABLE bonheur
(
id
bigint(20) NOT NULL AUTO_INCREMENT,
numero
varchar(15) NOT NULL,
jour
varchar(10) NOT NULL,
PRIMARY KEY (id)
)
** Création
des fichiers nécessaires à l'exécution automatique
-
rendez vous dans votre localhost
serenite@Serenity:~$
cd /var/www/html
Dans
votre localhost (/var/www/html/) créer les éléments suivants :
-
le dossier jeu
$
mkdir jeu
-
rendez vous dans ce dossier
$
cd jeu
-
créez
→ $
nano connexion.php
entrez
les 2 lignes suivantes
1-
<?php
2-
?>
Enregistrez
(ctrl+x)
→ $
nano bonheur.php
entrez
les 3 lignes suivantes
1-
# !/usr/bin/php
2-
<?php
3-
?>
Enregistrez
(ctrl+x)
→ $
nano daemon.sh
Entrez
les 06 lignes suivantes
1-
#!/bin/sh
2-
# Configure this (use absolute path)
3-
PHP=/usr/bin/php
4-
DAEMON=/var/www/html/jeu/daemon.php
5-
# Execute
6-
$PHP $DAEMON
Enregistrez
(ctrl+x)
Exemple:
** Modification
du daemon de gammu
- ouvrez le fichier
gammu-smsdrc
serenite@Serenity:~$
sudo /etc/gammu-smsdrc
- Ajoutez-y les lignes
suivantes dans la partie [smsd]
1- # Action à exécuter dès
réception d'un sms
2-
RunOnReceive=/var/www/html/jeu/daemon.sh
** Modification
du fichier ''connexion.php''
Ouvrez
le fichier ''connexion.php'' et collez-y les lignes suivantes :
N'oubliez pas de modifier
''root'' par votre identifiant et '' JdEElaor14789'' par votre mot de
passe d'accès à phpmyadmin.
***** début connexion.php
*******
/*
* Connexion à la Base de
données
*/
global $db;
$db = null;
try {
$db = new
PDO('mysql:host=localhost;dbname=jeu;charset=utf8', 'root',
'JdEElaor14789');
$db->setAttribute(PDO::ATTR_ERRMODE,
PDO::ERRMODE_EXCEPTION);
} catch (Exception $e) {
error_log($e->getMessage());
}
********** fin fichier
***********
** Modification
du fichier ''bonheur.php''
Ce
fichier est extrêmement important, dans la réussite de votre
projet.
Je
vous demanderais donc de lui accorder une attention toute
particulière.
On
l'expliquera, ne vous en faite pas !
Mais
je vous demanderez de ne pas faire de copier-coller à ce niveau, il
est possible que vous ayez des bugs.
Ainsi
je vous conseille de le construire méticuleusement, étape par
étape.
********** début bonheur.php
***********
#!/usr/bin/php
<?php
/*
|---------------------------------------------------------------
| Sms Application (SA) ---
Serenite 489
|---------------------------------------------------------------
*/
/* –------- partie 1
–------- */
require('db_connect.php');
$nb=null;
$requete="SELECT ID,
TextDecoded, SenderNumber from inbox where readed='false';";
$donne=$db->prepare($requete);
$donne->execute();
$nb=$donne->rowCount();
/*---------fin partie 1
--------- */
/* -------- partie 2
------------ */
if ($nb!=0) /* marqueur 1
*/
{
/* marqueur 2 */
while
($value=$donne->fetch(PDO::FETCH_OBJ))
{
/* –------- marqueur 3
–------ */
$SenderNumber=$value->SenderNumber;
$TextDecoded_1=trim($value->TextDecoded);
$ID=$value->ID;
list($TextDecoded,
$Var_1)=explode("*",$TextDecoded_1);
$keyword=strtolower($Var_1);
$TextDecoded=strtolower($TextDecoded);
/* –------- fin marqueur 3
–------ */
/* –------- marqueur
4 –------ */
if
($TextDecoded=="jeu"){ //Verification de syntaxe "jeu"
if ($keyword=="bonheur"){
//Verification de syntaxe "bonheur"
$date =
gmdate("Y-m-d ») ;
$text = utf8_decode("LSA
| Jeu Bonheur : Votre inscription a bien été prise en compte.
Augmentez vos chances en jouant encore plus.");
$sql="INSERT INTO
bonheur (numero, jour) values('$SenderNumber', $date)";
$inserer=$db->prepare($sql);
$inserer->execute();
shell_exec ('echo "'.$text.'"
| gammu --sendsms TEXT '.$SenderNumber);
} else{ // si different
de bonheur
$text = utf8_decode("Votre
message ne peut pas être traité par la plateforme Jeu du bonheur,
car il ne respecte pas la syntaxe prédéfinie. Envoyez plutôt
« jeu*bonheur »");
shell_exec ('echo "'.$text.'"
| gammu --sendsms TEXT '.$SenderNumber);
}
} else{ // si different
de jeu
$text =
utf8_decode("Votre message ne peut pas être traité par la
plateforme Jeu du bonheur, car il ne respecte pas la syntaxe
prédéfinie. Envoyez plutôt « jeu*bonheur »");
shell_exec ('echo "'.$text.'"
| gammu --sendsms TEXT '.$SenderNumber);
}
/* –------- fin
marqueur 4 –------ */
/* –------- marqueur 5
–------ */
$maj="UPDATE inbox SET
(readed=:read) where ID=:id ";
$result=$db->prepare($maj);
$result->execute(":id"=>$ID,
":read"=>"true");
/* –------- fin
marqueur 5 –------ */
} /* fin marqueur 2 */
} /* –------- fin marqueur 1
–------ */
/* –------- fin partie 2
–------ */
?>
*************** fin fichier
***********
Partie 1 : Dans
cette partie, on va rechercher dans chaque ligne de la table
''inbox'' de notre base de données les lignes où readed='false'.
C'est à dire on récupère l'ensemble des messages n'ayant pas
encore été lus. Et la variable $nb, pour en déterminer le nombre.
Partie
2: Ici, nous allons traiter les
données
réçus de la base de données.
Marqueur 1 : On
vérifie si la requête envoyée à a base de données nous ramène
bien des lignes d'informations avant de penser à les traiter.
Logique non ?
Marqueur
2: Convaincu, d'avoir reçu au
moins une ligne d'informations de la base de données. On peut
maintenant les traiter. Alors on fait une boucle avec ''while'' pour
traiter chacune des lignes reçues.
Marqueur
3: Dans
les lignes 1 à 3, on range dans des variables les données d'une
ligne données. Dans la 4ème ligne on décompose le message envoyé
et qu'on a stocker dans la variable ''$TextDecoded'', en fonction du
délimiteur que nous avons choisi. Dans notre cas le délimiteur est
''*''. Ensuite, on stocke dans des variables différentes les
éléments de part et d'autre du délimiteur.
Dans
notre cas, nous devons avoir 2 variables. '$TextDecoded' qui devra
contenir 'jeu', et 'Var_1' contiendra 'bonheur'.
Marqueur
4 : Ici,
commence le véritable traitement des messages. Tout d'abord, on
vérifie que $TextDecoded contient bien le mot 'jeu', sinon on ramène
un message d'erreur au numero ayant envoyé le message.
Si
$TextDecoded contient bien le mot 'jeu', alors continu le traitement.
Ensuite,
on vérifie que la deuxième variable '$Var_1' contient le mot
'bonheur', sinon on ramène un message d'erreur au numero ayant
envoyé le message.
Si
$Var_1 contient bien le mot 'bonheur', alors on commence le
traitement.
On
enregistre d'abord le numéro de l'envoyeur dans la table 'bonheur',
puis on lui envoie un message de confirmation de de réception de son
inscription.
Marqueur
5 : Dans
cette partie, nous allons modifier le champs 'readed' de la ligne que
nous venons de traiter en lui affectant la valeur 'true'. De sorte à
éviter qu'elle soit prise en compte à nouveau lors du prochain
scanne de la base de données.
Maintenant
notre système est prêt à 90 %. Il peut recevoir des sms, les
traiter et répondre à l'envoyeur en fonction du contenu de son
message.
Pour
cela il suffit juste pour nous de connecter notre modem et de lancer
le daemon de gammu
($ sudo /etc/init.d/gammu-smsd start).
Et nous sommes opérationnel.
4- Tirage
au sort automatique des gagnants
Dans
cette partie, nous allons créer un script qui se lancera tous les
jours à 18h 00mn 00s pour le tirage au sort du gagnant du jour.
** Création
du fichier ''gagnant.php''
Toujours
dans notre dossier 'jeu', on crée le fichier 'gagnant.php'
$
nano gagnant.php
-------–-
contenu du fichier –------------
#!/usr/bin/php
<?php
require('db_connect.php');
$date
= gmdate("Y-m-d'') ;
$donne=null;
$sql="SELECT
numero from bonheur where jour=".$date.";";
$donne=$db->prepare($sql);
$donne->execute();
$nb=$donne->rowCount();
$i=0;
while
($value=$donne->fetch(PDO::FETCH_OBJ))
{
$result[$i]=$value->numero;
$i++;
}
$winner=rand(0,
$nb); // on génère un numero au hasard, qui sera celui du gagnant
$num_winner=$result[$winner];
$jr=date('l') ;
if
($jr=='friday'){
$text
= utf8_decode("SA | Jeu Bonheur : FELICITATION!!! Vous venez
de remportez 5.000.000 FCFA. Passez à Bonheur-du-code récupérer
votre Lot.");
}
else {
$text
= utf8_decode("SA | Jeu Bonheur : FELICITATION!!! Vous venez
de remportez 50.000 FCFA. Passez à Bonheur-du-code récupérer votre
Lot.");
}
shell_exec
('echo "'.$text.'" | gammu --sendsms TEXT
'.$num_winner);
?>
Enregistrez
(ctrl+x)
-------------------------- fin fichier
---------------------------------
** Programmation
de l'exécution automatique tous les jours à 18h 00mn 00s
Tout
d'abord, on rend notre script exécutable :
$ chmod +x
/var/www/html/jeu/gagnant.php
Ensuite, on entre la commande
suivante :
$ crontab -e
Ce qui nous donne ceci :
no crontab for alex - using an
empty one
Select an editor. To
change later, run 'select-editor'.1. /bin/ed
2. /bin/nano <---- easiest
3. /usr/bin/vim.tiny
Choose 1-3 [2]:
A ce niveau on choisi le
numero, correspondant à notre éditeur préferé. Pour ma part, je
vous conseil, 'nano', donc le numéro 2.
Puis utilisez la flèche de
direction vers le bas pour vous rendre à la fin du fichier. Au
niveau de cette ligne :
# m h dom mon dow
command
En dessous entrez la ligne
suivante :
0 18 * * *
/var/www/html/jeu/gagnant.php
Conclusion
Et voilà ! On est prêt
à 100 %.
Notre système, reçoit,
stocke, traite, sauvegarde, repond à tous les sms qui lui sont
transmis. Et la cérise sur le gateau, tous les jours à 18h 00mn 00s
il tire au sort un gagnant et lui envoi un message. Tout ça sans
l'intervention de quiconque.
Vous savez déjà comment
lancer votre système.
Alors Bonne pratique.
------------------------------------------------------------------------
Erreurs courantes
** RunOnReceive ne fonctionne
pas
alors :
1- Dans le daemon de gammu
(/etc/gammu-smsdrc), supprimer la ligne du RunOnReceive
2- Dans votre script
''daemon.sh'' (/var/www/html/jeu/daemon.sh), ajoutez ne boucle
infinie qui encadrera la partie #Execute.
Le
code :
while :
do
# Execute
$PHP $DAEMON
sleep 5
done
3- Maintenant pour lancer
votre système, après avoir connecté votre modem, il vous faudra :
lancer le daemon de gammu et votre script daemon.sh.
- $ sudo /etc/init.d/gammu-smd
start
- $ cd /var/www/html/jeu
- /var/www/html/jeu/ $ sudo
bash daemon.sh
Et voilà, C'est pas trop
jolie joie, mais ça fait l'affaire !!!
** Messages en ligne de
commande ne passe pas
si vous n'arrivez pas à
envoyer des messages en ligne de commande, alors exécutez les
commandes suivantes.
Si le message d'erreur est :
Erreur à l'ouverture du
périphérique: il n'existe pas.
Essayez de repositionner
votre carte SIM et reconnectez votre modem.
Si cela ne marche toujours pas
alors exécutez les commandes suivantes :
1- $ sudo groups | grep -q
dialout || sudo adduser $USER dialout
2- $ sudo apt-get autoclean
3- $ sudo apt-get clean
4- $ sudo reeboot
5- et relancer les
services
Voilà, nous sommes à la fin de notre tutoriel. Et j'espère sincèrement vous avoir apporté ne serait-ce qu'un petit plus!
Ce document peut contenir des bugs ou imperfections, alors je me tiens à votre disposition pour tout apport, afin de l'améliorer.