| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 | '\" t.\"     Title: ne_set_server_auth.\"    Author: .\" Generator: DocBook XSL Stylesheets vsnapshot <http://docbook.sf.net/>.\"      Date: 11 September 2022.\"    Manual: neon API reference.\"    Source: neon 0.32.4.\"  Language: English.\".TH "NE_SET_SERVER_AUTH" "3" "11 September 2022" "neon 0.32.4" "neon API reference".\" -----------------------------------------------------------------.\" * Define some portability stuff.\" -----------------------------------------------------------------.\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~.\" http://bugs.debian.org/507673.\" http://lists.gnu.org/archive/html/groff/2009-02/msg00013.html.\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~.ie \n(.g .ds Aq \(aq.el       .ds Aq '.\" -----------------------------------------------------------------.\" * set default formatting.\" -----------------------------------------------------------------.\" disable hyphenation.nh.\" disable justification (adjust text to left margin only).ad l.\" -----------------------------------------------------------------.\" * MAIN CONTENT STARTS HERE *.\" -----------------------------------------------------------------.SH "NAME"ne_set_server_auth, ne_set_proxy_auth, ne_forget_auth \- register authentication callbacks.SH "SYNOPSIS".sp.ft B.nf#include <ne_auth\&.h>.fi.ft.HP \w'typedef\ int\ (*ne_auth_creds)('u.BI "typedef int (*ne_auth_creds)(void\ *" "userdata" ", const\ char\ *" "realm" ", int\ " "attempt" ", char\ *" "username" ", char\ *" "password" ");".HP \w'void\ ne_set_server_auth('u.BI "void ne_set_server_auth(ne_session\ *" "session" ", ne_auth_creds\ " "callback" ", void\ *" "userdata" ");".HP \w'void\ ne_set_proxy_auth('u.BI "void ne_set_proxy_auth(ne_session\ *" "session" ", ne_auth_creds\ " "callback" ", void\ *" "userdata" ");".HP \w'void\ ne_forget_auth('u.BI "void ne_forget_auth(ne_session\ *" "session" ");".SH "DESCRIPTION".PPThe\fBne_auth_creds\fRfunction type defines a callback which is invoked when a server or proxy server requires user authentication for a particular request\&. The\fIrealm\fRstring is supplied by the server\&.The\fIattempt\fRis a counter giving the number of times the request has been retried with different authentication credentials\&. The first time the callback is invoked for a particular request,\fIattempt\fRwill be zero\&..PPTo retry the request using new authentication credentials, the callback should return zero, and the\fIusername\fRand\fIpassword\fRbuffers must containNUL\-terminated strings\&. TheNE_ABUFSIZconstant gives the size of these buffers\&..if n \{\.sp.\}.RS 4.it 1 an-trap.nr an-no-space-flag 1.nr an-break-flag 1.br.ps +1\fBTip\fR.ps -1.br.PPIf you only wish to allow the user one attempt to enter credentials, use the value of the\fIattempt\fRparameter as the return value of the callback\&..sp .5v.RE.PPTo abort the request, the callback should return a non\-zero value; in which case the contents of the\fIusername\fRand\fIpassword\fRbuffers are ignored\&..PPThe\fBne_forget_auth\fRfunction can be used to discard the cached authentication credentials\&..SH "EXAMPLES".sp.if n \{\.RS 4.\}.nf/* Function which prompts for a line of user input: */extern char *prompt_for(const char *prompt);static intmy_auth(void *userdata, const char *realm, int attempts,        char *username, char *password){   strncpy(username, prompt_for("Username: "), NE_ABUFSIZ);   strncpy(password, prompt_for("Password: "), NE_ABUFSIZ);   return attempts;}int main(\&.\&.\&.){   ne_session *sess = ne_session_create(\&.\&.\&.);   ne_set_server_auth(sess, my_auth, NULL);   /* \&.\&.\&. */}.fi.if n \{\.RE.\}.SH "AUTHOR".PP\fBJoe Orton\fR <\&[email protected]\&>.RS 4Author..RE.SH "COPYRIGHT".br
 |