|
Packit Service |
3749ba |
/*
|
|
Packit Service |
3749ba |
* Copyright (c) 2011, Collabora Ltd.
|
|
Packit Service |
3749ba |
*
|
|
Packit Service |
3749ba |
* Redistribution and use in source and binary forms, with or without
|
|
Packit Service |
3749ba |
* modification, are permitted provided that the following conditions
|
|
Packit Service |
3749ba |
* are met:
|
|
Packit Service |
3749ba |
*
|
|
Packit Service |
3749ba |
* * Redistributions of source code must retain the above
|
|
Packit Service |
3749ba |
* copyright notice, this list of conditions and the
|
|
Packit Service |
3749ba |
* following disclaimer.
|
|
Packit Service |
3749ba |
* * Redistributions in binary form must reproduce the
|
|
Packit Service |
3749ba |
* above copyright notice, this list of conditions and
|
|
Packit Service |
3749ba |
* the following disclaimer in the documentation and/or
|
|
Packit Service |
3749ba |
* other materials provided with the distribution.
|
|
Packit Service |
3749ba |
* * The names of contributors to this software may not be
|
|
Packit Service |
3749ba |
* used to endorse or promote products derived from this
|
|
Packit Service |
3749ba |
* software without specific prior written permission.
|
|
Packit Service |
3749ba |
*
|
|
Packit Service |
3749ba |
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
Packit Service |
3749ba |
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
Packit Service |
3749ba |
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
Packit Service |
3749ba |
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
Packit Service |
3749ba |
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
Packit Service |
3749ba |
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
Packit Service |
3749ba |
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
Packit Service |
3749ba |
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
Packit Service |
3749ba |
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
Packit Service |
3749ba |
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
|
Packit Service |
3749ba |
* THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
|
|
Packit Service |
3749ba |
* DAMAGE.
|
|
Packit Service |
3749ba |
*
|
|
Packit Service |
3749ba |
* Author: Stef Walter <stefw@collabora.co.uk>
|
|
Packit Service |
3749ba |
*/
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
#include "config.h"
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
#include "compat.h"
|
|
Packit Service |
3749ba |
#include "debug.h"
|
|
Packit Service |
3749ba |
#include "message.h"
|
|
Packit Service |
3749ba |
#include "path.h"
|
|
Packit Service |
3749ba |
#include "p11-kit.h"
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
#include <assert.h>
|
|
Packit Service |
3749ba |
#include <ctype.h>
|
|
Packit Service |
3749ba |
#include <errno.h>
|
|
Packit Service |
3749ba |
#include <getopt.h>
|
|
Packit Service |
3749ba |
#include <string.h>
|
|
Packit Service |
3749ba |
#include <stdio.h>
|
|
Packit Service |
3749ba |
#include <stdlib.h>
|
|
Packit Service |
3749ba |
#include <unistd.h>
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
#include "tool.h"
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
int p11_kit_list_modules (int argc,
|
|
Packit Service |
3749ba |
char *argv[]);
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
int p11_kit_trust (int argc,
|
|
Packit Service |
3749ba |
char *argv[]);
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
int p11_kit_external (int argc,
|
|
Packit Service |
3749ba |
char *argv[]);
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
static const p11_tool_command commands[] = {
|
|
Packit Service |
3749ba |
{ "list-modules", p11_kit_list_modules, "List modules and tokens" },
|
|
Packit Service |
3749ba |
{ "remote", p11_kit_external, "Run a specific PKCS#11 module remotely" },
|
|
Packit Service |
3749ba |
{ "server", p11_kit_external, "Run a server process that exposes PKCS#11 module remotely" },
|
|
Packit Service |
3749ba |
{ P11_TOOL_FALLBACK, p11_kit_external, NULL },
|
|
Packit Service |
3749ba |
{ 0, }
|
|
Packit Service |
3749ba |
};
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
int
|
|
Packit Service |
3749ba |
p11_kit_trust (int argc,
|
|
Packit Service |
3749ba |
char *argv[])
|
|
Packit Service |
3749ba |
{
|
|
Packit Service |
3749ba |
char **args;
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
args = calloc (argc + 2, sizeof (char *));
|
|
Packit Service |
3749ba |
return_val_if_fail (args != NULL, 1);
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
args[0] = BINDIR "/trust";
|
|
Packit Service |
3749ba |
memcpy (args + 1, argv, sizeof (char *) * argc);
|
|
Packit Service |
3749ba |
args[argc + 1] = NULL;
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
execv (args[0], args);
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
/* At this point we have no command */
|
|
Packit Service |
3749ba |
p11_message_err (errno, "couldn't run trust tool");
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
free (args);
|
|
Packit Service |
3749ba |
return 2;
|
|
Packit Service |
3749ba |
}
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
int
|
|
Packit Service |
3749ba |
p11_kit_external (int argc,
|
|
Packit Service |
3749ba |
char *argv[])
|
|
Packit Service |
3749ba |
{
|
|
Packit Service |
3749ba |
const char *private_dir;
|
|
Packit Service |
3749ba |
char *filename;
|
|
Packit Service |
3749ba |
char *path;
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
/* These are trust commands, send them to that tool */
|
|
Packit Service |
3749ba |
if (strcmp (argv[0], "extract") == 0) {
|
|
Packit Service |
3749ba |
return p11_kit_trust (argc, argv);
|
|
Packit Service |
3749ba |
} else if (strcmp (argv[0], "extract-trust") == 0) {
|
|
Packit Service |
3749ba |
argv[0] = "extract-compat";
|
|
Packit Service |
3749ba |
return p11_kit_trust (argc, argv);
|
|
Packit Service |
3749ba |
}
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
if (asprintf (&filename, "p11-kit-%s%s", argv[0], EXEEXT) < 0)
|
|
Packit Service |
3749ba |
return_val_if_reached (1);
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
private_dir = secure_getenv ("P11_KIT_PRIVATEDIR");
|
|
Packit Service |
3749ba |
if (!private_dir || !private_dir[0])
|
|
Packit Service |
3749ba |
private_dir = PRIVATEDIR;
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
/* Add our libexec directory to the path */
|
|
Packit Service |
3749ba |
path = p11_path_build (private_dir, filename, NULL);
|
|
Packit Service |
3749ba |
return_val_if_fail (path != NULL, 1);
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
/* Windows execv() requires the first element of ARGV must be
|
|
Packit Service |
3749ba |
* the executable name */
|
|
Packit Service |
3749ba |
#ifdef OS_WIN32
|
|
Packit Service |
3749ba |
argv[0] = path;
|
|
Packit Service |
3749ba |
#endif
|
|
Packit Service |
3749ba |
argv[argc] = NULL;
|
|
Packit Service |
3749ba |
execv (path, argv);
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
/* At this point we have no command */
|
|
Packit Service |
3749ba |
p11_message ("'%s' is not a valid command. See 'p11-kit --help'", argv[0]);
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
free (filename);
|
|
Packit Service |
3749ba |
free (path);
|
|
Packit Service |
3749ba |
return 2;
|
|
Packit Service |
3749ba |
}
|
|
Packit Service |
3749ba |
|
|
Packit Service |
3749ba |
int
|
|
Packit Service |
3749ba |
main (int argc,
|
|
Packit Service |
3749ba |
char *argv[])
|
|
Packit Service |
3749ba |
{
|
|
Packit Service |
3749ba |
return p11_tool_main (argc, argv, commands);
|
|
Packit Service |
3749ba |
}
|