Dans cet article, je vais vous expliquer comment installer Gammu sur un Rasperry Pi par exemple. Gammu permet d’envoyer des SMS depuis un Raspberry, un PC sur lequel est tourne une plateforme Linux ou même Windows. Gammu vous permettra de transformer votre Rasperry en passerrelle SMS ou gateway SMS. Il faut bien entendu acheter une clé 3G compatible. J’ai acheté la clé suivante : Huawei E169 disponible sur Amazon ou sur Aliexpress
Il est possible aussi d’installer le deamon de gammu, afin de recevoir des SMS, et de lancer un script à chaque reception d’un message.
Le tuto qui suit permet donc de déployer l’outil sur une distribution Raspbian
Installer Gammu
Vérifier si la clé est bien détectée par le système et compatible
dmesg | grep tty | grep usb [ 5806.660785] usb 1-1.5: GSM modem (1-port) converter now attached to ttyUSB0 [ 5806.662796] usb 1-1.5: GSM modem (1-port) converter now attached to ttyUSB1 [ 5806.664577] usb 1-1.5: GSM modem (1-port) converter now attached to ttyUSB2
lsusb | grep -i Huawei Bus 001 Device 009: ID 12d1:1001 Huawei Technologies Co., Ltd. E169/E620/E800 HSDPA Modem
Mettre à jour le système
sudo apt-get update sudo apt-get upgrade
Installer gammu
sudo apt-get install gammu
Détecter la configuration de gammu
gammu-detect
Récupérer la configuration affichée à l’écran pour la mettre dans le fichier /etc/gammurc
Voici le contenu final de mon fichier :
[gammu] device = /dev/ttyUSB0 connection = at19200 name = Phone on USB serial port ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ HUAWEI_Mobile synchronizetime = yes gammucoding = utf8 [gammu1] device = /dev/ttyUSB1 connection = at19200 name = Phone on USB serial port ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ HUAWEI_Mobile synchronizetime = yes gammucoding = utf8 [gammu2] device = /dev/ttyUSB2 connection = at19200 name = Phone on USB serial port ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ HUAWEI_Mobile synchronizetime = yes gammucoding = utf8
Vous pouvez vérifier les caractéristiques de la clé 3g avec la commande suivante:
gammu --identify Périphérique : /dev/ttyUSB0 Fabricant : Huawei Modèle : E169 (E169) Firmware : 11.314.13.51.156 IMEI : 352835031664512
Si un code PIN est activé
gammu getsecuritystatus Waiting for PIN. gammu entersecuritycode PIN 1234 gammu getsecuritystatus Nothing to enter.
L’envoi de SMS se fait via l’une des deux commandes suivantes :
gammu sendsms TEXT 06xxxxxxxx -text "Test tutoandco"
echo "Test tutoandco" | gammu --sendsms TEXT 06XXXXXX
En réponse voici ce que la console affiche
If you want break, press Ctrl+C... Sending SMS 1/1....waiting for network answer..OK, message reference=1
Envoyer un message depuis un script PHP
J’utilise un script PHP pour envoyer des SMS depuis le web. Il se peut que vous rencontrez des soucis de droit lors de l’appel via un exec. Il faut que l’utilisateur apache puisse avoir accès à /dev/ttyUSB0 Il faut rajouter l’utilisateur www-data au groupe dialout
sudo usermod -a -G dialout www-data
Il faut ensuite autoriser www-data à executer gammu :
sudo chmod 4755 /usr/bin/gammu
J’ai du ensuite modifier le fichier /etc/apache2/conf-enabled/charset.conf d’Apache pour résoudre mes problème d’encodage afin de décommenter la ligne suivante AddDefaultCharset UTF-8
Voici mon script php, j’ai fait un truc très simple, il suffira de l’appeler de cette façon :
http://monsite/script.php?message=mon%20message%20de%20test&number=0000000000&token=azerty
J’ai rajouté un token de sécurité pour ne pas recevoir des messages indésirables.
<?php $locale = 'fr_FR.utf-8'; setlocale(LC_ALL, $locale); putenv('LC_ALL='.$locale); header("X-Robots-Tag: noindex, nofollow", true); $token = (string)$_GET['token']; $data = array(); if (!$token || $token != 'azerty') { $data = array( 'error' => "Not authorised", 'error_code' => 403, 'error_description' => "Not authorised", 'resource' => null ); echo json_encode($data); header('HTTP/1.0 403 Forbidden'); exit; } $message = urldecode((string)$_GET['message']); $number = (string)$_GET['number']; $number_array = explode('-', $number); if (!$message || !$number_array) { $data = array( 'error' => "Missing data", 'error_code' => 403, 'error_description' => "Missing data", 'resource' => null ); echo json_encode($data); header('HTTP/1.0 403 Forbidden'); exit; } foreach ($number_array as $number) { exec('echo "'.$message.'" | gammu --sendsms TEXT '.$number.' &'); }
Si malgré tout, vous avez encore des soucis d’encodage de vos SMS, il faut alors changer le « Locale » du Raspberry, tout est expliqué ici
Installer le daemon gammu
Suite à une investigation et aux commentaires, je me suis aperçu que la mise en place du daemon permettait de résoudre deux problème :
- Il n’est plus nécessaire de renseigner le code PIN à chaque reboot du serveur
- Il est possible d’envoyer des SMS à la chaîne sans perte.
Il est également intéressant à installer si vous souhaiter par exemple jouer un script à la réception de nouveaux messages.
sudo apt-get install gammu-smsd
Il faut ensuite compléter le fichier /etc/gammu-smsdrc avec la conf du fichier /etc/gammurc puis relancer le service
sudo service gammu-smsd restart
Options du daemon Gammu
Quelques spécificités concernant ce fichier. Il y a un nouveau « bloc » [smsd], qui contient la configuration du daemon de Gammu. Vous avez la possibilité de renseigner votre code PIN
PIN = xxxxxx
Vous pouvez aussi choisir la manière dont sont stockés les messages. Par défaut ils sont sauvegardés dans des fichiers dans le dossier /var/spool/gammu
Le dossier /var/spool/gammu appartient à root, tandis que l’ensemble des sous dossiers a pour propriétaire gammu, pour envoyer vos messages via votre site web il faut changer les droits du dossier.
sudo chmod 777 -R /var/spool/gammu
J’ai également ajouter cette variable. C’est le temps à attendre avant de nouveau vérifier s’il y a des nouveaux messages à envoyer. par défaut cette variable vaut 30.
CommTimeout=5
Vous trouverez l’ensemble des variables configurables sur cette page SMSD configuration File
Envoi de SMS
Il se fait via l’une des deux commandes suivantes :
gammu-smsd-inject TEXT 06XXXXXXXX -text "Test tutoandco"
echo "Test tutoandco" | gammu-smsd-inject TEXT 06XXXXXX
Vous trouverez l’ensemble des options pour envoyer des messages sur le site de Gammu
Fichiers de configuration
Vous trouverez les fichiers de configuration que j’utilise sur mon Github
Bonjour, tutoriel très utile mais je ne parviens pas à envoyer de sms. Lorsque j’essaie d’en envoyer un, il me dit « Impossible d’obtenir le numéro smsc depuis le téléphone. » Que faire ??
Dans la conf du fichier gammu-smsd, pour le démon de gammu, tu peux rajouter une ligne:
SMSC = xxxxxxxxxx
Tu devrais pouvoir l’obtenir en lançant la commande suivante : gammu getsmsc
De rien !
C’est cool quand tu suis un tuto et ça marche.
Si tu as un article de prêt, oui je veux bien en savoir plus sur RunOnReceive !
De mon coté, je vais aussi coder un script pour la reception.
Merci
Olivier
Et des recevoir des commentaires positifs sont encourageants et donnent envie de continuer 😉
Sinon j’ai juste cet exemple de script: https://github.com/colas31/gammu/blob/master/gammu_sms_received.sh
Et autrement tu peux regarder la doc officiel qui contient différent exemples https://docs.gammu.org/smsd/run.html
Bonsoir !
Après avoir regardé et testé beaucoup de tuto, celui-ci marche bien !
Par contre une fois, gammu-smsd installé je ne peux plus utiliser les commands de Gammu …
pi@raspberrypi:~ $ sudo gammu –identify
Erreur à l’ouverture du périphérique : périphérique inconnu, occupé ou problème de permissions.
Ce n’est pas si grave si je n’ai pas accès, les sms s’envoient quand même et je ne souhaite pas en recevoir, mais je voulais comprendre pourquoi !
Merci 😉
Bonne année
Hello,
Merci pour ton retour positif 🙂
Lorsque le daemon est lancé il se connecte/ouvre le périphérique en permanence, ce qui explique que la commande gammu –identify échoue. Il faut couper le daemon pour que la commande fonctionne.
Par défaut ton périphérique va recevoir les sms. Tu peux effectuer une action à chaque sms recu en utilisant l’option RunOnReceive.
Si besoin je peux rédiger un article à ce sujet.
Bonjour
Merci pour ce tuto.
Je l’utilise avec succès depuis deux ans… L’envoi de SMS est OK.
Sauf que…..
J’utilise ce système comme alarme de surveillance de température. Est que la sonnette de notification est insuffisante pour me réveiller ! Donc
Existe t-il ou commande pour faire sonner le téléphone comme un appel vocal. Avec un raccrochage auto au bout de x seconde.
Ainsi je pourrai avoir un système d’alarme à deux niveau. D’abord les SMS puis au bout de x SMS sans reponse une sonnerie plus inportante.
Je code en pyton
Call(….. Gammu SMS inject………)
D’avance merci
Bonjour,
Merci pour ton retour positif 🙂
A priori depuis la doc tu peux émettre un appel avec la commande: gammu maketerminatedcall 06xxx 20
Ça va faire un appel qui se terminera après 20secondes.
Par contre il faut probablement couper le daemon au moment ou tu exécutes cette commandes.
A tester 😉
Bonjour, ma clé 3G usb est bien détectée dans lsusb mais pas dans demsg. Aucune ligne GSM modem n’apparaît. Que faire ?
Hello,
Un redémarrage du raspberry change t’il quelque chose ?
Meme si tu n’as rien dans demsh as tu tenté d’aller plus loin dans le tuto?
bonjour, merci pour votre tuto mais je rencontre plusieurs problèmes notamment après l’installation de gammu et wammu par les commmendes apt-get install gammu et apt-get install wammu (déjà en super user)
wammu ne s’ouvre pas malgre le succès de l’installation, l’icone apparait mais lorsque je clique déçu cela ne s’ouvre pas
Bonjour,
Malheureusement je n’ai jamais utilisé Wammu, je suis dans l’incapacité de vous aider, désolé.
Hey, I installed gammu under centos 7 sever, When I test the send sms
[root@Gammu ~] # echo « hello » | gammu –sendsms TEXT +2162*******
No response in specified timeout. Probably phone not connected.
please How I resolve this issue
Hi,
Have you tried to restart your centos after the installation of Gammu?
Don’t hesitate to disconnect your phone, reconnect it and try again the gammu-detect and verify if the output is the same that the content of the file /etc/gammurc
Bonjour, votre tuto me parait très simple mais je bute dès le début.
J’ai raccordé 2 téléphones (Nokia et LG G6).
Le système ne les voit pas comme des USBxxx mais ttyACM
[gammu]
device = /dev/ttyACM0
name = LGE LG-H870
connection = at
[gammu1]
device = /dev/ttyACM1
name = Nokia Nokia_3109c
connection = at
Je ne compend pas pourquoi lors que je mets des
commands gammu –smsd-inject TEXT 06XXXXXXXX -text « Test tutoandco » -len 14 ou tout autre message après gammu est pris comme « impossible d’ouvrir le fichier spécifié »/
Les seuls commands possibles sont gammu-detect et gammu-config.
Bonjour,
As tu déjà tenté de faire le setup qu’avec un seul téléphone? Commencer avec deux téléphones d’un coup peut être un peu compliqué.
Est ce que tu as changé les droits sur le dossier /var/spool/gammu? J’ai l’impression que Gammu ne parvient pas à écrire dans un dossier.
Bonjour et merci pour votre article qui m’a permis de démarrer avec Gammu sur un raspberry. J’ai un petit soucis bizarre. Tout fonctionne bien avec Gammu en standard. Par contre, le daemon n’envoie et ne reçoit pas les SMS. J’ai le message « gammu-smsd[1045]: Error at init connection: Error opening device, it doesn’t exist. (DEVICENOTEXIST[4]) » dans le log.
J’ai pourtant bien recopié les 3 blocs [gammu] [gammu1] et [gammu2] dans le fichier de config de daemon.
Avec quelques recherches sur ce message d’erreur, cela correspondrait au fait que le daemon ne voit pas ma clé usb comme un modem et il y a des solutions pour ça mais j’hésite à casser ce qui marche en les appliquants car si Gammu standard sait utiliser la clé usb c’est qu’elle est bien reconnue comme modem. La seule utilité du dameon pour moi est de ne pas devoir taper le PIN mais au pire, je peux lancer un script au démarrage qui le fera.
Bref, si ce problème vous dit quelque chose, toute suggestion est la bienvenue. Merci déjà en tout cas.
Je réponds un peu tard. Avez vous réussi à corriger votre problème ?
De mémoire lorsque ce que j’avais eu à faire à ce genre d’erreur.
Redémarrage integralement le serveur.
Relance du daemon gammu
si toujours l’erreur je relancais un scan des device pour vérifier que les bons sont présent dans le fichier de conf, puis mise à jour du fichier si necessaire et relance du daemon
Hello et bravo pour ce tuto simple et efficace.
Moi le problème rencontré est le comportement de « Gammu SMS Daemon » lors de la tentative d’envoi à un numero erroné. « Gammu SMS Daemon » ne déplace pas le fichier dans le dossier « /var/spool/gammu/error/ »et le laisse dans le dossier « outboxpath = /var/spool/gammu/outbox/ ».
de ce fait les envois sont bloqué jusqu’à ce que l’on déplace le fichier manuellement ou on supprime l’intrus.
Avez-vous une idée?
Merci encore.
Avez vous réussi à corriger votre soucis.
J’avoue que je n’ai jamais eu à faire à ce use case.
Il me semble qu’il n’existe pas d’option pour vider le dossier.
je mettrai en place un cron qui en cas de présence de fichier vieux de plus de x minutes dans le dossier /var/spool/gammu/outbox/, je les deplacerai dans le dossier error
Bonjour,
Merci pour votre tutoriel, mais j’ai un petit soucis, je parviens à envoyer des sms mais ses sms sont incomplets, je ne sais quoi faire pour résoudre le problème. Svp avez-vous une idée pour solutionner ceci ?
Bonjour,
Il faut rajouter un paramètre -len suivi de la longueur du texte à la ligne de commande, ce qui donne : gammu-smsd-inject TEXT 06XXXXXXXX -text « Test tutoandco » -len 14
Bonjour,
j’ai une question assez proche de Thibault. Non seulement les ports /dev/ttyUSBx affectés au E169 varient au reboot mais ils changent aussi de façon imprévue. Ainsi, le soir, tout fonctionne (émission et réception de sms) mais dans la nuit la réaffectation des USBx fait que ça ne fonctionne plus le matin (sans redémarrage). Pourtant E169 est sur un hub alimenté et je ne comprends pas pourquoi les ports sont ainsi réaffectés car il ne devrait pas y avoir de coupure au niveau du dongle (défaut du dongle? mais comment savoir?). J’ai essayé la définition d’une règle pour un port logique mais ça ne semble pas s’adapter correctement…
Par ailleurs, je ne comprends pas pourquoi il y a trois fichiers de config : /etc/gammurc, /etc/gammu-smsd et /etc/gammu-smsdrc. Il y a de la redondance, non? De plus, l’attribut PIN défini dans /etc/gammu-smsdrc ne semble pas avoir d’effet puisqu’il faut faire un gamma-entersecuritycode pour que le démon smsd fonctionne. J’ai trouvé la doc sur comment définir les fichier de configuration mai assez peu sur comment ils sont utilisés. Pouvez-vous me faire partager vos fichiers de config?
Merci!!
Bonjour,
Concernant le changement des ports, j’ai trouvé une astuce qui dans mon cas me permet de reboot sans être embêté par le changement. Je finis le tuto et je le publi d’ici la fin de la semaine.
Concernant les fichiers, il y avait une erreur que j’ai corrigé. Tu ne devrais avoir que deux fichiers /etc/gammurc (pour gammu) et /etc/gammu-smsdrc (pour le daemon).
J’ai mis mes fichiers de conf sur mon github : https://github.com/colas31/gammu
Concernant le code pin, je n’ai eu à utiliser entersecuritycode que pour gammu et non pour le daemon. Il faudrait tenter avec mes fichiers de conf.
Si quelque chose n’est pas clair ne pas hésiter 🙂
Bonjour colas et merci pour ce tuto.
A la lecture de votre tuto en autre, je me suis lancé dans le projet suivant : communiquer par SMS avec Domoticz via un modem USB 3G
Mes achats : RapberryPI3, RFxcom 433 et Huawei E169 (+prises télécommandables et thermometre Oregon).
Bref, j’ai suivi le tuto et j’arrive à envoyer des SMS via des commandes de type « gammu-smsd-inject TEXT 06XXXXXXXX -text « Test » »
Cela prouve que j’ai bien installé, Raspbian, Gammu et Gammu-smsd
Mon problème est le besoin de rendre l’ensemble robuste et compatible avec une coupure de courant.
C’est là que j’ai mon problème : Error at init connection: Error opening device, it doesn’t exist. (DEVICENOTEXIST[4]) dans la log
C’est cependant aléatoire et semble t’il directement lié au périphérique retourné par gammu –identify qui change (parfois ttyUSB0 et parfois ttyUSB1)
J’en arrive donc à la conclusiond’un mauvais paramétrage des 2 fichiers de config /etc/gammurc et /etc/gammu-smsdrc ou/et des règles d’affectation des périphériques = fichier /etc/udev/rules.d/99-usb-serial.rules
(https://www.domoticz.com/wiki/PersistentUSBDevices)
Sauf erreur, au branchement du modem E169, 3 périphériques sont montés (un usb stockage de masse, un modem et ?) dans un ordre aléatoire.
Il semble donc nécessaire d’ajouter le montage d’un lien symbolique et de se servir de ce lien dans les fichiers de conf de Gammu et Gammu-smsd.
Je ne sais pas comment déterminer la syntaxe du etc/udev/rules.d car il faut, en plus des idVendor et idProduct, trouver une différence dans ce E169 pour identifier « à tous les coups » le modem des 2 autres périphériques.
Auriez-vous la possibilité de me communiquer le contenu de vos fichiers de conf, je me demande si il faut les 3 sections [gammu1, 2 et 3] dans gammurc et dans gammu-smsdrc ou pas ?
Voici le contenu des miens :
sudo nano /etc/gammurc
; Configuration file generated by gammu-detect.
; Please check The Gammu Manual for more information.
[gammu]
device = /dev/ttyUSB0
name = Phone on USB serial port ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ HUAWEI_Mobile
connection = at
[gammu1]
device = /dev/ttyUSB2
name = Phone on USB serial port ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ HUAWEI_Mobile
connection = at
[gammu2]
device = /dev/ttyUSB3
name = Phone on USB serial port ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ HUAWEI_Mobile
connection = at
et
sudo nano /etc/gammu-smsdrc
; Configuration file generated by gammu-detect.
; Please check The Gammu Manual for more information.
[gammu]
device = /dev/ttyUSB0
name = Phone on USB serial port ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ HUAWEI_Mobile
connection = at
[gammu1]
device = /dev/ttyUSB2
name = Phone on USB serial port ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ HUAWEI_Mobile
connection = at
[gammu2]
device = /dev/ttyUSB3
name = Phone on USB serial port ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ HUAWEI_Mobile
connection = at
[smsd]
PIN=0000
SMSC=+3369xxxxx95
service = files
logfile = /tmp/gammu-smsdsyslog
# 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/
enfin, une idée de ce que pourrait/devrait être
sudo nano /etc/udev/rules.d/99-usb-serial.rules
SUBSYSTEM== »tty », ATTRS{idVendor}== »12d1″, ATTRS{idProduct}== »140c », SYMLINK+= »ttyUSB-HuaweiE169_%E{ID_USB_INTERFACE_NUM} »
Désolé c’est peut-être un peu long mais je galère et tourne en rond.
D’avance merci
Bonjour,
Merci pour ce commentaire. Je vous ai envoyé directement un mail pour que ce soit plus clair et lisible.
Je mettrai un résumé et une solution ici plus tard
Bonjour,
Je rencontre le même pb de détection avec le même message d’erreur.
Je n’ai pas vu la solution à venir. 🙁
Merci d’avance.
Bruno
Bonsoir Bruno,
Vous pouvez aller lire cet article, https://tutoandco.colas-delmas.fr/software/fixer-ports-huawei-gammu/; il devrait vous aider à corriger l’erreur.
N’hésitez pas à revenir vers moi.
Colas
Merci pour ce tuto et ce partage. Vraiment très cool.
Merci pour votre retour 🙂
Bonjour,
J’ai déjà mit en place l’envois des sms avec gammu-sms mais lorsque je renvois un sms déçu, il ne l’affiche pas dans le /var/spool/gammu/inbox/ et m’affiche dans le /var/log/gammu_syslog un message d’erreur lors du déclenchement du script du type « process failed with exit status 127 ».
Que faire ?
Merci
Tu parles bien de l’option RunOnReceive ? je viens de la tester, et après quelques changement j’ai réussi à la faire marcher.
Il faut faire attention aux droits du fichier à exécuter, et à son emplacement.
RunOnReceive = /tmp/demo.sh
Voila les les droits que j’ai mis pour tester.
-rwxrwxrwx 1 gammu gammu 42 Mar 22 08:16 /tmp/demo.sh
Dans cette configuration j’ai ces infos dans mon syslog :
Mar 22 08:28:43 DietPi gammu-smsd[18826]: Received IN20170322_082749_00_+336xxxxxxx_00.txt
Mar 22 08:28:43 DietPi gammu-smsd[18862]: Starting run on receive: /tmp/demo.sh IN20170322_082749_00_+336xxxxxxx_00.txt
Mar 22 08:28:43 DietPi gammu-smsd[18826]: Process finished successfully
Voici mon code du fichier :
#!/bin/sh
echo "SMS OK" >> /tmp/debug.log
Bonjour, j’ai le même modem ( les mêmes caractéristiques) que celui que vous avez utiliser dans la présentation et les ttyUSB* apparaissent bien. Cependant, lorsque je lance « gammu identify » il renvoie : Le temps d’atente est passé. Le téléphone est probablement non connecté. Mais tout à l’heure je reverifi il ne présente que les ports ttyS*. Aider-moi s’il vous plait.
Bonjour,
Sur quel distribution fais tu les tests ? (Raspbian aussi) ? Hésite pas à reboot le PC, et rebrancher la clé après, voir si cela change quelque chose.
As tu regardé dans les logs (/var/log/gammu.log) si il y avait des détails de l’erreur ?
As tu testé sur un autre port USB ?
As tu testé la carte SIM dans un téléphone, afin de déterminer que tu as bien du réseau ?
Essaie également d’aller jusqu’à la fin de la configuration et de tenter d’envoyer un SMS via la commande gammu sendsms pour voir quel message d’erreur tu obtiens.
Bon courage 😉
Super projet !
Je suis confronté à un soucis, lorsque j’envoie deux SMS simultanément seul le premier est reçu, voir même aucun.
Avez-vous une idée pour solutionner ceci ?
En effet j’ai pu tester et reproduire le problème. L’installation du daemon corrige le problème.
J’ai mis à jour l’article en conséquent
Bonjour
Merci pour le tuto
A chaque redémarrage les textos ne semblent plus s’envoyer, avez vous une piste ?
Cordialement
Hello,
A priori si la carte SIM est protégée par un code PIN, il faut le renseigner à chaque redémarrage du serveur / PC via cette commande : gammu entersecuritycode PIN xxxx