mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-18 21:28:02 +00:00
opkg: add patch to circumvent signature checks on the command line
Signed-off-by: Felix Fietkau <nbd@openwrt.org> SVN-Revision: 45285
This commit is contained in:
parent
3efd1303d8
commit
dde8214d16
70
package/system/opkg/patches/210-add-force-signature.patch
Normal file
70
package/system/opkg/patches/210-add-force-signature.patch
Normal file
@ -0,0 +1,70 @@
|
||||
--- a/libopkg/opkg_conf.h
|
||||
+++ b/libopkg/opkg_conf.h
|
||||
@@ -80,6 +80,7 @@ struct opkg_conf
|
||||
int force_remove;
|
||||
int force_checksum;
|
||||
int check_signature;
|
||||
+ int force_signature;
|
||||
int nodeps; /* do not follow dependencies */
|
||||
int nocase; /* perform case insensitive matching */
|
||||
char *offline_root;
|
||||
--- a/src/opkg-cl.c
|
||||
+++ b/src/opkg-cl.c
|
||||
@@ -51,6 +51,7 @@ enum {
|
||||
ARGS_OPT_NOCASE,
|
||||
ARGS_OPT_AUTOREMOVE,
|
||||
ARGS_OPT_CACHE,
|
||||
+ ARGS_OPT_FORCE_SIGNATURE,
|
||||
};
|
||||
|
||||
static struct option long_options[] = {
|
||||
@@ -87,6 +88,8 @@ static struct option long_options[] = {
|
||||
{"force_remove", 0, 0, ARGS_OPT_FORCE_REMOVE},
|
||||
{"force-checksum", 0, 0, ARGS_OPT_FORCE_CHECKSUM},
|
||||
{"force_checksum", 0, 0, ARGS_OPT_FORCE_CHECKSUM},
|
||||
+ {"force-signature", 0, 0, ARGS_OPT_FORCE_SIGNATURE},
|
||||
+ {"force_signature", 0, 0, ARGS_OPT_FORCE_SIGNATURE},
|
||||
{"noaction", 0, 0, ARGS_OPT_NOACTION},
|
||||
{"download-only", 0, 0, ARGS_OPT_DOWNLOAD_ONLY},
|
||||
{"nodeps", 0, 0, ARGS_OPT_NODEPS},
|
||||
@@ -210,6 +213,9 @@ args_parse(int argc, char *argv[])
|
||||
case ARGS_OPT_DOWNLOAD_ONLY:
|
||||
conf->download_only = 1;
|
||||
break;
|
||||
+ case ARGS_OPT_FORCE_SIGNATURE:
|
||||
+ conf->force_signature = 1;
|
||||
+ break;
|
||||
case ':':
|
||||
parse_err = -1;
|
||||
break;
|
||||
--- a/libopkg/opkg_install.c
|
||||
+++ b/libopkg/opkg_install.c
|
||||
@@ -1306,13 +1306,15 @@ opkg_install_pkg(pkg_t *pkg, int from_up
|
||||
if (opkg_verify_file (list_file_name, sig_file_name)){
|
||||
opkg_msg(ERROR, "Failed to verify the signature of %s.\n",
|
||||
list_file_name);
|
||||
- return -1;
|
||||
+ if (!conf->force_signature)
|
||||
+ return -1;
|
||||
}
|
||||
}else{
|
||||
opkg_msg(ERROR, "Signature file is missing for %s. "
|
||||
"Perhaps you need to run 'opkg update'?\n",
|
||||
pkg->name);
|
||||
- return -1;
|
||||
+ if (!conf->force_signature)
|
||||
+ return -1;
|
||||
}
|
||||
|
||||
free (lists_dir);
|
||||
--- a/libopkg/opkg_cmd.c
|
||||
+++ b/libopkg/opkg_cmd.c
|
||||
@@ -196,7 +196,7 @@ opkg_update_cmd(int argc, char **argv)
|
||||
else
|
||||
opkg_msg(NOTICE, "Signature check failed.\n");
|
||||
}
|
||||
- if (err) {
|
||||
+ if (err && !conf->force_signature) {
|
||||
/* The signature was wrong so delete it */
|
||||
opkg_msg(NOTICE, "Remove wrong Signature file.\n");
|
||||
unlink (tmp_file_name);
|
Loading…
Reference in New Issue
Block a user