mirror of
git://git.gnupg.org/gnupg.git
synced 2024-06-17 00:39:50 +02:00
286a89da7c
* g13/call-syshelp.c, g13/call-syshelp.h: New. * g13/g13-syshelp.c, g13/g13-syshelp.h: New. * g13/sh-cmd.c: New. * g13/sh-blockdev.c: New. * g13/sh-exectool.c: New. * g13/sh-dmcrypt.c: New. * g13/Makefile.am (sbin_PROGRAMS): Add g13-syshelp.c (g13_syshelp_SOURCES): New. (g13_syshelp_LDADD): New. * g13/g13.c (opts): Add option --type. (g13_deinit_default_ctrl): New. (main): Implement that option. Call g13_deinit_default_ctrl. * g13/g13.h (struct call_syshelp_s): New declaration. (server_control_s): Add field syshelp_local. * g13/keyblob.h (KEYBLOB_TAG_CREATED): New. (KEYBLOB_TAG_ALGOSTR): New. (KEYBLOB_TAG_HDRCOPY): New. * g13/backend.c (be_parse_conttype_name): New. (be_get_detached_name): Add CONTTYPE_DM_CRYPT. Signed-off-by: Werner Koch <wk@gnupg.org>
170 lines
4.1 KiB
C
170 lines
4.1 KiB
C
/* backend.c - Dispatcher to the various backends.
|
|
* Copyright (C) 2009 Free Software Foundation, Inc.
|
|
*
|
|
* This file is part of GnuPG.
|
|
*
|
|
* GnuPG is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* GnuPG is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include <config.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <errno.h>
|
|
#include <unistd.h>
|
|
|
|
#include "g13.h"
|
|
#include "i18n.h"
|
|
#include "keyblob.h"
|
|
#include "backend.h"
|
|
#include "be-encfs.h"
|
|
#include "be-truecrypt.h"
|
|
|
|
|
|
static gpg_error_t
|
|
no_such_backend (int conttype)
|
|
{
|
|
log_error ("invalid backend %d given - this is most likely a bug\n",
|
|
conttype);
|
|
return gpg_error (GPG_ERR_INTERNAL);
|
|
}
|
|
|
|
|
|
/* Parse NAME and return the corresponding content type. If the name
|
|
is not known, a error message is printed and zero returned. If
|
|
NAME is NULL the supported backend types are listed and 0 is
|
|
returned. */
|
|
int
|
|
be_parse_conttype_name (const char *name)
|
|
{
|
|
static struct { const char *name; int conttype; } names[] = {
|
|
{ "encfs", CONTTYPE_ENCFS },
|
|
{ "dm-crypt", CONTTYPE_DM_CRYPT }
|
|
};
|
|
int i;
|
|
|
|
if (!name)
|
|
{
|
|
log_info ("Known backend types:\n");
|
|
for (i=0; i < DIM (names); i++)
|
|
log_info (" %s\n", names[i].name);
|
|
return 0;
|
|
}
|
|
|
|
for (i=0; i < DIM (names); i++)
|
|
{
|
|
if (!strcmp (names[i].name, name))
|
|
return names[i].conttype;
|
|
}
|
|
|
|
log_error ("invalid backend type '%s' given\n", name);
|
|
return 0;
|
|
}
|
|
|
|
|
|
/* Return true if CONTTYPE is supported by us. */
|
|
int
|
|
be_is_supported_conttype (int conttype)
|
|
{
|
|
switch (conttype)
|
|
{
|
|
case CONTTYPE_ENCFS:
|
|
return 1;
|
|
|
|
default:
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/* If the backend requires a separate file or directory for the
|
|
container, return its name by computing it from FNAME which gives
|
|
the g13 filename. The new file name is allocated and stored at
|
|
R_NAME, if this is expected to be a directory true is stored at
|
|
R_ISDIR. If no detached name is expected or an error occurs NULL
|
|
is stored at R_NAME. The function returns 0 on success or an error
|
|
code. */
|
|
gpg_error_t
|
|
be_get_detached_name (int conttype, const char *fname,
|
|
char **r_name, int *r_isdir)
|
|
{
|
|
*r_name = NULL;
|
|
*r_isdir = 0;
|
|
switch (conttype)
|
|
{
|
|
case CONTTYPE_ENCFS:
|
|
return be_encfs_get_detached_name (fname, r_name, r_isdir);
|
|
|
|
case CONTTYPE_DM_CRYPT:
|
|
return 0;
|
|
|
|
default:
|
|
return no_such_backend (conttype);
|
|
}
|
|
}
|
|
|
|
|
|
gpg_error_t
|
|
be_create_new_keys (int conttype, membuf_t *mb)
|
|
{
|
|
switch (conttype)
|
|
{
|
|
case CONTTYPE_ENCFS:
|
|
return be_encfs_create_new_keys (mb);
|
|
|
|
case CONTTYPE_TRUECRYPT:
|
|
return be_truecrypt_create_new_keys (mb);
|
|
|
|
default:
|
|
return no_such_backend (conttype);
|
|
}
|
|
}
|
|
|
|
|
|
/* Dispatcher to the backend's create function. */
|
|
gpg_error_t
|
|
be_create_container (ctrl_t ctrl, int conttype,
|
|
const char *fname, int fd, tupledesc_t tuples,
|
|
unsigned int *r_id)
|
|
{
|
|
(void)fd; /* Not yet used. */
|
|
|
|
switch (conttype)
|
|
{
|
|
case CONTTYPE_ENCFS:
|
|
return be_encfs_create_container (ctrl, fname, tuples, r_id);
|
|
|
|
default:
|
|
return no_such_backend (conttype);
|
|
}
|
|
}
|
|
|
|
|
|
/* Dispatcher to the backend's mount function. */
|
|
gpg_error_t
|
|
be_mount_container (ctrl_t ctrl, int conttype,
|
|
const char *fname, const char *mountpoint,
|
|
tupledesc_t tuples, unsigned int *r_id)
|
|
{
|
|
switch (conttype)
|
|
{
|
|
case CONTTYPE_ENCFS:
|
|
return be_encfs_mount_container (ctrl, fname, mountpoint, tuples, r_id);
|
|
|
|
default:
|
|
return no_such_backend (conttype);
|
|
}
|
|
}
|