Mikrotik : un « UserManager » pas au point !

Avec le développement de l’impression de tickets sur les hotspots Mikrotik, j’ai pu pas mal jouer avec le fameux User Manager, destiné à gérer les utilisateurs, leur affecter des profils, des durées, des limitations. Ce petit ajout au firmware RouterOS qui équipe les matériels Mikrotik semblait, sur le papier, plutôt sympa. Pour dialoguer avec, une simple connexion SSH initiée depuis un script Python sur un p’tit Raspberry Pi. Ca, c’est du moins la théorie, car en pratique, plusieurs bugs semblent subsister sur ce User Manager, et pas des moindres :

[badlist]

  • l’ajout d’utilisateur en ssh fonctionne, mais affecter un profil ne fonctionne qu’une fois sur deux : il faut envoyer la commande, vérifier, renvoyer la commande, vérifier, etc. Cela prend du temps, et lorsque vous voulez générer des dizaines de codes, la galère prend rapidement l’eau.
  • un utilisateur reçoit un profil qui lui attribue une durée d’utilisation : 1 jour, 1 heure, 1 minute, c’est vous qui décidez. Cela fonctionne super bien, sauf qu’une fois la durée expirée, votre utilisateur restera en mémoire : pas moyen de lister simplement tous les utilisateurs expirés. On les voit dans la liste car ils n’ont alors plus de profil mentionné : les supprimer supposerait de charger TOUTE la liste, de venir chercher utilisateur après utilisateur ce que contient la configuration, d’inscrire les logins à supprimer, etc. Imaginez le script de manipulation de chaine bien lourd qu’il faudrait, alors qu’une simple commande /tool usermanager delete expired aurait été d’un emploi si simple…. ben non 🙁

[/badlist]

 

De ce fait, après une journée perdue passée à cherche une solution fiable, stable, et universelle, force est de constater qu’il fallait se passer de ce User Manager encore trop peu stable pour un usage professionnel intensif et automatisé. Je précise bien automatisé car si vous gérez tout depuis l’interface d’administration, forcément cela fonctionne sans trop de soucis. Par contre, vous perdez alors la possibilité d’imprimer des coupons et n’avez toujours pas de fonctionnalité pour supprimer les codes expirés… on tourne en rond 🙁

Imprimante tickets pour hotspot Mikrotik

Retour donc à une solution plus simple, plus pratique : le gestionnaire utilisateur directement géré par la fonction /ip hotspot du firmware, et basta ! Là, la génération de code est bien plus simple : un login, un mot de passe, une durée et c’est tout ! Pas besoin de venir ajouter un profile ou je ne sais quoi d’autre.

Lorsque nous générons un code, voyons ce qu’il donne depuis l’accès ssh au hotspot :

name=« wsxb » password=« awfn » profile=default limit-uptime=1h uptime=0s bytes-in=0 bytes-out=0 packets-in=0 packets-out=0

limit-uptime=1h indique que ce code, wsxb dispose d’1 heure d’accès, pas plus. uptime=0s montre que le code n’a pas encore expiré, sans quoi nous aurions uptime=1h et là, nous pourrions clairement identifier le code pour venir le supprimer, étant expiré.

En conclusion, l’utilisation de RouterOS n’est pas si simple, les bugs subsistent et certaines fonctionnalités manquent cruellement. Si vous n’avez pas besoin de limiter vos utilisateurs autrement que sur la durée, User Manager ne vous sera d’aucune utilité. Espérons juste qu’il évolue vers une version plus « capable » et soit un jour en mesure d’effacer simplement les codes expirés.

 

Publications similaires

  • |

    Omni et gain

    Je lis ici et là qu’on trouve des antennes omni avec un gain totalement délirant, jusqu’à 19 dBi, voir plus si affinité !! Ne vous faites pas avoir, ce sont des dB commerciaux, sachant qu’une antenne omni ne dépassera généralement pas 15 dBi réellement mesurés ! Les boutiques qui cherchent à vous vendre des antennes omni au delà de 15 dBi ne sont par conséquent pas forcément les plus compétentes dans le domaine radio, même si leurs compétences marketing ne…

  • WiFi-Direct : nouvelle norme

    Wi-Fi CERTIFIED Wi-Fi Direct™ est une nouvelle certification pour une nouvelle technologie permettant aux périphériques WiFi d’effectuer des connexions directes, sans avoir besoin de soucier d’associations, d’IP ou de cryptage. L’interconnexion permet ainsi de connecter en quelques secondes des appareils photo, mobiles, imprimantes, des disques réseau, etc., sans avoir à utiliser de point d’accès ou de routeur. La seule action est, la plupart du temps, d’appuyer sur un seul bouton et d’effectuer une association. Protégées en WPA2, les connexions WiFi…

  • Restauration Bullet 5MHP

    Testant une configuration un peu particulière ce matin sur un Bullet 5MHP, avec un firmware tout aussi particulier, nous n’avons pas attendu longtemps le plantage de l’engin… Forcément, à force de l’asticoter, cela devait arriver… Ni une, ni deux, passage en mode restauration TFTP : hors tension, presser et maintenir le bouton reset situé à coté du connecteur ethernet du Bullet 5MHP mettre sous tension tout en maintenant la pression les LEDs s’allument, vous pouvez relâcher, le Bullet est désormais…

  • |

    Tim Cook : la Pomme se met au vert et nous prend pour des Poires

    Le dernier tweet de Tim Cook, patron de l’indéboulonnable Apple, a réussi à me faire bondir : Super, génial, la Pomme nous a sorti tout un tas de panneaux solaires en Chine, et c’est une bonne chose. Mais, si nous voulons laisser un monde meilleur après notre passage sur Terre, ne faudrait-il pas aussi penser à moins consommer, moins jeter surtout, et par dessus tout, mieux recycler ? Or, c’est tout l’inverse que le génial Apple nous propose, limitant les…

  • |

    Viber : les appels gratuits en 3G/WiFi sur iPhone

    En début d’année, j’avais évoqué, si ma mémoire ne me fait pas défaut, le fait que les forfaits actuels allaient petit à petit migrer vers des forfaits de données où tout protocole IP pourrait transiter. Je ne devais pas me tromper tant que ça si j’en juge les multiples applications communicantes sorties depuis : skype, iSip, Facetime, Tango, et maintenant Viber. L’idée est toujours aussi simple : s’appuyer sur votre connexion 3G ou WiFi pour passer des appels, à condition, dans…