/***************************************************************************** * _ _ ____ _ * Project ___| | | | _ \| | * / __| | | | |_) | | * | (__| |_| | _ <| |___ * \___|\___/|_| \_\_____| * * The contents of this file are subject to the Mozilla Public License * Version 1.0 (the "License"); you may not use this file except in * compliance with the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the * License for the specific language governing rights and limitations * under the License. * * The Original Code is Curl. * * The Initial Developer of the Original Code is Daniel Stenberg. * * Portions created by the Initial Developer are Copyright (C) 1998. * All Rights Reserved. * * ------------------------------------------------------------ * Main author: * - Daniel Stenberg * * http://curl.haxx.se * * $Source$ * $Revision$ * $Date$ * $Author$ * $State$ * $Locker$ * * ------------------------------------------------------------ ****************************************************************************/ #include "setup.h" #include #include #include #ifdef HAVE_UNISTD_H #include #endif #if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__) #include #endif #include #include "urldata.h" #include #ifdef KRB4 #include "security.h" #include #endif /* infof() is for info message along the way */ void infof(struct UrlData *data, char *fmt, ...) { va_list ap; if(data->bits.verbose) { va_start(ap, fmt); fputs("* ", data->err); vfprintf(data->err, fmt, ap); va_end(ap); } } /* failf() is for messages stating why we failed, the LAST one will be returned for the user (if requested) */ void failf(struct UrlData *data, char *fmt, ...) { va_list ap; va_start(ap, fmt); if(data->errorbuffer) vsprintf(data->errorbuffer, fmt, ap); else /* no errorbuffer receives this, write to data->err instead */ vfprintf(data->err, fmt, ap); va_end(ap); } /* sendf() sends the formated data to the server */ int sendf(int fd, struct UrlData *data, char *fmt, ...) { size_t bytes_written; char *s; va_list ap; va_start(ap, fmt); s = mvaprintf(fmt, ap); va_end(ap); if(!s) return 0; /* failure */ if(data->bits.verbose) fprintf(data->err, "> %s", s); #ifndef USE_SSLEAY bytes_written = swrite(fd, s, strlen(s)); #else /* USE_SSLEAY */ if (data->use_ssl) { bytes_written = SSL_write(data->ssl, s, strlen(s)); } else { bytes_written = swrite(fd, s, strlen(s)); } #endif /* USE_SSLEAY */ free(s); /* free the output string */ return(bytes_written); } /* * ftpsendf() sends the formated string as a ftp command to a ftp server */ int ftpsendf(int fd, struct connectdata *conn, char *fmt, ...) { size_t bytes_written; char *s; va_list ap; va_start(ap, fmt); s = mvaprintf(fmt, ap); va_end(ap); if(!s) return 0; /* failure */ if(conn->data->bits.verbose) fprintf(conn->data->err, "> %s\n", s); #ifdef KRB4 if(conn->sec_complete && conn->data->cmdchannel) { bytes_written = sec_fprintf(conn, conn->data->cmdchannel, s); bytes_written += fprintf(conn->data->cmdchannel, "\r\n"); fflush(conn->data->cmdchannel); } else #endif /* KRB4 */ { bytes_written = swrite(fd, s, strlen(s)); bytes_written += swrite(fd, "\r\n", 2); } free(s); /* free the output string */ return(bytes_written); } /* ssend() sends plain (binary) data to the server */ size_t ssend(int fd, struct connectdata *conn, void *mem, size_t len) { size_t bytes_written; struct UrlData *data=conn->data; /* conn knows data, not vice versa */ if(data->bits.verbose) fprintf(data->err, "> [binary output]\n"); #ifdef USE_SSLEAY if (data->use_ssl) { bytes_written = SSL_write(data->ssl, mem, len); } else { #endif #ifdef KRB4 if(conn->sec_complete) { bytes_written = sec_write(conn, fd, mem, len); } else #endif /* KRB4 */ bytes_written = swrite(fd, mem, len); #ifdef USE_SSLEAY } #endif return bytes_written; }