ssb: No longer replicate every account we hear about.

This commit is contained in:
Cory McWilliams 2025-01-03 15:25:59 -05:00
parent 0cb5025a16
commit 75c71135ba

View File

@ -148,14 +148,14 @@ static void _ebt_add_to_clock(ebt_get_clock_t* work, const char* id, int64_t val
{ {
int count = work->clock ? work->clock->count : 0; int count = work->clock ? work->clock->count : 0;
ebt_entry_t* entry = _ebt_get_entry(work->ebt, id); ebt_entry_t* entry = _ebt_get_entry(work->ebt, id);
if (entry->out_replicate != replicate || entry->out_receive != receive || ((replicate || receive) && entry->out != value)) if ((replicate && !entry->out_replicate) || (receive && !entry->out_receive) || ((replicate || receive || entry->out_replicate || entry->out_receive) && entry->out != value))
{ {
entry->out = value; entry->out = value;
entry->out_replicate = replicate; entry->out_replicate = entry->out_replicate || replicate;
entry->out_receive = receive; entry->out_receive = entry->out_receive || receive;
int index = tf_util_insert_index(id, count ? work->clock->entries : NULL, count, sizeof(tf_ssb_ebt_clock_entry_t), _ebt_compare_entry); int index = tf_util_insert_index(id, count ? work->clock->entries : NULL, count, sizeof(tf_ssb_ebt_clock_entry_t), _ebt_compare_entry);
int64_t out_value = replicate ? ((value << 1) | (receive ? 0 : 1)) : -1; int64_t out_value = entry->out_replicate ? ((value << 1) | (entry->out_receive ? 0 : 1)) : -1;
if (index < count && strcmp(id, work->clock->entries[index].id) == 0) if (index < count && strcmp(id, work->clock->entries[index].id) == 0)
{ {
work->clock->entries[index].value = out_value; work->clock->entries[index].value = out_value;
@ -229,7 +229,7 @@ static void _tf_ssb_ebt_get_send_clock_work(tf_ssb_connection_t* connection, voi
if (entry->in_replicate && !entry->out_replicate) if (entry->in_replicate && !entry->out_replicate)
{ {
requested = tf_resize_vec(requested, (requested_count + 1) * sizeof(tf_ssb_ebt_clock_entry_t)); requested = tf_resize_vec(requested, (requested_count + 1) * sizeof(tf_ssb_ebt_clock_entry_t));
requested[requested_count] = (tf_ssb_ebt_clock_entry_t) { 0 }; requested[requested_count] = (tf_ssb_ebt_clock_entry_t) { .value = -1 };
snprintf(requested[requested_count].id, sizeof(requested[requested_count].id), "%s", entry->id); snprintf(requested[requested_count].id, sizeof(requested[requested_count].id), "%s", entry->id);
requested_count++; requested_count++;
} }
@ -246,7 +246,7 @@ static void _tf_ssb_ebt_get_send_clock_work(tf_ssb_connection_t* connection, voi
uv_mutex_lock(&work->ebt->mutex); uv_mutex_lock(&work->ebt->mutex);
for (int i = 0; i < requested_count; i++) for (int i = 0; i < requested_count; i++)
{ {
_ebt_add_to_clock(work, requested[i].id, requested[i].value, true, true); _ebt_add_to_clock(work, requested[i].id, requested[i].value, requested[i].value >= 0, false);
} }
uv_mutex_unlock(&work->ebt->mutex); uv_mutex_unlock(&work->ebt->mutex);
tf_free(requested); tf_free(requested);