
#use wml::openssl-macros area=docs page=SSL_set_connect_state

<title>Documents, SSL_set_connect_state(3)</title>

<h1>SSL_set_connect_state(3)</h1>

#use wml::imp::generic

{:
## What's this? [[s|(<STRONG>[^<].+?)</A>(</STRONG><DD>)|$1$2|sg]]
[[s|<P>\s+<P>|<P>|sg]]
[[s|<P>\s+</|</|sg]]
[[s|<DD>\s*<DT>|<DD>&nbsp;<DT>|sg]]
[[s|<DD>\s*</DL>|<DD>&nbsp;</DL>|sg]]
[[s|\[|&#91;|sg]]
[[s|\]|&#93;|sg]]

<!-- INDEX BEGIN -->

<UL>

	<LI><A HREF="#NAME">NAME</A>
	<LI><A HREF="#SYNOPSIS">SYNOPSIS</A>
	<LI><A HREF="#DESCRIPTION">DESCRIPTION</A>
	<LI><A HREF="#NOTES">NOTES</A>
	<LI><A HREF="#RETURN_VALUES">RETURN VALUES</A>
	<LI><A HREF="#SEE_ALSO">SEE ALSO</A>
</UL>
<!-- INDEX END -->

<HR>
<P>
<HR>
<H1><A NAME="NAME">NAME</A></H1>
<P>
SSL_set_connect_state, SSL_get_accept_state - prepare SSL object to work in
client or server mode

</P>
<P>
<HR>
<H1><A NAME="SYNOPSIS">SYNOPSIS</A></H1>
<PRE> #include &lt;openssl/ssl.h&gt;
</PRE>
<PRE> void SSL_set_connect_state(SSL *ssl);
</PRE>
<PRE> void SSL_set_accept_state(SSL *ssl);
</PRE>
<P>
<HR>
<H1><A NAME="DESCRIPTION">DESCRIPTION</A></H1>
<P>
<CODE>SSL_set_connect_state()</CODE> sets <STRONG>ssl</STRONG> to work in client mode.

</P>
<P>
<CODE>SSL_set_accept_state()</CODE> sets <STRONG>ssl</STRONG> to work in server mode.

</P>
<P>
<HR>
<H1><A NAME="NOTES">NOTES</A></H1>
<P>
When the SSL_CTX object was created with <A HREF="../ssl/SSL_CTX_new.html#">SSL_CTX_new(3)</A>, it was either assigned a dedicated client method, a dedicated server
method, or a generic method, that can be used for both client and server
connections. (The method might have been changed with
<A HREF="../ssl/SSL_CTX_set_ssl_version.html#">SSL_CTX_set_ssl_version(3)</A> or <CODE>SSL_set_ssl_method().)</CODE>

</P>
<P>
When beginning a new handshake, the SSL engine must know whether it must
call the connect (client) or accept (server) routines. Even though it may
be clear from the method chosen, whether client or server mode was
requested, the handshake routines must be explicitly set.

</P>
<P>
When using the <A HREF="../ssl/SSL_connect.html#">SSL_connect(3)</A> or
<A HREF="../ssl/SSL_accept.html#">SSL_accept(3)</A> routines, the correct handshake routines are automatically set. When
performing a transparent negotiation using <A HREF="../ssl/SSL_write.html#">SSL_write(3)</A> or <A HREF="../ssl/SSL_read.html#">SSL_read(3)</A>, the handshake routines must be explicitly set in advance using either
<CODE>SSL_set_connect_state()</CODE> or
<CODE>SSL_set_accept_state().</CODE>

</P>
<P>
<HR>
<H1><A NAME="RETURN_VALUES">RETURN VALUES</A></H1>
<P>
<CODE>SSL_set_connect_state()</CODE> and
<CODE>SSL_set_accept_state()</CODE> do not return diagnostic information.

</P>
<P>
<HR>
<H1><A NAME="SEE_ALSO">SEE ALSO</A></H1>
<P>
<A HREF="../ssl/ssl.html#">ssl(3)</A>, <A HREF="../ssl/SSL_new.html#">SSL_new(3)</A>, <A HREF="../ssl/SSL_CTX_new.html#">SSL_CTX_new(3)</A>,
<A HREF="../ssl/SSL_connect.html#">SSL_connect(3)</A>, <A HREF="../ssl/SSL_accept.html#">SSL_accept(3)</A>,
<A HREF="../ssl/SSL_write.html#">SSL_write(3)</A>, <A HREF="../ssl/SSL_read.html#">SSL_read(3)</A>,
<A HREF="../ssl/SSL_do_handshake.html#">SSL_do_handshake(3)</A>,
<A HREF="../ssl/SSL_CTX_set_ssl_version.html#">SSL_CTX_set_ssl_version(3)</A>



</P>
:}


