aboutsummaryrefslogtreecommitdiff
path: root/content/activity_info_server.js
blob: 81a25fbc8b609d7ce7fb6f0775e6e8d97b0fb91c (about) (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/**
 * part of Hachette
 * Informing about activities performed by content script (script injection,
 * script blocking).
 *
 * Copyright (C) 2021 Wojtek Kosior
 * Redistribution terms are gathered in the `copyright' file.
 */

/*
 * IMPORTS_START
 * IMPORT listen_for_connection
 * IMPORT CONNECTION_TYPE
 * IMPORT repo_query
 * IMPORT subscribe_repo_query_results
 * IMPORT unsubscribe_repo_query_results
 * IMPORTS_END
 */

var activities = [];
var ports = new Set();

function report_activity_oneshot(name, data, port)
{
    port.postMessage([name, data]);
}

function report_activity(name, data)
{
    const activity = [name, data];
    activities.push(activity);

    for (const port of ports)
	port.postMessage(activity);
}

function report_script(script_data)
{
    report_activity("script", script_data);
}

function report_settings(settings)
{
    report_activity("settings", settings);
}

function report_repo_query_action(update, port)
{
    report_activity_oneshot("repo_query_action", update, port);
}

function trigger_repo_query(query_specifier)
{
    repo_query(...query_specifier);
}

function handle_disconnect(port, report_action)
{
    ports.delete(port)
    unsubscribe_repo_query_results(report_action);
}

function new_connection(port)
{
    console.log("new activity info connection!");

    ports.add(port);

    for (const activity of activities)
	port.postMessage(activity);

    const report_action = u => report_repo_query_action(u, port);
    subscribe_repo_query_results(report_action);

    /*
     * So far the only thing we expect to receive is repo query order. Once more
     * possibilities arrive, we will need to complicate this listener.
     */
    port.onMessage.addListener(trigger_repo_query);

    port.onDisconnect.addListener(() => handle_disconnect(port, report_action));
}

function start_activity_info_server()
{
    listen_for_connection(CONNECTION_TYPE.ACTIVITY_INFO, new_connection);
}

/*
 * EXPORTS_START
 * EXPORT start_activity_info_server
 * EXPORT report_script
 * EXPORT report_settings
 * EXPORTS_END
 */