Skip to content

zdimension/security-iot-notre-projet

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 

Repository files navigation

Projet de sécurité / IoT

Documentation des composants :

Rapport de développement

Nous sommes partis de l'exemple Hello World fourni, et avons commencé par mettre en place une architecture de code permettant de gérer plusieurs instructions (décodage du champ INS, appel de la fonction correspondante). De là, nous avons pu implémenter la gestion du code PIN et de l'authentification ; faute d'une documentation correcte pour OwnerPIN, nous avons pu nous inspirer de ce projet. Concrètement, un objet OwnerPIN est stocké de manière persistante dans l'applet et fournit les fonctionnalités usuelles d'un PIN (vérifier, gérer le nombre d'essais restant avant blocage, modifier).

Pour le chiffrement, nous avons pu utiliser les classes du package javacard.security qui correspond plus ou moins aux classes disponibles sur bureau dans javax.crypto. Un objet KeyPair est instancié lors de la [ré]initialisation de l'applet, et est stocké de manière persistante. Cependant, ce package ne supporte pas le hachage SHA-256, celui-ci est donc effectué côté client (ce qui ne change rien à la validité du processus). Côté carte, la charge à signer est construite à partir du hash transmis et de l'identifiant ASN.1 pour le SHA-256, et le tout est chiffré avec la clé privée pour aboutir à une signature.

Le client a été développé en tandem avec l'applet, et les tests se faisaient ainsi via l'envoi des APDUs à tester depuis le REPL du client. L'utilitaire openssl sur ordinateur a été utilisé pour s'assurer que les signatures étaient correctement générées et valides (en effet, on peut vérifier avec openssl une signature générée par la carte, et ça fonctionne).

Détail des APDUs

Toutes les communications avec l'applet se font en T=0.

INS Description Entrée Sortie Authentifié
01 Renvoie un message stocké dans la carte Message
02 S'authentifie dans la carte PIN (4 o)
03 Modifie le PIN PIN (4 o) Oui
04 Se désauthentifie de la carte Oui
05 Réinitialise le PIN et la paire de clés
06 Signe le hash SHA-256 fourni Hash (32 o) Signature (64 o) Oui
07 Renvoie la clé publique Clé publique
08 Renvoie la clé privée Clé privée Oui

Format de la clé publique

Position Taille Description
0 2 Longueur de l'exposant (e_len)
2 e_len Exposant
2 + e_len 2 Longueur du module (n_len)
4 + e_len n_len Module

Le couple (e, n) décrit la clé publique et permet de chiffrer des données.

Format de la clé privée

Position Taille Description
0 2 Longueur de p (p_len)
2 p_len p
2 + p_len 2 Longueur de q (q_len)
4 + p_len q_len q

Les clés privées RSA sont usuellement décrites via le nombre d défini comme d = e^-1 mod (p-1)(q-1). Cependant, l'API JavaCard ne permet pas d'obtenir d directement, et le calculer sur la carte est coûteux en ressources (en outre, BigInteger n'est pas disponible sur la carte). Nous récupérons donc p et q, que JavaCard expose, et nous calculons d côté client à partir de la clé publiqu et la clé privée à l'aide de la formule citée plus tôt.

Exemple de communication

sequenceDiagram
    participant C as Client
    participant A as Applet

    critical Load applet
        C->>+A: LOAD with applet AID<br>80 E8 00 00 0A A0 40 41 42 43 44 45 46 10 01 00
        A->>-C: OK<br>90 00

        C->>+A: SELECT with applet AID<br>00 A4 04 00 0A A0 40 41 42 43 44 45 46 10 01 00
        A->>-C: OK<br>90 00
    end

    C->>+A: HELLO<br>42 01 00 00 00
    A->>C: Bad length value in Le, 19 is the correct exact Le<br>6C 13

    C->>A: HELLO<br>42 01 00 00 13
    A->>-C: "Virtualbox m'a tuer"<br>56 69 72 74 75 61 6C 62 6F 78 20 6D 27 61 20 74 75 65 72<br>OK<br>90 00

    C->>+A: LOGIN 1234<br>42 02 00 00 04 01 02 03 04 00
    critical Logged in
        A->>-C: OK<br>90 00

        C->>+A: SIGN (SHA-256 digest of "bonjour")<br>42 06 00 00 20 ......... (32 bytes) 00
        A->>C: Success, 64 bytes available using GET RESPONSE
        C->>A: GET RESPONSE<br>A0 C0 00 00 40
        A->>-C: Signature<br>........ (64 bytes)

        C->>+A: LOGOUT<br>42 04 00 00 00
    end
    A->>-C: OK<br>90 00
Loading

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published