1 ! Copyright (C) 2007, 2011, Slava Pestov, Elie CHAFTARI.
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: accessors destructors io.backend.unix io.files
4 io.sockets.private io.sockets.secure io.sockets.secure.openssl
5 io.timeouts kernel openssl openssl.libssl system ;
6 FROM: io.ports => shutdown ;
7 IN: io.sockets.secure.unix
9 M: openssl ssl-supported? t ;
10 M: openssl ssl-certificate-verification-supported? t ;
12 M: ssl-handle handle-fd file>> handle-fd ;
14 M: unix socket-handle fd>> ;
16 M: secure remote>handle
17 [ addrspec>> remote>handle ] [ hostname>> ] bi <ssl-socket> ;
19 M: secure parse-sockaddr addrspec>> parse-sockaddr f <secure> ;
21 M: secure (get-local-address) addrspec>> (get-local-address) ;
23 M: secure establish-connection
24 addrspec>> [ establish-connection ] [ secure-connection ] 2bi ;
28 addrspec>> (accept) [ |dispose f <ssl-socket> ] dip
31 : (shutdown) ( ssl-handle -- )
32 dup dup handle>> SSL_shutdown check-ssl-error
33 [ dupd wait-for-fd (shutdown) ] [ drop ] if* ;
35 M: ssl-handle shutdown
37 f >>connected [ (shutdown) ] with-timeout
40 M: unix non-ssl-socket? fd? ;