summaryrefslogtreecommitdiff
path: root/usr/src/lib/print/libpapi-dynamic/common/service.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr/src/lib/print/libpapi-dynamic/common/service.c')
-rw-r--r--usr/src/lib/print/libpapi-dynamic/common/service.c572
1 files changed, 0 insertions, 572 deletions
diff --git a/usr/src/lib/print/libpapi-dynamic/common/service.c b/usr/src/lib/print/libpapi-dynamic/common/service.c
deleted file mode 100644
index 55f1732a65..0000000000
--- a/usr/src/lib/print/libpapi-dynamic/common/service.c
+++ /dev/null
@@ -1,572 +0,0 @@
-/*
- * CDDL HEADER START
- *
- * The contents of this file are subject to the terms of the
- * Common Development and Distribution License (the "License").
- * You may not use this file except in compliance with the License.
- *
- * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
- * or http://www.opensolaris.org/os/licensing.
- * See the License for the specific language governing permissions
- * and limitations under the License.
- *
- * When distributing Covered Code, include this CDDL HEADER in each
- * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
- * If applicable, add the following below this CDDL HEADER, with the
- * fields enclosed by brackets "[]" replaced with your own identifying
- * information: Portions Copyright [yyyy] [name of copyright owner]
- *
- * CDDL HEADER END
- */
-
-/*
- * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
- * Use is subject to license terms.
- *
- */
-
-/* $Id: service.c 172 2006-05-24 20:54:00Z njacobs $ */
-
-#pragma ident "%Z%%M% %I% %E% SMI"
-
-/*LINTLIBRARY*/
-
-#include <stdlib.h>
-#include <stdio.h>
-#include <stdarg.h>
-#include <sys/types.h>
-#include <unistd.h>
-#include <string.h>
-#include <alloca.h>
-#include <libintl.h>
-#include <papi_impl.h>
-#include <config-site.h>
-
-static int
-interposed_auth_callback(papi_service_t handle, void *app_data)
-{
- int result = -1;
- service_t *svc = app_data;
-
- if (svc != NULL)
- result = svc->authCB(svc, svc->app_data);
-
- return (result);
-}
-
-static char *
-default_service_uri(char *fallback)
-{
- char *result = NULL;
-
- if (getuid() == geteuid())
- result = getenv("PAPI_SERVICE_URI");
-
- if (result == NULL) {
- char *cups;
-
- if ((cups = getenv("CUPS_SERVER")) != NULL) {
- char buf[BUFSIZ];
-
- snprintf(buf, sizeof (buf), "ipp://%s/printers/", cups);
- result = strdup(buf);
- }
- }
-
- if (result == NULL)
- result = fallback;
-
- return (result);
-}
-
-static char *
-default_print_service()
-{
- static char *result = NULL;
-
- if (result == NULL) {
- char *service_uri = default_service_uri(DEFAULT_SERVICE_URI);
- uri_t *uri = NULL;
-
- if (uri_from_string(service_uri, &uri) != -1)
- result = strdup(uri->scheme);
-
- if (uri != NULL)
- uri_free(uri);
- }
-
- return (result);
-}
-
-static papi_status_t
-service_load(service_t *svc, char *name)
-{
- papi_status_t result;
- char *scheme = default_print_service();
-
- if (svc->so_handle != NULL) /* already loaded */
- return (PAPI_OK);
-
- if (name == NULL) /* no info, can't load yet */
- return (PAPI_OK);
-
- /* Lookup the printer in the configuration DB */
- svc->attributes = getprinterbyname((char *)name, NULL);
-
- if (svc->attributes != NULL) {
- char *tmp = NULL;
-
- /* Printer found (or was a URI), use the attribute data */
- papiAttributeListGetString(svc->attributes, NULL,
- "printer-uri-supported", &tmp);
- if (tmp != NULL)
- svc->name = strdup(tmp);
-
- /* parse the URI and set the scheme(print service) */
- if (uri_from_string(svc->name, &svc->uri) != -1)
- scheme = (svc->uri)->scheme;
-
- /* override the scheme if it was in the attributes */
- papiAttributeListGetString(svc->attributes, NULL,
- "print-service-module", &scheme);
-
- } else /* not found, assume it is the actual print service name */
- scheme = name;
-
- result = psm_open(svc, scheme);
- switch (result) {
- case PAPI_OK:
- break; /* no error */
- case PAPI_URI_SCHEME:
- result = PAPI_NOT_FOUND;
-#ifdef DEBUG
- detailed_error(svc, "Unable to load service for: %s", name);
-#endif
- break;
- default: /* set the detailed message */
- detailed_error(svc, "Unable to load service (%s) for: %s",
- scheme, name);
- }
-
- return (result);
-}
-
-static papi_status_t
-service_send_peer(service_t *svc)
-{
- papi_status_t result = PAPI_OK;
-
- if ((svc->peer_fd != -1) && (svc->so_handle != NULL) &&
- (svc->svc_handle != NULL)) {
- papi_status_t (*f)();
-
- f = (papi_status_t (*)())psm_sym(svc, "papiServiceSetPeer");
-
- if (f != NULL)
- result = f(svc->svc_handle, svc->peer_fd);
- }
-
- return (result);
-}
-
-papi_status_t
-service_connect(service_t *svc, char *name)
-{
- papi_status_t result = PAPI_NOT_POSSIBLE;
-
- /* if there is no print service module loaded, try and load one. */
- if (svc->so_handle == NULL)
- result = service_load(svc, name);
- else if ((svc->name == NULL) && (name != NULL))
- svc->name = strdup(name);
-
- /*
- * the print service module is loaded, but we don't have a service
- * handle.
- */
- if (svc->so_handle != NULL) {
- papi_status_t (*f)();
-
- if (svc->svc_handle != NULL) /* already connected? */
- return (PAPI_OK);
-
- f = (papi_status_t (*)())psm_sym(svc, "papiServiceCreate");
-
- if (f != NULL) {
- char *user = svc->user;
- char *password = svc->password;
-
- /* if no API user, try the URI user */
- if ((user == NULL) && (svc->uri != NULL))
- user = (svc->uri)->user;
- /* if no API password, try the URI password */
- if ((password == NULL) && (svc->uri != NULL))
- password = (svc->uri)->password;
-
- result = f(&svc->svc_handle, svc->name, user, password,
- (svc->authCB ? interposed_auth_callback
- : NULL),
- svc->encryption, svc);
- (void) service_send_peer(svc);
- }
- }
-
- return (result);
-}
-
-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 result = PAPI_NOT_POSSIBLE;
- service_t *svc = NULL;
- uri_t *u = NULL;
-
- if (handle == NULL)
- return (PAPI_BAD_ARGUMENT);
-
- if ((*handle = svc = calloc(1, sizeof (*svc))) == NULL)
- return (PAPI_TEMPORARY_ERROR);
-
- svc->peer_fd = -1;
-
- if (user_name != NULL)
- svc->user = strdup(user_name);
-
- if (password != NULL)
- svc->password = strdup(password);
-
- svc->encryption = encryption;
-
- if (authCB != NULL)
- svc->authCB = authCB;
-
- if (app_data != NULL)
- svc->app_data = app_data;
-
- /* If not specified, get a "default" service from the environment */
- if (service_name == NULL)
- service_name = default_service_uri(NULL);
-
- if (service_name != NULL) {
- result = service_load(svc, service_name);
- /* if the psm loaded and the svc contains a URI, connect */
- if ((result == PAPI_OK) && (svc->uri != NULL))
- result = service_connect(svc, service_name);
- } else
- result = PAPI_OK;
-
- return (result);
-}
-
-void
-papiServiceDestroy(papi_service_t handle)
-{
- if (handle != NULL) {
- service_t *svc = handle;
-
- if (svc->so_handle != NULL) {
- if (svc->svc_handle != NULL) {
- void (*f)();
-
- f = (void (*)())psm_sym(svc,
- "papiServiceDestroy");
- f(svc->svc_handle);
- }
- psm_close(svc->so_handle);
- }
- if (svc->attributes != NULL)
- papiAttributeListFree(svc->attributes);
- if (svc->name != NULL)
- free(svc->name);
- if (svc->user != NULL)
- free(svc->user);
- if (svc->password != NULL)
- free(svc->password);
- if (svc->uri != NULL)
- uri_free(svc->uri);
-
- free(handle);
- }
-}
-
-papi_status_t
-papiServiceSetPeer(papi_service_t handle, int fd)
-{
- papi_status_t result = PAPI_OK;
-
- if (handle != NULL) {
- service_t *svc = handle;
-
- svc->peer_fd = fd;
- result = service_send_peer(svc);
- } else
- result = PAPI_BAD_ARGUMENT;
-
- return (result);
-}
-
-papi_status_t
-papiServiceSetUserName(papi_service_t handle, char *user_name)
-{
- papi_status_t result = PAPI_OK;
-
- if (handle != NULL) {
- service_t *svc = handle;
- papi_status_t (*f)();
-
- if (svc->user != NULL)
- free(svc->user);
- if (user_name != NULL)
- svc->user = strdup(user_name);
- f = (papi_status_t (*)())psm_sym(svc, "papiServiceSetUserName");
- if (f != NULL)
- result = f(svc->svc_handle, user_name);
- } else
- result = PAPI_BAD_ARGUMENT;
-
- return (result);
-}
-
-papi_status_t
-papiServiceSetPassword(papi_service_t handle, char *password)
-{
- papi_status_t result = PAPI_OK;
-
- if (handle != NULL) {
- service_t *svc = handle;
- papi_status_t (*f)();
-
- if (svc->password != NULL)
- free(svc->password);
- if (password != NULL)
- svc->password = strdup(password);
- f = (papi_status_t (*)())psm_sym(svc, "papiServiceSetPassword");
- if (f != NULL)
- result = f(svc->svc_handle, password);
- } else
- result = PAPI_BAD_ARGUMENT;
-
- return (result);
-}
-
-papi_status_t
-papiServiceSetEncryption(papi_service_t handle, papi_encryption_t encryption)
-{
- papi_status_t result = PAPI_OK;
-
- if (handle != NULL) {
- service_t *svc = handle;
- papi_status_t (*f)();
-
- svc->encryption = encryption;
- f = (papi_status_t (*)())psm_sym(svc,
- "papiServiceSetEncryption");
- if (f != NULL)
- result = f(svc->svc_handle, encryption);
- } else
- result = PAPI_BAD_ARGUMENT;
-
- return (result);
-}
-
-papi_status_t
-papiServiceSetAuthCB(papi_service_t handle,
- int (*authCB)(papi_service_t svc, void *app_data))
-{
- papi_status_t result = PAPI_OK;
-
- if (handle != NULL) {
- service_t *svc = handle;
- papi_status_t (*f)();
-
- svc->authCB = authCB;
- f = (papi_status_t (*)())psm_sym(svc, "papiServiceSetAuthCB");
- if (f != NULL)
- result = f(svc->svc_handle, interposed_auth_callback);
- } else
- result = PAPI_BAD_ARGUMENT;
-
- return (result);
-}
-
-
-papi_status_t
-papiServiceSetAppData(papi_service_t handle, void *app_data)
-{
- papi_status_t result = PAPI_OK;
-
- if (handle != NULL) {
- service_t *svc = handle;
- papi_status_t (*f)();
-
- svc->app_data = (void *)app_data;
- } else
- result = PAPI_BAD_ARGUMENT;
-
- return (result);
-}
-
-char *
-papiServiceGetServiceName(papi_service_t handle)
-{
- char *result = NULL;
-
- if (handle != NULL) {
- service_t *svc = handle;
- char *(*f)();
-
- f = (char *(*)())psm_sym(svc, "papiServiceGetServiceName");
- if (f != NULL)
- result = f(svc->svc_handle);
- if (result == NULL)
- result = svc->name;
- }
-
- return (result);
-}
-
-char *
-papiServiceGetUserName(papi_service_t handle)
-{
- char *result = NULL;
-
- if (handle != NULL) {
- service_t *svc = handle;
- char *(*f)();
-
- f = (char *(*)())psm_sym(svc, "papiServiceGetUserName");
- if (f != NULL)
- result = f(svc->svc_handle);
- if (result == NULL)
- result = svc->user;
- }
-
- return (result);
-}
-
-char *
-papiServiceGetPassword(papi_service_t handle)
-{
- char *result = NULL;
-
- if (handle != NULL) {
- service_t *svc = handle;
- char *(*f)();
-
- f = (char *(*)())psm_sym(svc, "papiServiceGetPassword");
- if (f != NULL)
- result = f(svc->svc_handle);
- if (result == NULL)
- result = svc->password;
- }
-
- return (result);
-}
-
-papi_encryption_t
-papiServiceGetEncryption(papi_service_t handle)
-{
- papi_encryption_t result = PAPI_ENCRYPT_NEVER;
-
- if (handle != NULL) {
- service_t *svc = handle;
- papi_encryption_t (*f)();
-
- f = (papi_encryption_t (*)())psm_sym(svc,
- "papiServiceGetEncryption");
- if (f != NULL)
- result = f(svc->svc_handle);
- if (result == PAPI_ENCRYPT_NEVER)
- result = svc->encryption;
- }
-
- return (result);
-}
-
-void *
-papiServiceGetAppData(papi_service_t handle)
-{
- void *result = NULL;
- service_t *svc = handle;
-
- if (handle != NULL)
- result = svc->app_data;
-
- return (result);
-}
-
-papi_attribute_t **
-papiServiceGetAttributeList(papi_service_t handle)
-{
- papi_attribute_t **result = NULL;
- service_t *svc = handle;
-
- if (handle != NULL) {
- papi_attribute_t **(*f)();
-
- if (svc->so_handle == NULL) {
- char *uri = default_service_uri(DEFAULT_SERVICE_URI);
-
- if (service_connect(svc, uri) != PAPI_OK)
- return (NULL);
- }
-
- f = (papi_attribute_t **(*)())psm_sym(svc,
- "papiServiceGetAttributeList");
- if (f != NULL)
- result = f(svc->svc_handle);
- } else
- result = svc->attributes;
-
- return (result);
-}
-
-char *
-papiServiceGetStatusMessage(papi_service_t handle)
-{
- char *result = NULL;
- service_t *svc = handle;
-
- if (handle != NULL) {
- char *(*f)();
-
- f = (char *(*)())psm_sym(svc, "papiServiceGetStatusMessage");
- if (f != NULL)
- result = f(svc->svc_handle);
- }
- if (result == 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;
- size_t size;
- char *message = alloca(BUFSIZ);
-
- va_start(ap, fmt);
- /*
- * fill in the message. If the buffer is too small, allocate
- * one that is large enough and fill it in.
- */
- if ((size = vsnprintf(message, BUFSIZ, fmt, ap)) >= BUFSIZ)
- if ((message = alloca(size)) != NULL)
- vsnprintf(message, size, fmt, ap);
- va_end(ap);
-
- papiAttributeListAddString(&svc->attributes, PAPI_ATTR_APPEND,
- "detailed-status-message", message);
-#ifdef DEBUG
- fprintf(stderr, "detailed_error(%s)\n", message);
-#endif
- }
-}