blob: 33ae7f73fd9c1db53bd8a3ed4deaf261fcd0f487 [file] [log] [blame]
Adam Langleyd0592972015-03-30 14:49:51 -07001/* $OpenBSD: bufbn.c,v 1.12 2014/04/30 05:29:56 djm Exp $ */
2
Greg Hartmanbd77cf72015-02-25 13:21:06 -08003/*
Adam Langleyd0592972015-03-30 14:49:51 -07004 * Copyright (c) 2012 Damien Miller <djm@mindrot.org>
Greg Hartmanbd77cf72015-02-25 13:21:06 -08005 *
Adam Langleyd0592972015-03-30 14:49:51 -07006 * Permission to use, copy, modify, and distribute this software for any
7 * purpose with or without fee is hereby granted, provided that the above
8 * copyright notice and this permission notice appear in all copies.
Greg Hartmanbd77cf72015-02-25 13:21:06 -08009 *
Adam Langleyd0592972015-03-30 14:49:51 -070010 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
Greg Hartmanbd77cf72015-02-25 13:21:06 -080017 */
18
Adam Langleyd0592972015-03-30 14:49:51 -070019/* Emulation wrappers for legacy OpenSSH buffer API atop sshbuf */
20
Greg Hartmanbd77cf72015-02-25 13:21:06 -080021#include "includes.h"
22
Adam Langleyd0592972015-03-30 14:49:51 -070023#ifdef WITH_OPENSSL
24
Greg Hartmanbd77cf72015-02-25 13:21:06 -080025#include <sys/types.h>
26
Greg Hartmanbd77cf72015-02-25 13:21:06 -080027#include "buffer.h"
28#include "log.h"
Adam Langleyd0592972015-03-30 14:49:51 -070029#include "ssherr.h"
Greg Hartmanbd77cf72015-02-25 13:21:06 -080030
Adam Langleyd0592972015-03-30 14:49:51 -070031#ifdef WITH_SSH1
Greg Hartmanbd77cf72015-02-25 13:21:06 -080032int
33buffer_put_bignum_ret(Buffer *buffer, const BIGNUM *value)
34{
Adam Langleyd0592972015-03-30 14:49:51 -070035 int ret;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080036
Adam Langleyd0592972015-03-30 14:49:51 -070037 if ((ret = sshbuf_put_bignum1(buffer, value)) != 0) {
38 error("%s: %s", __func__, ssh_err(ret));
39 return -1;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080040 }
Adam Langleyd0592972015-03-30 14:49:51 -070041 return 0;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080042}
43
44void
45buffer_put_bignum(Buffer *buffer, const BIGNUM *value)
46{
47 if (buffer_put_bignum_ret(buffer, value) == -1)
Adam Langleyd0592972015-03-30 14:49:51 -070048 fatal("%s: buffer error", __func__);
Greg Hartmanbd77cf72015-02-25 13:21:06 -080049}
50
Greg Hartmanbd77cf72015-02-25 13:21:06 -080051int
52buffer_get_bignum_ret(Buffer *buffer, BIGNUM *value)
53{
Adam Langleyd0592972015-03-30 14:49:51 -070054 int ret;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080055
Adam Langleyd0592972015-03-30 14:49:51 -070056 if ((ret = sshbuf_get_bignum1(buffer, value)) != 0) {
57 error("%s: %s", __func__, ssh_err(ret));
58 return -1;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080059 }
Adam Langleyd0592972015-03-30 14:49:51 -070060 return 0;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080061}
62
63void
64buffer_get_bignum(Buffer *buffer, BIGNUM *value)
65{
66 if (buffer_get_bignum_ret(buffer, value) == -1)
Adam Langleyd0592972015-03-30 14:49:51 -070067 fatal("%s: buffer error", __func__);
Greg Hartmanbd77cf72015-02-25 13:21:06 -080068}
Adam Langleyd0592972015-03-30 14:49:51 -070069#endif /* WITH_SSH1 */
Greg Hartmanbd77cf72015-02-25 13:21:06 -080070
Greg Hartmanbd77cf72015-02-25 13:21:06 -080071int
72buffer_put_bignum2_ret(Buffer *buffer, const BIGNUM *value)
73{
Adam Langleyd0592972015-03-30 14:49:51 -070074 int ret;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080075
Adam Langleyd0592972015-03-30 14:49:51 -070076 if ((ret = sshbuf_put_bignum2(buffer, value)) != 0) {
77 error("%s: %s", __func__, ssh_err(ret));
78 return -1;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080079 }
Adam Langleyd0592972015-03-30 14:49:51 -070080 return 0;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080081}
82
83void
84buffer_put_bignum2(Buffer *buffer, const BIGNUM *value)
85{
86 if (buffer_put_bignum2_ret(buffer, value) == -1)
Adam Langleyd0592972015-03-30 14:49:51 -070087 fatal("%s: buffer error", __func__);
Greg Hartmanbd77cf72015-02-25 13:21:06 -080088}
89
90int
91buffer_get_bignum2_ret(Buffer *buffer, BIGNUM *value)
92{
Adam Langleyd0592972015-03-30 14:49:51 -070093 int ret;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080094
Adam Langleyd0592972015-03-30 14:49:51 -070095 if ((ret = sshbuf_get_bignum2(buffer, value)) != 0) {
96 error("%s: %s", __func__, ssh_err(ret));
97 return -1;
Greg Hartmanbd77cf72015-02-25 13:21:06 -080098 }
Adam Langleyd0592972015-03-30 14:49:51 -070099 return 0;
Greg Hartmanbd77cf72015-02-25 13:21:06 -0800100}
101
102void
103buffer_get_bignum2(Buffer *buffer, BIGNUM *value)
104{
105 if (buffer_get_bignum2_ret(buffer, value) == -1)
Adam Langleyd0592972015-03-30 14:49:51 -0700106 fatal("%s: buffer error", __func__);
Greg Hartmanbd77cf72015-02-25 13:21:06 -0800107}
Adam Langleyd0592972015-03-30 14:49:51 -0700108
109#endif /* WITH_OPENSSL */