Blog geekesque... ou pas

Aller au contenu | Aller au menu | Aller à la recherche

27/06/2016

[MAJ] Fail2ban ne donne pas les lignes correspondantes à une détection

Après avoir appliqué ce que j'ai expliqué dans ce billet, j'ai reçu des mails signalant le bannissement de certaines IP suite à la détection de tentatives d'injection SQL.

Problème : juste en dessous de Lines containing IP: <le méchant> in /var/log/nginx/*.access.log, il n'y avait rien.

Je suis allé voir le fichier /etc/fail2ban/action.d/sendmail-whois-lines.conf et l'expression régulière présente ne fonctionne pas avec mes logs.

Version initiale:

`grep '[^0-9]<ip>[^0-9]' <logpath>`

Je l'ai remplacée par:

`egrep '[^0-9]?<ip>([^0-9]|$)' <logpath>`

Maintenant, ça fonctionne. Ceci est dû aux types de fichiers logs que j'utilise pour nginx et dont le premier élément de la ligne est l'adresse IP.

MAJ : Problème de dates

Il arrive parfois que fail2ban envoie des mails à une date erronée (comme 01/01/1970). Pour corriger ça, il faut éditer le fichier /etc/default/fail2ban et ajouter les lignes suivantes:

LC_ALL=C
LANG=C

25/06/2016

fail2ban pour lutter contre les injections SQL

Si vous ne connaissez pas fail2ban, c'est un excellent utilitaire pour protéger vos serveurs des différentes attaques.

Il fonctionne à partir de filtres (des expressions régulières) qui sont appliqués aux fichiers logs et appliquer des sanctions aux petits malins qui tenteraient d'exploiter des failles.

Il existe beaucoup de filtres officiels contre les attaques les plus courantes, mais pas contre les tentatives d'injections SQL. Heureusement, TrogloGeek a créé un filtre, que j'ai un peu modifié pour le rendre plus fonctionnel et utilisable avec Apache et Nginx

# Fail2Ban configuration file
#
# Author: TrogloGeek (Damien VERON)
#
# $Revision: 1 $
#
 
[Definition]
sqlfragments_generic = select.*from|delete.*from|update.*set|insert.*into|replace.*(value|set)
sqlfragments_havij = and(\+|%%20)ascii%%28substring|and(\+|%%20)Length|union(\+|%%20)all(\+|%%20)select|and(\+|%%20)1%%3C1|and(\+|%%20)1%%3D1|and(\+|%%20)1%%3E1|and(\+|%%20)%%27.%%27%%3D%%27|%%2F\*%%21[0-9]+((\+|%%20)[0-9]*)?\*%%2F
 
# Option:  failregex
# Notes.:  Regex to try to detect SQL injection trials
# Values:  TEXT
#
failregex = (?i)<HOST> -.*"(GET|POST).*(?:%(sqlfragments_generic)s|%(sqlfragments_havij)s)[^"]*HTTP[^"]*".*
 
# Option:  ignoreregex
# Notes.:  regex to ignore. If this regex matches, the line is ignored.
# Values:  TEXT
#
ignoreregex =

Dans la partie Definition, vous trouvez les bouts de SQL les plus communs utilisés pour une tentative d'injection, séparés en deux parties: les génériques (requêtes de bases) et ceux qui sont clairement des signatures de tentatives de hack.

L'expression régulière est plus ou moins celle de base pour les logs apache et nginx, notez tout de même la présence de (?i) au début qui la rend insensible à la casse.

11/05/2016

Configurer le Raspberry Pi en point d'accès Wifi

Transformer son Raspberry Pi en point d'accès wifi est quelque chose de très simple à faire.

Si vous avez un Pi3, vous n'aurez aucun investissement particulier à faire. Si vous avez une version précédente, il faudra investir dans un dongle wifi qui le permette. Pour ma part, j'utilise le dongle officiel, mais la plupart le permettent.

Attention: vous devez soit être connecté en ethernet, soit être directement sur votre machine (clavier + écran) pour procéder à la suite des opérations, car vous allez modifier la configuration wifi. Elle ne sera donc plus fonctionnelle pendant un certain temps.

Lire la suite

26/04/2016

Démarrer son Raspberry Pi sur un disque dur

Par défaut, le Raspberry Pi fonctionne avec une carte SD, or ces cartes ont une durée de vie limitée en nombre de cycles d'écriture. Par contre, on peut les lire à l'infini sans souci.

Ayant fait l'acquisition d'un PiDrive, j'ai tenté de déporter tout le système sur le disque. Non seulement ça marche, mais c'est très simple à faire.

Sachez tout de même que vous ne pourrez pas éliminer complètement la carte SD. En effet, le RPi est ainsi fait qu'il va chercher le bootloader sur la carte SD, c'est inscrit de manière quasi-matérielle dans son système. Mais fort heureusement, il ne fait que le lire, donc aucune incidence sur la durée de vie de la-dite carte.

Lire la suite

05/03/2016

Caméra de surveillance avec Raspberry Pi

Suite à l'excellent billet de François Mocq "Une caméra de surveillance vidéo avec le Raspberry Pi", j'ai essayé de me faire mon propre système.

Ca marche, et c'est fort simple.

Lire la suite

Contrôler les leds du Raspberry Pi2B

Le Raspberry Pi 2 modèle B comporte 2 leds en face avant, une verte et une rouge. Par défaut, la verte (led0) signale l'utilisation de la carte SD et la rouge (led1) signale que le RPi est alimenté, mais pas forcément en marche.

Il est tout à fait possible de modifier le fonctionnement de ces leds, et très simplement.

Edit 07/03/2016

Claudius m'a signalé une chose importante, que je viens de vérifier: le changement en ligne de commande doit se faire en tant que root, pas avec la commande sudo.

Lire la suite

22/02/2016

Internet des objets facile avec Cayenne ?

On m'a fait découvrir Cayenne, qui permet de simplifier l'IoT ou, en français, l'Internet des Objets avec un Raspberry Pi.

J'ai testé, et pour l'instant je ne suis pas convaincu.

Lire la suite

11/02/2016

Raspberry Pi : Changer de carte SD sans perte

Ce tutoriel concerne les Raspberry Pi mais est facilement transposable à tout système utilisant des cartes SD.

Si comme moi vous avez acheté une SD NOOBS, vous n'avez que 8Go sur la carte, avec au mieux 5 Go d'utilisables. Et surtout, comme vous avez déjà configuré votre système, installé ou développé des applications, vous ne voulez pas tout perdre. Mais vous manquez de place, cruellement. Heureusement, il est possible de cloner sa carte sur une plus grande.

Je donne les explications pour procéder sous Windows et sous linux, car les logiciels employés ne sont pas les mêmes. Tous les logiciels utilisés sont gratuits.

Lire la suite

05/01/2016

Danger avec Tapatalk : perdez votre anonymat

Vous ne connaissez peut-être pas l'application Tapatalk, elle permet d'accèder à des forums et des blogs sur mobiles (et tablettes) si les webmasters ont installé le bon plugin. Elle a l'énorme avantage d'utiliser sa propre interface, donc indépendante du style du site et par conséquent de sa compatibilité avec votre écran.

Jusqu'ici, tout va bien... Sauf qu'il y a eu une mise à jour...

Lire la suite

11/09/2015

Installer une extension sur Yii2 sans composer

Lorsque Yii2 est sorti, une grande avancée a été faite dans son système d'installation, ainsi que dans celui des extensions: l'utilisation de composer. Composer est un outil de gestion des dépendances en PHP qui est fort utile et pratique, un peu comme les gestionnaires de package sous linux (apt, yum, ...). Mais parfois, on ne peut pas l'utiliser, et c'est plutôt bloquant.

Je vais donc vous décrire, si possible simplement, comment ajouter une extension à Yii2 à la main.

Lire la suite

- page 1 de 10