003 File Manager
Current Path:
/usr/src/contrib/bearssl/tools
usr
/
src
/
contrib
/
bearssl
/
tools
/
📁
..
📄
brssl.c
(3.29 KB)
📄
brssl.h
(16.93 KB)
📄
certs.c
(5.59 KB)
📄
chain.c
(3.46 KB)
📄
client.c
(25.76 KB)
📄
errors.c
(8.67 KB)
📄
files.c
(6.62 KB)
📄
impl.c
(1.49 KB)
📄
keys.c
(5.3 KB)
📄
names.c
(27.33 KB)
📄
server.c
(28.48 KB)
📄
skey.c
(17.09 KB)
📄
sslio.c
(16.88 KB)
📄
ta.c
(6.77 KB)
📄
twrch.c
(24.85 KB)
📄
vector.c
(2.13 KB)
📄
verify.c
(8.01 KB)
📄
xmem.c
(2.87 KB)
Editing: brssl.c
/* * Copyright (c) 2016 Thomas Pornin <pornin@bolet.org> * * Permission is hereby granted, free of charge, to any person obtaining * a copy of this software and associated documentation files (the * "Software"), to deal in the Software without restriction, including * without limitation the rights to use, copy, modify, merge, publish, * distribute, sublicense, and/or sell copies of the Software, and to * permit persons to whom the Software is furnished to do so, subject to * the following conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ #include <stdio.h> #include <stdlib.h> #include <string.h> #include <stdint.h> #include <errno.h> /* * Network stuff on Windows requires some specific code. */ #ifdef _WIN32 #include <winsock2.h> #include <ws2tcpip.h> #pragma comment(lib, "Ws2_32.lib") #endif #include "brssl.h" static void usage(void) { fprintf(stderr, "usage: brssl command [ options ]\n"); fprintf(stderr, "available commands:\n"); fprintf(stderr, " client run SSL client\n"); fprintf(stderr, " server run SSL server\n"); fprintf(stderr, " verify verify certificate chain\n"); fprintf(stderr, " skey decode private key\n"); fprintf(stderr, " ta decode trust anchors\n"); fprintf(stderr, " chain make C code for certificate chains\n"); fprintf(stderr, " twrch run the Twrch protocol\n"); fprintf(stderr, " impl report on implementations\n"); } int main(int argc, char *argv[]) { char *cmd; if (argc < 2) { usage(); return EXIT_FAILURE; } #ifdef _WIN32 { WSADATA wd; int r; r = WSAStartup(MAKEWORD(2, 2), &wd); if (r != 0) { fprintf(stderr, "WARNING: network initialisation" " failed (WSAStartup() returned %d)\n", r); } } #endif cmd = argv[1]; if (eqstr(cmd, "client")) { if (do_client(argc - 2, argv + 2) < 0) { return EXIT_FAILURE; } } else if (eqstr(cmd, "server")) { if (do_server(argc - 2, argv + 2) < 0) { return EXIT_FAILURE; } } else if (eqstr(cmd, "verify")) { if (do_verify(argc - 2, argv + 2) < 0) { return EXIT_FAILURE; } } else if (eqstr(cmd, "skey")) { if (do_skey(argc - 2, argv + 2) < 0) { return EXIT_FAILURE; } } else if (eqstr(cmd, "ta")) { if (do_ta(argc - 2, argv + 2) < 0) { return EXIT_FAILURE; } } else if (eqstr(cmd, "chain")) { if (do_chain(argc - 2, argv + 2) < 0) { return EXIT_FAILURE; } } else if (eqstr(cmd, "twrch")) { int ret; ret = do_twrch(argc - 2, argv + 2); if (ret < 0) { return EXIT_FAILURE; } else { return ret; } } else if (eqstr(cmd, "impl")) { if (do_impl(argc - 2, argv + 2) < 0) { return EXIT_FAILURE; } } else { fprintf(stderr, "unknown command: '%s'\n", cmd); usage(); return EXIT_FAILURE; } return 0; }
Upload File
Create Folder