blob: ce6cf6301219784c8d6e903d918fb1c05e3c66ba [file] [log] [blame]
NingSun0c89b3c2018-02-08 08:34:03 -08001/*
2 * Copyright (c) 2010 SURFnet bv
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
13 *
14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
15 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
16 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
18 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
20 * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
21 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
22 * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
23 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
24 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 */
26
27/*****************************************************************************
28 ECPublicKey.h
29
30 Elliptic Curve public key class
31 *****************************************************************************/
32
33#ifndef _SOFTHSM_V2_ECPUBLICKEY_H
34#define _SOFTHSM_V2_ECPUBLICKEY_H
35
36#include "config.h"
37#include "PublicKey.h"
38
39class ECPublicKey : public PublicKey
40{
41public:
42 // The type
43 static const char* type;
44
45 // Check if the key is of the given type
46 virtual bool isOfType(const char* inType);
47
48 // Get the bit length
49 virtual unsigned long getBitLength() const;
50
51 // Get the output length
52 virtual unsigned long getOutputLength() const;
53
54 // Get the base point order length
55 virtual unsigned long getOrderLength() const = 0;
56
57 // Setters for the EC public key components
58 virtual void setEC(const ByteString& inEc);
59 virtual void setQ(const ByteString& inQ);
60
61 // Getters for the EC public key components
62 virtual const ByteString& getEC() const;
63 virtual const ByteString& getQ() const;
64
65 // Serialisation
66 virtual ByteString serialise() const;
67 virtual bool deserialise(ByteString& serialised);
68
69protected:
70 // Public components
71 ByteString ec,q;
72};
73
74#endif // !_SOFTHSM_V2_ECPUBLICKEY_H
75