File: engine_passthrough.cc

package info (click to toggle)
grpc 1.51.1-8
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 78,336 kB
  • sloc: cpp: 361,873; python: 72,206; ansic: 37,787; objc: 12,434; ruby: 11,521; sh: 7,652; php: 7,615; makefile: 3,481; xml: 3,246; cs: 1,836; javascript: 1,614; java: 465; pascal: 227; awk: 132
file content (73 lines) | stat: -rw-r--r-- 2,288 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
 *
 * Copyright 2020 gRPC authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 */

// This is a sample openSSL engine which tests the openSSL
// engine plugability with gRPC.
// This sample engine expects KeyId to be actual PEM encoded
// key itself and just calls standard openSSL functions.

#include <openssl/bio.h>
#include <openssl/engine.h>
#include <openssl/pem.h>

#ifndef OPENSSL_IS_BORINGSSL

#include <stdio.h>
#include <string.h>

extern "C" {
static const char engine_id[] = "libengine_passthrough";
static const char engine_name[] = "A passthrough engine for private keys";
static int e_passthrough_idx = -1;

static int e_passthrough_init(ENGINE* e) {
  if (e_passthrough_idx < 0) {
    e_passthrough_idx = ENGINE_get_ex_new_index(0, NULL, NULL, NULL, 0);
    if (e_passthrough_idx < 0) return 0;
  }
  return 1;
}

EVP_PKEY* e_passthrough_load_privkey(ENGINE* eng, const char* key_id,
                                     UI_METHOD* ui_method,
                                     void* callback_data) {
  EVP_PKEY* pkey = NULL;
  BIO* pem = BIO_new_mem_buf((void*)key_id, (int)(strlen(key_id)));
  if (pem == NULL) return NULL;
  pkey = PEM_read_bio_PrivateKey(pem, NULL, NULL, (void*)"");
  BIO_free(pem);
  return pkey;
}

int passthrough_bind_helper(ENGINE* e, const char* id) {
  if (id && strcmp(id, engine_id)) {
    return 0;
  }
  if (!ENGINE_set_id(e, engine_id) || !ENGINE_set_name(e, engine_name) ||
      !ENGINE_set_flags(e, ENGINE_FLAGS_NO_REGISTER_ALL) ||
      !ENGINE_set_init_function(e, e_passthrough_init) ||
      !ENGINE_set_load_privkey_function(e, e_passthrough_load_privkey)) {
    return 0;
  }
  return 1;
}

IMPLEMENT_DYNAMIC_BIND_FN(passthrough_bind_helper)
IMPLEMENT_DYNAMIC_CHECK_FN()
}
#endif  // OPENSSL_IS_BORINGSSL