cert_util.cpp 1.65 KB
Newer Older
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
//
// Created by kladko on 12/27/19.
//

#include <iostream>
#include <cstring>
#include <jsonrpccpp/client/connectors/httpclient.h>
#include "stubclient.h"

#include <unistd.h>

int print_hashes(){
  jsonrpc::HttpClient client("http://localhost:1028");
  StubClient c(client, jsonrpc::JSONRPC_CLIENT_V2);
  std::cout << "Client inited" << std::endl;
  std::cout << c.GetUnsignedCSRs() << std::endl;
  exit(0);
}

void sign_by_hash(std::string & hash, int status){
  jsonrpc::HttpClient client("http://localhost:1028");
  StubClient c(client, jsonrpc::JSONRPC_CLIENT_V2);
  std::cout << "Client inited" << std::endl;
  std::cout << c.SignByHash(hash, status) << std::endl;
  exit(0);
}

int main(int argc, char *argv[]) {

  int opt;

  if (argc > 1 && strlen(argv[1]) == 1) {
    fprintf(stderr, "option is too short %s\n", argv[1]);
    exit(1);
  }

  if (argc == 1) {
    std::cout << "You may use following flags:" << std::endl;
    std::cout << " -p  print all unsigned csr hashes " << std::endl;
    std::cout << " -s [hash] sign csr by hash" << std::endl;
    std::cout << " -r [hash] reject csr by hash" << std::endl;
    exit(0);
  }
     std::string hash;
      while ((opt = getopt(argc, argv, "ps:r:")) != -1) {
          switch (opt) {

              case 'p': print_hashes();
                        break;
              case 's': hash = optarg;
                        sign_by_hash(hash, 0);
                        break;
              case 'r': hash = optarg;
                        sign_by_hash(hash, 2);
                        break;
              case '?': // fprintf(stderr, "unknown flag\n");
                        exit(1);

          }
      }

  return 0;
}