xbps-rindex(8): added support for XBPS_PASSPHRASE env var.
- XBPS_PASSPHRASE (if set) will be supplied as passphrase when signing repos. - Use the default OpenSSL passphrase cb when loading the private key.
This commit is contained in:
parent
c91050fc35
commit
43b9be6046
3
NEWS
3
NEWS
@ -1,5 +1,8 @@
|
|||||||
xbps-0.27 (???):
|
xbps-0.27 (???):
|
||||||
|
|
||||||
|
* xbps-rindex(8): also understands the XBPS_PASSPHRASE environmental variable to
|
||||||
|
supply the passphrase when signing repositories.
|
||||||
|
|
||||||
* xbps-rindex(8): added -v --verbose option.
|
* xbps-rindex(8): added -v --verbose option.
|
||||||
|
|
||||||
* xbps-rindex(8): -c --clean mode has been removed. Generating a local repository
|
* xbps-rindex(8): -c --clean mode has been removed. Generating a local repository
|
||||||
|
@ -2,8 +2,6 @@ TOPDIR = ../..
|
|||||||
-include $(TOPDIR)/config.mk
|
-include $(TOPDIR)/config.mk
|
||||||
|
|
||||||
BIN = xbps-rindex
|
BIN = xbps-rindex
|
||||||
OBJS = main.o index-add.o remove-obsoletes.o repoflush.o
|
OBJS = main.o index-add.o remove-obsoletes.o repoflush.o sign.o
|
||||||
OBJS += readpassphrase.o sign.o
|
|
||||||
EXTRA_CFLAGS = -Wno-unused-result
|
|
||||||
|
|
||||||
include $(TOPDIR)/mk/prog.mk
|
include $(TOPDIR)/mk/prog.mk
|
||||||
|
@ -74,9 +74,6 @@ int remove_obsoletes(struct xbps_handle *, const char *);
|
|||||||
int sign_repo(struct xbps_handle *, const char *, const char *,
|
int sign_repo(struct xbps_handle *, const char *, const char *,
|
||||||
const char *);
|
const char *);
|
||||||
|
|
||||||
/* From readpass.c */
|
|
||||||
char *readpassphrase(const char *, char *, size_t, int);
|
|
||||||
|
|
||||||
/* From repoflush.c */
|
/* From repoflush.c */
|
||||||
bool repodata_flush(struct xbps_handle *, const char *,
|
bool repodata_flush(struct xbps_handle *, const char *,
|
||||||
xbps_dictionary_t, xbps_dictionary_t, xbps_dictionary_t);
|
xbps_dictionary_t, xbps_dictionary_t, xbps_dictionary_t);
|
||||||
|
@ -1,123 +0,0 @@
|
|||||||
/* $NetBSD: readpassphrase.c,v 1.1 2009/06/07 22:38:47 christos Exp $ */
|
|
||||||
/*
|
|
||||||
* Copyright (c) 2000 Todd C. Miller <Todd.Miller@courtesan.com>
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
* 3. The name of the author may not be used to endorse or promote products
|
|
||||||
* derived from this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
||||||
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
||||||
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
|
||||||
* THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
||||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
||||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
|
||||||
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
||||||
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
|
||||||
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
|
||||||
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <ctype.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#include <fcntl.h>
|
|
||||||
#include <paths.h>
|
|
||||||
#include <pwd.h>
|
|
||||||
#include <signal.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <termios.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
|
|
||||||
#include "defs.h"
|
|
||||||
|
|
||||||
#define RPP_ECHO_OFF 0x00 /* Turn off echo (default). */
|
|
||||||
#define RPP_ECHO_ON 0x01 /* Leave echo on. */
|
|
||||||
#define RPP_REQUIRE_TTY 0x02 /* Fail if there is no tty. */
|
|
||||||
#define RPP_FORCELOWER 0x04 /* Force input to lower case. */
|
|
||||||
#define RPP_FORCEUPPER 0x08 /* Force input to upper case. */
|
|
||||||
#define RPP_SEVENBIT 0x10 /* Strip the high bit from input. */
|
|
||||||
|
|
||||||
char *
|
|
||||||
readpassphrase(const char *prompt, char *buf, size_t bufsiz, int flags)
|
|
||||||
{
|
|
||||||
struct termios term, oterm;
|
|
||||||
char ch, *p, *end;
|
|
||||||
int input, output;
|
|
||||||
sigset_t oset, nset;
|
|
||||||
|
|
||||||
/* I suppose we could alloc on demand in this case (XXX). */
|
|
||||||
if (bufsiz == 0) {
|
|
||||||
errno = EINVAL;
|
|
||||||
return(NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Read and write to /dev/tty if available. If not, read from
|
|
||||||
* stdin and write to stderr unless a tty is required.
|
|
||||||
*/
|
|
||||||
if ((input = output = open(_PATH_TTY, O_RDWR)) == -1) {
|
|
||||||
if (flags & RPP_REQUIRE_TTY) {
|
|
||||||
errno = ENOTTY;
|
|
||||||
return(NULL);
|
|
||||||
}
|
|
||||||
input = STDIN_FILENO;
|
|
||||||
output = STDERR_FILENO;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* We block SIGINT and SIGTSTP so the terminal is not left
|
|
||||||
* in an inconsistent state (ie: no echo). It would probably
|
|
||||||
* be better to simply catch these though.
|
|
||||||
*/
|
|
||||||
sigemptyset(&nset);
|
|
||||||
sigaddset(&nset, SIGINT);
|
|
||||||
sigaddset(&nset, SIGTSTP);
|
|
||||||
(void)sigprocmask(SIG_BLOCK, &nset, &oset);
|
|
||||||
|
|
||||||
/* Turn off echo if possible. */
|
|
||||||
if (tcgetattr(input, &oterm) == 0) {
|
|
||||||
memcpy(&term, &oterm, sizeof(term));
|
|
||||||
if (!(flags & RPP_ECHO_ON) && (term.c_lflag & ECHO))
|
|
||||||
term.c_lflag &= ~ECHO;
|
|
||||||
(void)tcsetattr(input, TCSAFLUSH, &term);
|
|
||||||
} else {
|
|
||||||
memset(&term, 0, sizeof(term));
|
|
||||||
memset(&oterm, 0, sizeof(oterm));
|
|
||||||
}
|
|
||||||
|
|
||||||
(void)write(output, prompt, strlen(prompt));
|
|
||||||
end = buf + bufsiz - 1;
|
|
||||||
for (p = buf; read(input, &ch, 1) == 1 && ch != '\n' && ch != '\r';) {
|
|
||||||
if (p < end) {
|
|
||||||
if ((flags & RPP_SEVENBIT))
|
|
||||||
ch &= 0x7f;
|
|
||||||
if (isalpha((unsigned char)ch)) {
|
|
||||||
if ((flags & RPP_FORCELOWER))
|
|
||||||
ch = tolower((unsigned char)ch);
|
|
||||||
if ((flags & RPP_FORCEUPPER))
|
|
||||||
ch = toupper((unsigned char)ch);
|
|
||||||
}
|
|
||||||
*p++ = ch;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*p = '\0';
|
|
||||||
if (!(term.c_lflag & ECHO))
|
|
||||||
(void)write(output, "\n", 1);
|
|
||||||
|
|
||||||
/* Restore old terminal settings and signal mask. */
|
|
||||||
if (memcmp(&term, &oterm, sizeof(term)) != 0)
|
|
||||||
(void)tcsetattr(input, TCSAFLUSH, &oterm);
|
|
||||||
(void)sigprocmask(SIG_SETMASK, &oset, NULL);
|
|
||||||
if (input != STDIN_FILENO)
|
|
||||||
(void)close(input);
|
|
||||||
|
|
||||||
return(buf);
|
|
||||||
}
|
|
@ -38,34 +38,13 @@
|
|||||||
|
|
||||||
#include "defs.h"
|
#include "defs.h"
|
||||||
|
|
||||||
static int
|
|
||||||
password_cb(char *buf, int size)
|
|
||||||
{
|
|
||||||
int len = 0;
|
|
||||||
char pass[BUFSIZ];
|
|
||||||
|
|
||||||
if (readpassphrase("Enter passphrase: ", pass, BUFSIZ, 0) == NULL)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
len = strlen(pass);
|
|
||||||
|
|
||||||
if (len <= 0)
|
|
||||||
return 0;
|
|
||||||
if (len > size)
|
|
||||||
len = size;
|
|
||||||
|
|
||||||
memset(buf, '\0', size);
|
|
||||||
memcpy(buf, pass, len);
|
|
||||||
memset(&pass, 0, BUFSIZ);
|
|
||||||
|
|
||||||
return len;
|
|
||||||
}
|
|
||||||
|
|
||||||
static RSA *
|
static RSA *
|
||||||
load_rsa_privkey(const char *path)
|
load_rsa_privkey(const char *path)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
RSA *rsa = NULL;
|
RSA *rsa = NULL;
|
||||||
|
const char *p;
|
||||||
|
char *passphrase = NULL;
|
||||||
|
|
||||||
if ((fp = fopen(path, "r")) == 0)
|
if ((fp = fopen(path, "r")) == 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -75,9 +54,15 @@ load_rsa_privkey(const char *path)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
rsa = PEM_read_RSAPrivateKey(fp, 0,
|
p = getenv("XBPS_PASSPHRASE");
|
||||||
(pem_password_cb *)password_cb,
|
if (p) {
|
||||||
__UNCONST(path));
|
passphrase = strdup(p);
|
||||||
|
}
|
||||||
|
rsa = PEM_read_RSAPrivateKey(fp, 0, NULL, passphrase);
|
||||||
|
if (passphrase) {
|
||||||
|
free(passphrase);
|
||||||
|
passphrase = NULL;
|
||||||
|
}
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
return rsa;
|
return rsa;
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
.Dd October 5, 2013
|
.Dd October 12, 2013
|
||||||
.Os Void Linux
|
.Os Void Linux
|
||||||
.Dt xbps-rindex 8
|
.Dt xbps-rindex 8
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
@ -49,6 +49,9 @@ argument not set, it defaults to
|
|||||||
.Sy ~/.ssh/id_rsa .
|
.Sy ~/.ssh/id_rsa .
|
||||||
.Sh ENVIRONMENT
|
.Sh ENVIRONMENT
|
||||||
.Bl -tag -width XBPS_TARGET_ARCH
|
.Bl -tag -width XBPS_TARGET_ARCH
|
||||||
|
.It Sy XBPS_PASSPHRASE
|
||||||
|
If this is set, it will use this passphrase for the RSA private key when signing
|
||||||
|
a repository. Otherwise it will ask you to enter the passphrase on the terminal.
|
||||||
.It Sy XBPS_TARGET_ARCH
|
.It Sy XBPS_TARGET_ARCH
|
||||||
Overrides
|
Overrides
|
||||||
.Xr uname 2
|
.Xr uname 2
|
||||||
|
Loading…
Reference in New Issue
Block a user