| 1 | |
|---|
| 2 | |
|---|
| 3 | |
|---|
| 4 | |
|---|
| 5 | |
|---|
| 6 | |
|---|
| 7 | |
|---|
| 8 | |
|---|
| 9 | |
|---|
| 10 | |
|---|
| 11 | |
|---|
| 12 | |
|---|
| 13 | |
|---|
| 14 | |
|---|
| 15 | |
|---|
| 16 | |
|---|
| 17 | |
|---|
| 18 | |
|---|
| 19 | |
|---|
| 20 | #ifndef MUSCLE_H_ |
|---|
| 21 | #define MUSCLE_H_ |
|---|
| 22 | |
|---|
| 23 | #include <stddef.h> |
|---|
| 24 | |
|---|
| 25 | #include <opensc/types.h> |
|---|
| 26 | #include <opensc.h> |
|---|
| 27 | #include <opensc/cardctl.h> |
|---|
| 28 | |
|---|
| 29 | #include "muscle-filesystem.h" |
|---|
| 30 | |
|---|
| 31 | #define MSC_MAX_APDU 256 |
|---|
| 32 | #define MSC_MAX_PIN_LENGTH 8 |
|---|
| 33 | #define MSC_MAX_PIN_COMMAND_LENGTH ((1 + MSC_MAX_PIN_LENGTH) * 2) |
|---|
| 34 | |
|---|
| 35 | |
|---|
| 36 | #define MSC_MAX_READ (MIN(card->reader->driver->max_recv_size,255)) |
|---|
| 37 | #define MSC_MAX_SEND (MIN(card->reader->driver->max_send_size,255)) |
|---|
| 38 | |
|---|
| 39 | int msc_list_objects(sc_card_t* card, u8 next, mscfs_file_t* file); |
|---|
| 40 | int msc_partial_read_object(sc_card_t *card, msc_id objectId, int offset, u8 *data, size_t dataLength); |
|---|
| 41 | int msc_read_object(sc_card_t *card, msc_id objectId, int offset, u8 *data, size_t dataLength); |
|---|
| 42 | int msc_create_object(sc_card_t *card, msc_id objectId, size_t objectSize, unsigned short read, unsigned short write, unsigned short deletion); |
|---|
| 43 | int msc_partial_update_object(sc_card_t *card, msc_id objectId, int offset, const u8 *data, size_t dataLength); |
|---|
| 44 | int msc_update_object(sc_card_t *card, msc_id objectId, int offset, const u8 *data, size_t dataLength); |
|---|
| 45 | int msc_zero_object(sc_card_t *card, msc_id objectId, size_t dataLength); |
|---|
| 46 | |
|---|
| 47 | int msc_delete_object(sc_card_t *card, msc_id objectId, int zero); |
|---|
| 48 | int msc_select_applet(sc_card_t *card, u8 *appletId, size_t appletIdLength); |
|---|
| 49 | |
|---|
| 50 | int msc_verify_pin(sc_card_t *card, int pinNumber, const u8 *pinValue, int pinLength, int *tries); |
|---|
| 51 | void msc_verify_pin_apdu(sc_card_t *card, sc_apdu_t *apdu, u8* buffer, size_t bufferLength, int pinNumber, const u8 *pinValue, int pinLength); |
|---|
| 52 | int msc_unblock_pin(sc_card_t *card, int pinNumber, const u8 *pukValue, int pukLength, int *tries); |
|---|
| 53 | void msc_unblock_pin_apdu(sc_card_t *card, sc_apdu_t *apdu, u8* buffer, size_t bufferLength, int pinNumber, const u8 *pukValue, int pukLength); |
|---|
| 54 | int msc_change_pin(sc_card_t *card, int pinNumber, const u8 *pinValue, int pinLength, const u8 *newPin, int newPinLength, int *tries); |
|---|
| 55 | void msc_change_pin_apdu(sc_card_t *card, sc_apdu_t *apdu, u8* buffer, size_t bufferLength, int pinNumber, const u8 *pinValue, int pinLength, const u8 *newPin, int newPinLength); |
|---|
| 56 | |
|---|
| 57 | int msc_get_challenge(sc_card_t *card, short dataLength, short seedLength, u8 *seedData, u8* outputData); |
|---|
| 58 | |
|---|
| 59 | int msc_generate_keypair(sc_card_t *card, int privateKey, int publicKey, int algorithm, int keySize, int options); |
|---|
| 60 | int msc_extract_rsa_public_key(sc_card_t *card, |
|---|
| 61 | int keyLocation, |
|---|
| 62 | int* modLength, |
|---|
| 63 | u8** modulus, |
|---|
| 64 | int* expLength, |
|---|
| 65 | u8** exponent); |
|---|
| 66 | int msc_extract_key(sc_card_t *card, |
|---|
| 67 | int keyLocation); |
|---|
| 68 | int msc_compute_crypt_init(sc_card_t *card, |
|---|
| 69 | int keyLocation, |
|---|
| 70 | int cipherMode, |
|---|
| 71 | int cipherDirection, |
|---|
| 72 | const u8* initData, |
|---|
| 73 | u8* outputData, |
|---|
| 74 | size_t dataLength, |
|---|
| 75 | size_t* outputDataLength); |
|---|
| 76 | int msc_compute_crypt_process( |
|---|
| 77 | sc_card_t *card, |
|---|
| 78 | int keyLocation, |
|---|
| 79 | const u8* inputData, |
|---|
| 80 | u8* outputData, |
|---|
| 81 | size_t dataLength, |
|---|
| 82 | size_t* outputDataLength); |
|---|
| 83 | int msc_compute_crypt_final( |
|---|
| 84 | sc_card_t *card, |
|---|
| 85 | int keyLocation, |
|---|
| 86 | const u8* inputData, |
|---|
| 87 | u8* outputData, |
|---|
| 88 | size_t dataLength, |
|---|
| 89 | size_t* outputDataLength); |
|---|
| 90 | int msc_compute_crypt(sc_card_t *card, |
|---|
| 91 | int keyLocation, |
|---|
| 92 | int cipherMode, |
|---|
| 93 | int cipherDirection, |
|---|
| 94 | const u8* data, |
|---|
| 95 | u8* outputData, |
|---|
| 96 | size_t dataLength, |
|---|
| 97 | size_t outputDataLength); |
|---|
| 98 | int msc_import_key(sc_card_t *card, |
|---|
| 99 | int keyLocation, |
|---|
| 100 | sc_cardctl_muscle_key_info_t *data); |
|---|
| 101 | |
|---|
| 102 | |
|---|
| 103 | #endif |
|---|