aboutsummaryrefslogtreecommitdiff
path: root/xdr_internal.h
blob: 921b991ecfa357abc01da0fbeaf18c8b18b282db (plain) (blame)
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
/*
 * xdr_internal.h
 * --------------
 * Serialization/deserialization routines, using XDR (RFC 4506) encoding.
 *
 * Copyright (c) 2016, NORDUnet A/S All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are
 * met:
 * - Redistributions of source code must retain the above copyright notice,
 *   this list of conditions and the following disclaimer.
 *
 * - Redistributions in binary form must reproduce the above copyright
 *   notice, this list of conditions and the following disclaimer in the
 *   documentation and/or other materials provided with the distribution.
 *
 * - Neither the name of the NORDUnet nor the names of its contributors may
 *   be used to endorse or promote products derived from this software
 *   without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
 * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

#ifndef _XDR_INTERNAL_H
#define _XDR_INTERNAL_H

 /*
 * RPC serialization/deserialization routines, using XDR (RFC 4506) encoding.
 */

hal_error_t hal_xdr_encode_int(uint8_t ** const outbuf,
                               const uint8_t * const limit,
                               const uint32_t value);

hal_error_t hal_xdr_decode_int(const uint8_t ** const inbuf,
                               const uint8_t * const limit,
                               uint32_t * const value);

hal_error_t hal_xdr_encode_buffer(uint8_t ** const outbuf,
                                  const uint8_t * const limit,
                                  const uint8_t * const value,
                                  const uint32_t len);

hal_error_t hal_xdr_decode_buffer_in_place(const uint8_t ** const inbuf,
                                           const uint8_t * const limit,
                                           const uint8_t ** const vptr,
                                           uint32_t * const len);

hal_error_t hal_xdr_decode_buffer(const uint8_t ** const inbuf,
                                  const uint8_t * const limit,
                                  uint8_t * const value,
                                  uint32_t * const len);


#endif /* _XDR_INTERNAL_H*/
span> self.new_tcattr = termios.tcgetattr(self.fd) atexit.register(self.termios_teardown) self.new_tcattr[3] &= ~(termios.ICANON | termios.ECHO) # | termios.ISIG self.new_tcattr[6][termios.VMIN] = 1 self.new_tcattr[6][termios.VTIME] = 0 termios.tcsetattr(self.fd, termios.TCSANOW, self.new_tcattr) def termios_teardown(self): if self.fd is not None: termios.tcsetattr(self.fd, termios.TCSAFLUSH, self.old_tcattr) self.fd = None @tornado.gen.coroutine def copy_loop(self, stream1, stream2, text1, text2, buffer_size = 1024): try: while not self.closed: buffer = yield stream1.read_bytes(buffer_size, partial = True) yield stream2.write(buffer.replace(text1, text2)) except tornado.iostream.StreamClosedError: self.close() def stdin_loop(self): return self.copy_loop(self.stdin_stream, self.socket_stream, "\n", "\r") def stdout_loop(self): return self.copy_loop(self.socket_stream, self.stdout_stream, "\r\n", "\n") def main(): parser = argparse.ArgumentParser(formatter_class = argparse.ArgumentDefaultsHelpFormatter) parser.add_argument("cty_socket", nargs = "?", help = "CTY PF_UNIX socket name", default = os.getenv("CRYPTECH_CTY_CLIENT_SOCKET_NAME", "/tmp/.cryptech_muxd.cty")) args = parser.parse_args() s = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM) try: s.connect(args.cty_socket) except socket.error: sys.exit("Couldn't connect to socket {}".format(args.cty_socket)) tornado.ioloop.IOLoop.current().run_sync(FemtoTerm(s).run) if __name__ == "__main__": try: main() except KeyboardInterrupt: pass