clnt_perror.c revision 1.9
11.9Smrg/* $NetBSD: clnt_perror.c,v 1.9 1997/01/23 14:02:15 mrg Exp $ */ 21.5Scgd 31.1Scgd/* 41.1Scgd * Sun RPC is a product of Sun Microsystems, Inc. and is provided for 51.1Scgd * unrestricted use provided that this legend is included on all tape 61.1Scgd * media and as a part of the software program in whole or part. Users 71.1Scgd * may copy or modify Sun RPC without charge, but are not authorized 81.1Scgd * to license or distribute it to anyone else except as part of a product or 91.1Scgd * program developed by the user. 101.1Scgd * 111.1Scgd * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE 121.1Scgd * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR 131.1Scgd * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE. 141.1Scgd * 151.1Scgd * Sun RPC is provided with no support and without any obligation on the 161.1Scgd * part of Sun Microsystems, Inc. to assist in its use, correction, 171.1Scgd * modification or enhancement. 181.1Scgd * 191.1Scgd * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE 201.1Scgd * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC 211.1Scgd * OR ANY PART THEREOF. 221.1Scgd * 231.1Scgd * In no event will Sun Microsystems, Inc. be liable for any lost revenue 241.1Scgd * or profits or other special, indirect and consequential damages, even if 251.1Scgd * Sun has been advised of the possibility of such damages. 261.1Scgd * 271.1Scgd * Sun Microsystems, Inc. 281.1Scgd * 2550 Garcia Avenue 291.1Scgd * Mountain View, California 94043 301.1Scgd */ 311.1Scgd 321.1Scgd#if defined(LIBC_SCCS) && !defined(lint) 331.1Scgd/*static char *sccsid = "from: @(#)clnt_perror.c 1.15 87/10/07 Copyr 1984 Sun Micro";*/ 341.1Scgd/*static char *sccsid = "from: @(#)clnt_perror.c 2.1 88/07/29 4.0 RPCSRC";*/ 351.9Smrgstatic char *rcsid = "$NetBSD: clnt_perror.c,v 1.9 1997/01/23 14:02:15 mrg Exp $"; 361.1Scgd#endif 371.1Scgd 381.1Scgd/* 391.1Scgd * clnt_perror.c 401.1Scgd * 411.1Scgd * Copyright (C) 1984, Sun Microsystems, Inc. 421.1Scgd * 431.1Scgd */ 441.1Scgd#include <stdio.h> 451.3Scgd#include <stdlib.h> 461.1Scgd#include <string.h> 471.1Scgd#include <rpc/rpc.h> 481.1Scgd#include <rpc/types.h> 491.1Scgd#include <rpc/auth.h> 501.1Scgd#include <rpc/clnt.h> 511.1Scgd 521.1Scgdstatic char *auth_errmsg(); 531.1Scgd 541.1Scgdstatic char *buf; 551.9Smrgstatic int buflen; 561.1Scgd 571.1Scgdstatic char * 581.1Scgd_buf() 591.1Scgd{ 601.1Scgd 611.1Scgd if (buf == 0) 621.1Scgd buf = (char *)malloc(256); 631.9Smrg buflen = 256; 641.1Scgd return (buf); 651.1Scgd} 661.1Scgd 671.1Scgd/* 681.1Scgd * Print reply error info 691.1Scgd */ 701.1Scgdchar * 711.1Scgdclnt_sperror(rpch, s) 721.1Scgd CLIENT *rpch; 731.1Scgd char *s; 741.1Scgd{ 751.1Scgd struct rpc_err e; 761.1Scgd void clnt_perrno(); 771.1Scgd char *err; 781.1Scgd char *str = _buf(); 791.1Scgd char *strstart = str; 801.9Smrg int len = buflen, i; 811.1Scgd 821.1Scgd if (str == 0) 831.1Scgd return (0); 841.1Scgd CLNT_GETERR(rpch, &e); 851.1Scgd 861.9Smrg i = snprintf(str, len, "%s: ", s); 871.9Smrg str += i; 881.9Smrg len -= i; 891.9Smrg 901.9Smrg (void)strncpy(str, clnt_sperrno(e.re_status), len - 1); 911.9Smrg i = strlen(str); 921.9Smrg str += i; 931.9Smrg len -= i; 941.1Scgd 951.1Scgd switch (e.re_status) { 961.1Scgd case RPC_SUCCESS: 971.1Scgd case RPC_CANTENCODEARGS: 981.1Scgd case RPC_CANTDECODERES: 991.1Scgd case RPC_TIMEDOUT: 1001.1Scgd case RPC_PROGUNAVAIL: 1011.1Scgd case RPC_PROCUNAVAIL: 1021.1Scgd case RPC_CANTDECODEARGS: 1031.1Scgd case RPC_SYSTEMERROR: 1041.1Scgd case RPC_UNKNOWNHOST: 1051.1Scgd case RPC_UNKNOWNPROTO: 1061.1Scgd case RPC_PMAPFAILURE: 1071.1Scgd case RPC_PROGNOTREGISTERED: 1081.1Scgd case RPC_FAILED: 1091.1Scgd break; 1101.1Scgd 1111.1Scgd case RPC_CANTSEND: 1121.1Scgd case RPC_CANTRECV: 1131.9Smrg i = snprintf(str, len, "; errno = %s", 1141.1Scgd strerror(e.re_errno)); 1151.9Smrg str += i; 1161.9Smrg len -= i; 1171.1Scgd break; 1181.1Scgd 1191.1Scgd case RPC_VERSMISMATCH: 1201.9Smrg i = snprintf(str, len, 1211.1Scgd "; low version = %lu, high version = %lu", 1221.1Scgd e.re_vers.low, e.re_vers.high); 1231.9Smrg str += i; 1241.9Smrg len -= i; 1251.1Scgd break; 1261.1Scgd 1271.1Scgd case RPC_AUTHERROR: 1281.1Scgd err = auth_errmsg(e.re_why); 1291.9Smrg i = snprintf(str, len, "; why = "); 1301.9Smrg str += i; 1311.9Smrg len -= i; 1321.1Scgd if (err != NULL) { 1331.9Smrg i = snprintf(str, len, "%s",err); 1341.1Scgd } else { 1351.9Smrg i = snprintf(str, len, 1361.1Scgd "(unknown authentication error - %d)", 1371.1Scgd (int) e.re_why); 1381.1Scgd } 1391.9Smrg str += i; 1401.9Smrg len -= i; 1411.1Scgd break; 1421.1Scgd 1431.1Scgd case RPC_PROGVERSMISMATCH: 1441.9Smrg i = snprintf(str, len, 1451.1Scgd "; low version = %lu, high version = %lu", 1461.1Scgd e.re_vers.low, e.re_vers.high); 1471.9Smrg str += i; 1481.9Smrg len -= i; 1491.1Scgd break; 1501.1Scgd 1511.1Scgd default: /* unknown */ 1521.9Smrg i = snprintf(str, len, 1531.1Scgd "; s1 = %lu, s2 = %lu", 1541.1Scgd e.re_lb.s1, e.re_lb.s2); 1551.9Smrg str += i; 1561.9Smrg len -= i; 1571.1Scgd break; 1581.1Scgd } 1591.1Scgd return(strstart) ; 1601.1Scgd} 1611.1Scgd 1621.1Scgdvoid 1631.1Scgdclnt_perror(rpch, s) 1641.1Scgd CLIENT *rpch; 1651.1Scgd char *s; 1661.1Scgd{ 1671.4Sjtc (void) fprintf(stderr,"%s\n",clnt_sperror(rpch,s)); 1681.1Scgd} 1691.1Scgd 1701.6Sjtcstatic const char *const rpc_errlist[] = { 1711.6Sjtc "RPC: Success", /* 0 - RPC_SUCCESS */ 1721.6Sjtc "RPC: Can't encode arguments", /* 1 - RPC_CANTENCODEARGS */ 1731.6Sjtc "RPC: Can't decode result", /* 2 - RPC_CANTDECODERES */ 1741.6Sjtc "RPC: Unable to send", /* 3 - RPC_CANTSEND */ 1751.6Sjtc "RPC: Unable to receive", /* 4 - RPC_CANTRECV */ 1761.6Sjtc "RPC: Timed out", /* 5 - RPC_TIMEDOUT */ 1771.6Sjtc "RPC: Incompatible versions of RPC", /* 6 - RPC_VERSMISMATCH */ 1781.6Sjtc "RPC: Authentication error", /* 7 - RPC_AUTHERROR */ 1791.6Sjtc "RPC: Program unavailable", /* 8 - RPC_PROGUNAVAIL */ 1801.6Sjtc "RPC: Program/version mismatch", /* 9 - RPC_PROGVERSMISMATCH */ 1811.6Sjtc "RPC: Procedure unavailable", /* 10 - RPC_PROCUNAVAIL */ 1821.6Sjtc "RPC: Server can't decode arguments", /* 11 - RPC_CANTDECODEARGS */ 1831.6Sjtc "RPC: Remote system error", /* 12 - RPC_SYSTEMERROR */ 1841.6Sjtc "RPC: Unknown host", /* 13 - RPC_UNKNOWNHOST */ 1851.6Sjtc "RPC: Port mapper failure", /* 14 - RPC_PMAPFAILURE */ 1861.6Sjtc "RPC: Program not registered", /* 15 - RPC_PROGNOTREGISTERED */ 1871.6Sjtc "RPC: Failed (unspecified error)", /* 16 - RPC_FAILED */ 1881.6Sjtc "RPC: Unknown protocol" /* 17 - RPC_UNKNOWNPROTO */ 1891.1Scgd}; 1901.1Scgd 1911.1Scgd 1921.1Scgd/* 1931.1Scgd * This interface for use by clntrpc 1941.1Scgd */ 1951.1Scgdchar * 1961.1Scgdclnt_sperrno(stat) 1971.1Scgd enum clnt_stat stat; 1981.1Scgd{ 1991.1Scgd int i; 2001.1Scgd 2011.6Sjtc unsigned int errnum = stat; 2021.6Sjtc 2031.6Sjtc if (errnum < (sizeof(rpc_errlist)/sizeof(rpc_errlist[0]))) 2041.7Scgd return (char *)rpc_errlist[errnum]; 2051.6Sjtc 2061.1Scgd return ("RPC: (unknown error code)"); 2071.1Scgd} 2081.1Scgd 2091.1Scgdvoid 2101.1Scgdclnt_perrno(num) 2111.1Scgd enum clnt_stat num; 2121.1Scgd{ 2131.4Sjtc (void) fprintf(stderr,"%s\n",clnt_sperrno(num)); 2141.1Scgd} 2151.1Scgd 2161.1Scgd 2171.1Scgdchar * 2181.1Scgdclnt_spcreateerror(s) 2191.1Scgd char *s; 2201.1Scgd{ 2211.1Scgd char *str = _buf(); 2221.9Smrg int len = buflen, i; 2231.1Scgd 2241.1Scgd if (str == 0) 2251.1Scgd return(0); 2261.9Smrg i = snprintf(str, len, "%s: ", s); 2271.9Smrg len -= i; 2281.9Smrg (void)strncat(str, clnt_sperrno(rpc_createerr.cf_stat), len - 1); 2291.1Scgd switch (rpc_createerr.cf_stat) { 2301.1Scgd case RPC_PMAPFAILURE: 2311.9Smrg (void) strncat(str, " - ", len - 1); 2321.9Smrg (void) strncat(str, 2331.9Smrg clnt_sperrno(rpc_createerr.cf_error.re_status), len - 4); 2341.1Scgd break; 2351.1Scgd 2361.1Scgd case RPC_SYSTEMERROR: 2371.9Smrg (void)strncat(str, " - ", len - 1); 2381.9Smrg (void)strncat(str, strerror(rpc_createerr.cf_error.re_errno), 2391.9Smrg len - 4); 2401.1Scgd break; 2411.1Scgd } 2421.1Scgd return (str); 2431.1Scgd} 2441.1Scgd 2451.1Scgdvoid 2461.1Scgdclnt_pcreateerror(s) 2471.1Scgd char *s; 2481.1Scgd{ 2491.4Sjtc (void) fprintf(stderr,"%s\n",clnt_spcreateerror(s)); 2501.1Scgd} 2511.1Scgd 2521.6Sjtcstatic const char *const auth_errlist[] = { 2531.6Sjtc "Authentication OK", /* 0 - AUTH_OK */ 2541.6Sjtc "Invalid client credential", /* 1 - AUTH_BADCRED */ 2551.6Sjtc "Server rejected credential", /* 2 - AUTH_REJECTEDCRED */ 2561.6Sjtc "Invalid client verifier", /* 3 - AUTH_BADVERF */ 2571.6Sjtc "Server rejected verifier", /* 4 - AUTH_REJECTEDVERF */ 2581.6Sjtc "Client credential too weak", /* 5 - AUTH_TOOWEAK */ 2591.6Sjtc "Invalid server verifier", /* 6 - AUTH_INVALIDRESP */ 2601.6Sjtc "Failed (unspecified error)" /* 7 - AUTH_FAILED */ 2611.1Scgd}; 2621.1Scgd 2631.1Scgdstatic char * 2641.1Scgdauth_errmsg(stat) 2651.1Scgd enum auth_stat stat; 2661.1Scgd{ 2671.6Sjtc unsigned int errnum = stat; 2681.6Sjtc 2691.6Sjtc if (errnum < (sizeof(auth_errlist)/sizeof(auth_errlist[0]))) 2701.7Scgd return (char *)auth_errlist[errnum]; 2711.1Scgd 2721.1Scgd return(NULL); 2731.1Scgd} 274