#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <stdarg.h>
#include <uri.h>
#include <papi_impl.h>
papi_status_t
service_fill_in(service_t *svc, char *name)
{
papi_status_t status = PAPI_OK;
uri_t *uri = NULL;
if (svc == NULL)
return (PAPI_BAD_ARGUMENT);
if (name == NULL)
return (PAPI_OK);
if (uri_from_string((char *)name, &uri) != -1) {
if ((strcasecmp(uri->scheme, "lpd") == 0) ||
(strcasecmp(uri->scheme, "rfc-1179") == 0)) {
if (svc->uri != NULL)
uri_free(svc->uri);
svc->uri = uri;
} else {
uri_free(uri);
status = PAPI_URI_SCHEME;
}
}
return (status);
}
papi_status_t
papiServiceCreate(papi_service_t *handle, char *service_name,
char *user_name, char *password,
int (*authCB)(papi_service_t svc, void *app_data),
papi_encryption_t encryption, void *app_data)
{
papi_status_t status;
service_t *svc = NULL;
if (handle == NULL)
return (PAPI_BAD_ARGUMENT);
if ((*handle = svc = (service_t *)calloc(1, sizeof (*svc))) == NULL)
return (PAPI_TEMPORARY_ERROR);
if (service_name != NULL)
papiAttributeListAddString(&svc->attributes, PAPI_ATTR_EXCL,
"service-name", service_name);
(void) papiServiceSetUserName(svc, user_name);
(void) papiServiceSetPassword(svc, password);
(void) papiServiceSetAuthCB(svc, authCB);
(void) papiServiceSetAppData(svc, app_data);
(void) papiServiceSetEncryption(svc, encryption);
status = service_fill_in(svc, service_name);
return (status);
}
void
papiServiceDestroy(papi_service_t handle)
{
if (handle != NULL) {
service_t *svc = handle;
#ifdef DEADBEEF
if (svc->cache != NULL)
cache_free(svc->cache);
#endif
if (svc->uri != NULL)
uri_free(svc->uri);
if (svc->attributes != NULL)
papiAttributeListFree(svc->attributes);
free(svc);
}
}
papi_status_t
papiServiceSetUserName(papi_service_t handle, char *user_name)
{
service_t *svc = handle;
if (svc == NULL)
return (PAPI_BAD_ARGUMENT);
return (papiAttributeListAddString(&svc->attributes, PAPI_ATTR_REPLACE,
"user-name", user_name));
}
papi_status_t
papiServiceSetPassword(papi_service_t handle, char *password)
{
service_t *svc = handle;
if (svc == NULL)
return (PAPI_BAD_ARGUMENT);
return (papiAttributeListAddString(&svc->attributes,
PAPI_ATTR_REPLACE, "password", password));
}
papi_status_t
papiServiceSetEncryption(papi_service_t handle,
papi_encryption_t encryption)
{
service_t *svc = handle;
if (svc == NULL)
return (PAPI_BAD_ARGUMENT);
return (papiAttributeListAddInteger(&svc->attributes, PAPI_ATTR_REPLACE,
"encryption", (int)encryption));
}
papi_status_t
papiServiceSetAuthCB(papi_service_t handle,
int (*authCB)(papi_service_t svc, void *app_data))
{
service_t *svc = handle;
if (svc == NULL)
return (PAPI_BAD_ARGUMENT);
svc->authCB = (int (*)(papi_service_t svc, void *))authCB;
return (PAPI_OK);
}
papi_status_t
papiServiceSetAppData(papi_service_t handle, void *app_data)
{
service_t *svc = handle;
if (svc == NULL)
return (PAPI_BAD_ARGUMENT);
svc->app_data = (void *)app_data;
return (PAPI_OK);
}
char *
papiServiceGetServiceName(papi_service_t handle)
{
service_t *svc = handle;
char *result = NULL;
if (svc != NULL)
papiAttributeListGetString(svc->attributes, NULL,
"service-name", &result);
return (result);
}
char *
papiServiceGetUserName(papi_service_t handle)
{
service_t *svc = handle;
char *result = NULL;
if (svc != NULL)
papiAttributeListGetString(svc->attributes, NULL,
"user-name", &result);
return (result);
}
char *
papiServiceGetPassword(papi_service_t handle)
{
service_t *svc = handle;
char *result = NULL;
if (svc != NULL)
papiAttributeListGetString(svc->attributes, NULL,
"password", &result);
return (result);
}
papi_encryption_t
papiServiceGetEncryption(papi_service_t handle)
{
service_t *svc = handle;
papi_encryption_t result = PAPI_ENCRYPT_NEVER;
if (svc != NULL)
papiAttributeListGetInteger(svc->attributes, NULL,
"encryption", (int *)&result);
return (result);
}
void *
papiServiceGetAppData(papi_service_t handle)
{
service_t *svc = handle;
void *result = NULL;
if (svc != NULL) {
result = svc->app_data;
}
return (result);
}
papi_attribute_t **
papiServiceGetAttributeList(papi_service_t handle)
{
service_t *svc = handle;
papi_attribute_t **result = NULL;
if (svc != NULL)
result = svc->attributes;
return (result);
}
char *
papiServiceGetStatusMessage(papi_service_t handle)
{
service_t *svc = handle;
char *result = NULL;
if (svc != NULL) {
papiAttributeListGetString(svc->attributes, NULL,
"detailed-status-message", &result);
}
return (result);
}
void
detailed_error(service_t *svc, char *fmt, ...)
{
if ((svc != NULL) && (fmt != NULL)) {
va_list ap;
char *message;
int rv;
va_start(ap, fmt);
rv = vasprintf(&message, fmt, ap);
va_end(ap);
if (rv >= 0) {
papiAttributeListAddString(&svc->attributes,
PAPI_ATTR_APPEND, "detailed-status-message",
message);
free(message);
}
}
}