2018-12-29 06:31:10 +08:00
|
|
|
/* roca.c - ROCA (CVE-2017-15361) fingerprint checker.
|
|
|
|
* Written by Rob Stradling (based on https://github.com/crocs-muni/roca/blob/master/roca/detect.py)
|
|
|
|
* Copyright (C) 2017-2018 Sectigo Limited
|
|
|
|
* modified 2018 iceman (dropped openssl bignum, now use mbedtls lib)
|
|
|
|
* modified 2018 merlok
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
2018-12-28 19:46:52 +08:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// EMV roca commands
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#ifndef EMV_ROCA_H__
|
|
|
|
#define EMV_ROCA_H__
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include "mbedtls/bignum.h"
|
|
|
|
#include "util.h"
|
|
|
|
|
|
|
|
#define ROCA_PRINTS_LENGTH 17
|
|
|
|
|
2018-12-29 02:33:24 +08:00
|
|
|
extern bool emv_rocacheck( const unsigned char *buf, size_t buflen, bool verbose );
|
2019-01-01 17:53:41 +08:00
|
|
|
extern int roca_self_test( void );
|
2018-12-28 19:46:52 +08:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|