ssb: Adjust the follow/hops policies. Replication defaults to 2 hops, counted in the same way as the docs, and is configurable. #79
Some checks are pending
Build Tilde Friends / Build-All (push) Waiting to run
Some checks are pending
Build Tilde Friends / Build-All (push) Waiting to run
This commit is contained in:
parent
d5bd4c6735
commit
f6d4e934e3
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"type": "tildefriends-app",
|
"type": "tildefriends-app",
|
||||||
"emoji": "🐌",
|
"emoji": "🐌",
|
||||||
"previous": "&Cqu8pxYxC8fBQuUpa3z2kVnX5cqbQ+p5mhqySZwWwb4=.sha256"
|
"previous": "&VCGjLxXNz7S8jDYM0HK+GfHsLujtIRiwYQcIGo5Y9+A=.sha256"
|
||||||
}
|
}
|
||||||
|
@ -221,7 +221,7 @@ class TfElement extends LitElement {
|
|||||||
async load() {
|
async load() {
|
||||||
let whoami = this.whoami;
|
let whoami = this.whoami;
|
||||||
let tags = this.load_recent_tags();
|
let tags = this.load_recent_tags();
|
||||||
let following = await tfrpc.rpc.following([whoami], 2);
|
let following = await tfrpc.rpc.following([whoami], 3);
|
||||||
let users = {};
|
let users = {};
|
||||||
let by_count = [];
|
let by_count = [];
|
||||||
for (let [id, v] of Object.entries(following)) {
|
for (let [id, v] of Object.entries(following)) {
|
||||||
|
@ -2341,7 +2341,7 @@ typedef struct _following_t
|
|||||||
static void _tf_ssb_following_work(tf_ssb_t* ssb, void* user_data)
|
static void _tf_ssb_following_work(tf_ssb_t* ssb, void* user_data)
|
||||||
{
|
{
|
||||||
following_t* following = user_data;
|
following_t* following = user_data;
|
||||||
following->out_following = tf_ssb_db_following_deep(ssb, following->ids, following->ids_count, following->depth);
|
following->out_following = tf_ssb_db_following_deep(ssb, following->ids, following->ids_count, following->depth - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _tf_ssb_following_after_work(tf_ssb_t* ssb, int status, void* user_data)
|
static void _tf_ssb_following_after_work(tf_ssb_t* ssb, int status, void* user_data)
|
||||||
|
@ -978,8 +978,10 @@ static void _tf_ssb_rpc_ebt_replicate_send_clock_work(tf_ssb_connection_t* conne
|
|||||||
tf_ssb_t* ssb = tf_ssb_connection_get_ssb(connection);
|
tf_ssb_t* ssb = tf_ssb_connection_get_ssb(connection);
|
||||||
JSValue full_clock = JS_NewObject(context);
|
JSValue full_clock = JS_NewObject(context);
|
||||||
|
|
||||||
|
int64_t depth = _get_global_setting_int64(ssb, "replication_hops", -1);
|
||||||
|
|
||||||
/* Ask for every identity we know is being followed from local accounts. */
|
/* Ask for every identity we know is being followed from local accounts. */
|
||||||
const char** visible = tf_ssb_db_get_all_visible_identities(ssb, 2);
|
const char** visible = tf_ssb_db_get_all_visible_identities(ssb, depth - 1);
|
||||||
for (int i = 0; visible[i]; i++)
|
for (int i = 0; visible[i]; i++)
|
||||||
{
|
{
|
||||||
int64_t sequence = 0;
|
int64_t sequence = 0;
|
||||||
|
@ -350,6 +350,7 @@ static JSValue _util_defaultGlobalSettings(JSContext* context, JSValueConst this
|
|||||||
{ .name = "room_name", .type = "string", .description = "Name of the room.", .default_value = JS_NewString(context, "tilde friends tunnel") },
|
{ .name = "room_name", .type = "string", .description = "Name of the room.", .default_value = JS_NewString(context, "tilde friends tunnel") },
|
||||||
{ .name = "seeds_host", .type = "string", .description = "Hostname for seed connections.", .default_value = JS_NewString(context, "seeds.tildefriends.net") },
|
{ .name = "seeds_host", .type = "string", .description = "Hostname for seed connections.", .default_value = JS_NewString(context, "seeds.tildefriends.net") },
|
||||||
{ .name = "account_registration", .type = "boolean", .description = "Allow registration of new accounts.", .default_value = JS_TRUE },
|
{ .name = "account_registration", .type = "boolean", .description = "Allow registration of new accounts.", .default_value = JS_TRUE },
|
||||||
|
{ .name = "replication_hops", .type = "integer", .description = "Number of hops to replicate (1 = direct follows, 2 = follows of follows, etc.).", .default_value = JS_NewInt32(context, 2) },
|
||||||
};
|
};
|
||||||
|
|
||||||
JSValue settings = JS_NewObject(context);
|
JSValue settings = JS_NewObject(context);
|
||||||
|
@ -77,16 +77,9 @@ try:
|
|||||||
break
|
break
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
tf_tab_news = wait.until(exists_in_shadow_root(tf_app, By.ID, 'tf-tab-news')).shadow_root
|
wait.until(exists_in_shadow_root(wait.until(exists_in_shadow_root(tf_app, By.ID, 'tf-tab-news')).shadow_root, By.CLASS_NAME, 'tf-profile')).shadow_root.find_element(By.ID, 'edit_profile').click()
|
||||||
while True:
|
wait.until(exists_in_shadow_root(wait.until(exists_in_shadow_root(tf_app, By.ID, 'tf-tab-news')).shadow_root, By.CLASS_NAME, 'tf-profile')).shadow_root.find_element(By.ID, 'name').send_keys('user')
|
||||||
try:
|
wait.until(exists_in_shadow_root(wait.until(exists_in_shadow_root(tf_app, By.ID, 'tf-tab-news')).shadow_root, By.CLASS_NAME, 'tf-profile')).shadow_root.find_element(By.ID, 'save_profile').click()
|
||||||
tf_profile = wait.until(exists_in_shadow_root(tf_tab_news, By.CLASS_NAME, 'tf-profile')).shadow_root
|
|
||||||
tf_profile.find_element(By.ID, 'edit_profile').click()
|
|
||||||
break
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
tf_profile.find_element(By.ID, 'name').send_keys('user')
|
|
||||||
tf_profile.find_element(By.ID, 'save_profile').click()
|
|
||||||
driver.switch_to.default_content()
|
driver.switch_to.default_content()
|
||||||
wait.until(expected_conditions.presence_of_element_located((By.XPATH, '//button[text()="✅ Allow"]'))).click()
|
wait.until(expected_conditions.presence_of_element_located((By.XPATH, '//button[text()="✅ Allow"]'))).click()
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user