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
use fxhash::FxHashSet;

use crate::crypto::AteHash;
use crate::event::*;
use crate::{header::*, meta::MetaAuthorization};

use super::*;

#[derive(Debug, Clone, Hash, Eq, PartialEq)]
pub struct UniqueEvent {
    key: PrimaryKey,
    auth: Option<MetaAuthorization>,
}

#[derive(Default, Clone)]
pub struct RemoveDuplicatesCompactor {
    keep: FxHashSet<AteHash>,
    drop: FxHashSet<AteHash>,
    already: FxHashSet<UniqueEvent>,
    parent_override: FxHashSet<PrimaryKey>,
}

impl EventCompactor for RemoveDuplicatesCompactor {
    fn clone_compactor(&self) -> Option<Box<dyn EventCompactor>> {
        Some(Box::new(Self::default()))
    }

    fn relevance(&self, header: &EventHeader) -> EventRelevance {
        if self.keep.contains(&header.raw.event_hash) {
            return EventRelevance::Keep;
        }
        if self.drop.contains(&header.raw.event_hash) {
            return EventRelevance::Drop;
        }

        if header.meta.get_data_key().is_some() {
            return EventRelevance::Keep;
        } else {
            return EventRelevance::Abstain;
        }
    }

    fn feed(&mut self, header: &EventHeader, _keep: bool) {
        let key = match header.meta.get_data_key() {
            Some(key) => key,
            None => {
                return;
            }
        };

        if let Some(parent) = header.meta.get_parent() {
            self.parent_override.insert(parent.vec.parent_id);
        }

        let unique = UniqueEvent {
            key,
            auth: header.meta.get_authorization().map(|a| a.clone()),
        };

        let keep = if self.already.contains(&unique) == false {
            self.already.insert(unique);
            self.parent_override.remove(&key);
            true
        } else if self.parent_override.remove(&key) {
            true
        } else {
            false
        };

        if keep {
            self.keep.insert(header.raw.event_hash);
        } else {
            self.drop.insert(header.raw.event_hash);
        }
    }

    fn name(&self) -> &str {
        "remove-duplicates-compactor"
    }
}