dimanche 7 juin 2015

Plate-forme SMS avec traitement automatique de contenu

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 
   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 **********

# 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à
 
-  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 »

  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 :

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.


      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.

   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.