Don't check for duplicates if an existing id has been supplied

This commit is contained in:
Jeremy Lakeman 2013-01-03 11:18:30 +10:30
parent 66deb575d3
commit 2967d1e00f
6 changed files with 23 additions and 24 deletions

View File

@ -202,14 +202,19 @@ int rhizome_manifest_bind_id(rhizome_manifest *m_in)
} }
/* Check if a manifest is already stored for the same payload with the same details. /* Check if a manifest is already stored for the same payload with the same details.
This catches the case of "dna rhizome add file <filename>" on the same file more than once. This catches the case of "rhizome add file <filename>" on the same file more than once.
(Debounce!) */ (Debounce!) */
int rhizome_manifest_check_duplicate(rhizome_manifest *m_in, rhizome_manifest **m_out) int rhizome_manifest_check_duplicate(rhizome_manifest *m_in, rhizome_manifest **m_out)
{ {
// if a manifest was supplied with an ID, don't bother to check for a duplicate.
// we only want to filter out added files with no existing manifest.
if (m_in->haveSecret!=NEW_BUNDLE_ID)
return 0;
if (config.debug.rhizome) DEBUG("Checking for duplicate"); if (config.debug.rhizome) DEBUG("Checking for duplicate");
if (m_out) *m_out = NULL; if (m_out) *m_out = NULL;
rhizome_manifest *dupm = NULL; rhizome_manifest *dupm = NULL;
if (rhizome_find_duplicate(m_in, &dupm,0 /* version doesn't matter */) == -1) if (rhizome_find_duplicate(m_in, &dupm) == -1)
return WHY("Errors encountered searching for duplicate manifest"); return WHY("Errors encountered searching for duplicate manifest");
if (dupm) { if (dupm) {
/* If the caller wants the duplicate manifest, it must be finalised, otherwise discarded. */ /* If the caller wants the duplicate manifest, it must be finalised, otherwise discarded. */

View File

@ -73,6 +73,9 @@ extern time_ms_t rhizome_voice_timeout;
#define RHIZOME_IDLE_TIMEOUT 10000 #define RHIZOME_IDLE_TIMEOUT 10000
#define EXISTING_BUNDLE_ID 1
#define NEW_BUNDLE_ID 2
typedef struct rhizome_signature { typedef struct rhizome_signature {
unsigned char signature[crypto_sign_edwards25519sha512batch_BYTES unsigned char signature[crypto_sign_edwards25519sha512batch_BYTES
+crypto_sign_edwards25519sha512batch_PUBLICKEYBYTES+1]; +crypto_sign_edwards25519sha512batch_PUBLICKEYBYTES+1];
@ -298,8 +301,7 @@ int _sqlite_exec_strbuf(struct __sourceloc, strbuf sb, const char *sqlformat,...
double rhizome_manifest_get_double(rhizome_manifest *m,char *var,double default_value); double rhizome_manifest_get_double(rhizome_manifest *m,char *var,double default_value);
int rhizome_manifest_extract_signature(rhizome_manifest *m,int *ofs); int rhizome_manifest_extract_signature(rhizome_manifest *m,int *ofs);
int rhizome_update_file_priority(const char *fileid); int rhizome_update_file_priority(const char *fileid);
int rhizome_find_duplicate(const rhizome_manifest *m, rhizome_manifest **found, int rhizome_find_duplicate(const rhizome_manifest *m, rhizome_manifest **found);
int checkVersionP);
int rhizome_manifest_to_bar(rhizome_manifest *m,unsigned char *bar); int rhizome_manifest_to_bar(rhizome_manifest *m,unsigned char *bar);
long long rhizome_bar_version(unsigned char *bar); long long rhizome_bar_version(unsigned char *bar);
unsigned long long rhizome_bar_bidprefix_ll(unsigned char *bar); unsigned long long rhizome_bar_bidprefix_ll(unsigned char *bar);

View File

@ -644,12 +644,8 @@ int rhizome_manifest_dump(rhizome_manifest *m, const char *msg)
int rhizome_manifest_finalise(rhizome_manifest *m, rhizome_manifest **mout) int rhizome_manifest_finalise(rhizome_manifest *m, rhizome_manifest **mout)
{ {
/* Add the manifest and its associated file to the Rhizome database,
generating an "id" in the process.
PGS @20121003 - Hang on, didn't we create the ID above? Presumably the
following does NOT in fact generate a bundle ID.
*/
int ret=0; int ret=0;
if (rhizome_manifest_check_duplicate(m, mout) == 2) { if (rhizome_manifest_check_duplicate(m, mout) == 2) {
/* duplicate found -- verify it so that we can write it out later */ /* duplicate found -- verify it so that we can write it out later */
rhizome_manifest_verify(*mout); rhizome_manifest_verify(*mout);

View File

@ -34,7 +34,7 @@ unsigned char *rhizome_bundle_shared_secret(rhizome_manifest *m)
int rhizome_manifest_createid(rhizome_manifest *m) int rhizome_manifest_createid(rhizome_manifest *m)
{ {
m->haveSecret=1; m->haveSecret=NEW_BUNDLE_ID;
int r=crypto_sign_edwards25519sha512batch_keypair(m->cryptoSignPublic,m->cryptoSignSecret); int r=crypto_sign_edwards25519sha512batch_keypair(m->cryptoSignPublic,m->cryptoSignSecret);
if (!r) return 0; if (!r) return 0;
return WHY("Failed to create keypair for manifest ID."); return WHY("Failed to create keypair for manifest ID.");
@ -225,7 +225,7 @@ int rhizome_extract_privatekey(rhizome_manifest *m)
bkBytes,m->cryptoSignSecret); bkBytes,m->cryptoSignSecret);
if (result == 0) { if (result == 0) {
m->haveSecret=1; m->haveSecret=EXISTING_BUNDLE_ID;
RETURN(0); // bingo RETURN(0); // bingo
} }
memset(m->cryptoSignSecret, 0, sizeof m->cryptoSignSecret); memset(m->cryptoSignSecret, 0, sizeof m->cryptoSignSecret);
@ -275,7 +275,7 @@ int rhizome_find_bundle_author(rhizome_manifest *m)
if (!rhizome_bk2secret(m,m->cryptoSignPublic,rs,rs_len, if (!rhizome_bk2secret(m,m->cryptoSignPublic,rs,rs_len,
bkBytes,m->cryptoSignSecret)) { bkBytes,m->cryptoSignSecret)) {
memcpy(m->author, authorSid, sizeof m->author); memcpy(m->author, authorSid, sizeof m->author);
m->haveSecret=1; m->haveSecret=EXISTING_BUNDLE_ID;
if (config.debug.rhizome) if (config.debug.rhizome)
DEBUGF("found bundle author sid=%s", alloca_tohex_sid(m->author)); DEBUGF("found bundle author sid=%s", alloca_tohex_sid(m->author));
@ -333,8 +333,8 @@ int rhizome_verify_bundle_privatekey(rhizome_manifest *m,
if (config.debug.rhizome) if (config.debug.rhizome)
DEBUGF("We have the private key for this bundle."); DEBUGF("We have the private key for this bundle.");
if (m&&sk==m->cryptoSignSecret&&pkin==m->cryptoSignPublic) { if (m&&sk==m->cryptoSignSecret&&pkin==m->cryptoSignPublic) {
DEBUGF("Set haveSecret=1 in manifest"); DEBUGF("Set haveSecret=%d in manifest",EXISTING_BUNDLE_ID);
m->haveSecret=1; m->haveSecret=EXISTING_BUNDLE_ID;
} }
RETURN(0); RETURN(0);
} }

View File

@ -1032,8 +1032,10 @@ int rhizome_update_file_priority(const char *fileid)
@author Andrew Bettison <andrew@servalproject.com> @author Andrew Bettison <andrew@servalproject.com>
*/ */
int rhizome_find_duplicate(const rhizome_manifest *m, rhizome_manifest **found, int checkVersionP) int rhizome_find_duplicate(const rhizome_manifest *m, rhizome_manifest **found)
{ {
// TODO, add service, name, sender & recipient to manifests table so we can simply query them.
const char *service = rhizome_manifest_get(m, "service", NULL, 0); const char *service = rhizome_manifest_get(m, "service", NULL, 0);
const char *name = NULL; const char *name = NULL;
const char *sender = NULL; const char *sender = NULL;
@ -1058,8 +1060,6 @@ int rhizome_find_duplicate(const rhizome_manifest *m, rhizome_manifest **found,
strbuf_puts(b, "filehash = ?"); strbuf_puts(b, "filehash = ?");
} else } else
strbuf_puts(b, "filesize = 0"); strbuf_puts(b, "filesize = 0");
if (checkVersionP)
strbuf_puts(b, " AND version = ?");
if (strbuf_overrun(b)) if (strbuf_overrun(b))
return WHYF("SQL command too long: %s", strbuf_str(b)); return WHYF("SQL command too long: %s", strbuf_str(b));
int ret = 0; int ret = 0;
@ -1076,8 +1076,6 @@ int rhizome_find_duplicate(const rhizome_manifest *m, rhizome_manifest **found,
DEBUGF("filehash=\"%s\"", filehash); DEBUGF("filehash=\"%s\"", filehash);
sqlite3_bind_text(statement, field++, filehash, -1, SQLITE_STATIC); sqlite3_bind_text(statement, field++, filehash, -1, SQLITE_STATIC);
} }
if (checkVersionP)
sqlite3_bind_int64(statement, field++, m->version);
size_t rows = 0; size_t rows = 0;
while (sqlite_step_retry(&retry, statement) == SQLITE_ROW) { while (sqlite_step_retry(&retry, statement) == SQLITE_ROW) {
++rows; ++rows;
@ -1128,7 +1126,7 @@ int rhizome_find_duplicate(const rhizome_manifest *m, rhizome_manifest **found,
WARNF("MANIFESTS row id=%s has inconsistent blob with id=%s -- skipped", q_manifestid, blob_id); WARNF("MANIFESTS row id=%s has inconsistent blob with id=%s -- skipped", q_manifestid, blob_id);
++inconsistent; ++inconsistent;
} }
if (checkVersionP && blob_version != q_version) { if (blob_version != q_version) {
WARNF("MANIFESTS row id=%s has inconsistent blob: manifests.version=%lld, blob.version=%lld -- skipped", WARNF("MANIFESTS row id=%s has inconsistent blob: manifests.version=%lld, blob.version=%lld -- skipped",
q_manifestid, q_version, blob_version); q_manifestid, q_version, blob_version);
++inconsistent; ++inconsistent;
@ -1151,10 +1149,6 @@ int rhizome_find_duplicate(const rhizome_manifest *m, rhizome_manifest **found,
++inconsistent; ++inconsistent;
} }
} }
if (checkVersionP && q_version != m->version) {
WARNF("SELECT query with version=%lld returned incorrect row: manifests.version=%lld -- skipped", m->version, q_version);
++inconsistent;
}
if (blob_service == NULL) { if (blob_service == NULL) {
WARNF("MANIFESTS row id=%s has blob with no 'service' -- skipped", q_manifestid, blob_id); WARNF("MANIFESTS row id=%s has blob with no 'service' -- skipped", q_manifestid, blob_id);
++inconsistent; ++inconsistent;

View File

@ -305,6 +305,8 @@ int rhizome_manifest_version_cache_lookup(rhizome_manifest *m)
str_toupper_inplace(id); str_toupper_inplace(id);
m->version = rhizome_manifest_get_ll(m, "version"); m->version = rhizome_manifest_get_ll(m, "version");
// TODO, work out why the cache was failing and fix it, then prove that it is faster than accessing the database.
// skip the cache for now // skip the cache for now
long long dbVersion = -1; long long dbVersion = -1;
if (sqlite_exec_int64(&dbVersion, "SELECT version FROM MANIFESTS WHERE id='%s';", id) == -1) if (sqlite_exec_int64(&dbVersion, "SELECT version FROM MANIFESTS WHERE id='%s';", id) == -1)