4 * The secure anycast tunneling protocol (satp) defines a protocol used
5 * for communication between any combination of unicast and anycast
6 * tunnel endpoints. It has less protocol overhead than IPSec in Tunnel
7 * mode and allows tunneling of every ETHER TYPE protocol (e.g.
8 * ethernet, ip, arp ...). satp directly includes cryptography and
9 * message authentication based on the methodes used by SRTP. It is
10 * intended to deliver a generic, scaleable and secure solution for
11 * tunneling and relaying of packets of any protocol.
14 * Copyright (C) 2007 anytun.org <satp@wirdorange.org>
16 * This program is free software; you can redistribute it and/or modify
17 * it under the terms of the GNU General Public License version 2
18 * as published by the Free Software Foundation.
20 * This program is distributed in the hope that it will be useful,
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23 * GNU General Public License for more details.
25 * You should have received a copy of the GNU General Public License
26 * along with this program (see the file COPYING included with this
27 * distribution); if not, write to the Free Software Foundation, Inc.,
28 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
34 #include "datatypes.h"
41 * This class is a wrapper for the libgcrypt multi precision integer library [1]
42 * [1] http://www.gnupg.org/documentation/manuals/gcrypt/MPI-library.html
53 Mpi(const u_int8_t
* src
, u_int32_t len
);
55 void operator=(const Mpi
&src
);
56 void operator=(u_int32_t src
);
57 Mpi
operator+(const Mpi
&b
) const;
58 Mpi
operator+(const u_int32_t
&b
) const;
59 Mpi
operator*(const u_int32_t n
) const;
60 Mpi
operator/(const Mpi
&b
) const;
62 Mpi
operator^(const Mpi
&b
) const;
64 Mpi
mul2exp(u_int32_t e
) const; // value * 2^e
67 * returns a new[] u_int8_t* buffer with the MPI value in the
68 * GCRYMPI_FMT_STD (2-complement stored without a length header).<br>
69 * you have to delete it by hand with delete[]!
70 * @param buf_len size of the new buffer that is returned
71 * @return a byte buffer of size buf_len
73 u_int8_t
*getNewBuf(u_int32_t
* written
) const;
74 std::string
getHexDump() const;
75 u_int32_t
getLength() const;