2023-06-07 01:31:03 +00:00
<!doctype html>
< html class = "no-js" lang = "en" >
< head > < meta charset = "utf-8" / >
< meta name = "viewport" content = "width=device-width,initial-scale=1" / >
< meta name = "color-scheme" content = "light dark" > < meta name = "generator" content = "Docutils 0.19: https://docutils.sourceforge.io/" / >
2023-06-20 02:21:17 +00:00
< link rel = "index" title = "Index" href = "../../genindex.html" / > < link rel = "search" title = "Search" href = "../../search.html" / > < link rel = "next" title = "Matrix" href = "matrix.html" / > < link rel = "prev" title = "ActivityPub" href = "activitypub.html" / >
< link rel = "canonical" href = "/docs/comparison/social/ssb.html" / >
2023-06-07 01:31:03 +00:00
<!-- Generated with Sphinx 6.2.1 and Furo 2023.05.20 -->
2023-06-09 04:19:31 +00:00
< title > Secure Scuttlebutt - p2p-ld 0.1.0 documentation< / title >
2023-06-20 02:21:17 +00:00
< link rel = "stylesheet" type = "text/css" href = "../../_static/pygments.css" / >
< link rel = "stylesheet" type = "text/css" href = "../../_static/styles/furo.css?digest=e6660623a769aa55fea372102b9bf3151b292993" / >
2023-06-28 04:35:44 +00:00
< link rel = "stylesheet" type = "text/css" href = "../../_static/design-style.1e8bd061cd6da7fc9cf755528e8ffc24.min.css" / >
2023-06-20 02:21:17 +00:00
< link rel = "stylesheet" type = "text/css" href = "../../_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" / >
2023-06-07 01:31:03 +00:00
< style >
body {
--color-code-background: #f8f8f8;
--color-code-foreground: black;
}
@media not print {
body[data-theme="dark"] {
2023-07-01 06:59:21 +00:00
--color-code-background: #0d1117;
--color-code-foreground: #e6edf3;
2023-06-07 01:31:03 +00:00
}
@media (prefers-color-scheme: dark) {
body:not([data-theme="light"]) {
2023-07-01 06:59:21 +00:00
--color-code-background: #0d1117;
--color-code-foreground: #e6edf3;
2023-06-07 01:31:03 +00:00
}
}
}
< / style > < / head >
< body >
< script >
document.body.dataset.theme = localStorage.getItem("theme") || "auto";
< / script >
< svg xmlns = "http://www.w3.org/2000/svg" style = "display: none;" >
< symbol id = "svg-toc" viewBox = "0 0 24 24" >
< title > Contents< / title >
< svg stroke = "currentColor" fill = "currentColor" stroke-width = "0" viewBox = "0 0 1024 1024" >
< path d = "M408 442h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm-8 204c0 4.4 3.6 8 8 8h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56zm504-486H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 632H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM115.4 518.9L271.7 642c5.8 4.6 14.4.5 14.4-6.9V388.9c0-7.4-8.5-11.5-14.4-6.9L115.4 505.1a8.74 8.74 0 0 0 0 13.8z" / >
< / svg >
< / symbol >
< symbol id = "svg-menu" viewBox = "0 0 24 24" >
< title > Menu< / title >
< svg xmlns = "http://www.w3.org/2000/svg" viewBox = "0 0 24 24" fill = "none" stroke = "currentColor"
stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather-menu">
< line x1 = "3" y1 = "12" x2 = "21" y2 = "12" > < / line >
< line x1 = "3" y1 = "6" x2 = "21" y2 = "6" > < / line >
< line x1 = "3" y1 = "18" x2 = "21" y2 = "18" > < / line >
< / svg >
< / symbol >
< symbol id = "svg-arrow-right" viewBox = "0 0 24 24" >
< title > Expand< / title >
< svg xmlns = "http://www.w3.org/2000/svg" viewBox = "0 0 24 24" fill = "none" stroke = "currentColor"
stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather-chevron-right">
< polyline points = "9 18 15 12 9 6" > < / polyline >
< / svg >
< / symbol >
< symbol id = "svg-sun" viewBox = "0 0 24 24" >
< title > Light mode< / title >
< svg xmlns = "http://www.w3.org/2000/svg" viewBox = "0 0 24 24" fill = "none" stroke = "currentColor"
stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" class="feather-sun">
< circle cx = "12" cy = "12" r = "5" > < / circle >
< line x1 = "12" y1 = "1" x2 = "12" y2 = "3" > < / line >
< line x1 = "12" y1 = "21" x2 = "12" y2 = "23" > < / line >
< line x1 = "4.22" y1 = "4.22" x2 = "5.64" y2 = "5.64" > < / line >
< line x1 = "18.36" y1 = "18.36" x2 = "19.78" y2 = "19.78" > < / line >
< line x1 = "1" y1 = "12" x2 = "3" y2 = "12" > < / line >
< line x1 = "21" y1 = "12" x2 = "23" y2 = "12" > < / line >
< line x1 = "4.22" y1 = "19.78" x2 = "5.64" y2 = "18.36" > < / line >
< line x1 = "18.36" y1 = "5.64" x2 = "19.78" y2 = "4.22" > < / line >
< / svg >
< / symbol >
< symbol id = "svg-moon" viewBox = "0 0 24 24" >
< title > Dark mode< / title >
< svg xmlns = "http://www.w3.org/2000/svg" viewBox = "0 0 24 24" fill = "none" stroke = "currentColor"
stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" class="icon-tabler-moon">
< path stroke = "none" d = "M0 0h24v24H0z" fill = "none" / >
< path d = "M12 3c.132 0 .263 0 .393 0a7.5 7.5 0 0 0 7.92 12.446a9 9 0 1 1 -8.313 -12.454z" / >
< / svg >
< / symbol >
< symbol id = "svg-sun-half" viewBox = "0 0 24 24" >
< title > Auto light/dark mode< / title >
< svg xmlns = "http://www.w3.org/2000/svg" viewBox = "0 0 24 24" fill = "none" stroke = "currentColor"
stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" class="icon-tabler-shadow">
< path stroke = "none" d = "M0 0h24v24H0z" fill = "none" / >
< circle cx = "12" cy = "12" r = "9" / >
< path d = "M13 12h5" / >
< path d = "M13 15h4" / >
< path d = "M13 18h1" / >
< path d = "M13 9h4" / >
< path d = "M13 6h1" / >
< / svg >
< / symbol >
< / svg >
< input type = "checkbox" class = "sidebar-toggle" name = "__navigation" id = "__navigation" >
< input type = "checkbox" class = "sidebar-toggle" name = "__toc" id = "__toc" >
< label class = "overlay sidebar-overlay" for = "__navigation" >
< div class = "visually-hidden" > Hide navigation sidebar< / div >
< / label >
< label class = "overlay toc-overlay" for = "__toc" >
< div class = "visually-hidden" > Hide table of contents sidebar< / div >
< / label >
< div class = "page" >
< header class = "mobile-header" >
< div class = "header-left" >
< label class = "nav-overlay-icon" for = "__navigation" >
< div class = "visually-hidden" > Toggle site navigation sidebar< / div >
< i class = "icon" > < svg > < use href = "#svg-menu" > < / use > < / svg > < / i >
< / label >
< / div >
< div class = "header-center" >
2023-06-20 02:21:17 +00:00
< a href = "../../index.html" > < div class = "brand" > p2p-ld 0.1.0 documentation< / div > < / a >
2023-06-07 01:31:03 +00:00
< / div >
< div class = "header-right" >
< div class = "theme-toggle-container theme-toggle-header" >
< button class = "theme-toggle" >
< div class = "visually-hidden" > Toggle Light / Dark / Auto color theme< / div >
< svg class = "theme-icon-when-auto" > < use href = "#svg-sun-half" > < / use > < / svg >
< svg class = "theme-icon-when-dark" > < use href = "#svg-moon" > < / use > < / svg >
< svg class = "theme-icon-when-light" > < use href = "#svg-sun" > < / use > < / svg >
< / button >
< / div >
2023-06-19 19:04:24 +00:00
< label class = "toc-overlay-icon toc-header-icon" for = "__toc" >
2023-06-07 01:31:03 +00:00
< div class = "visually-hidden" > Toggle table of contents sidebar< / div >
< i class = "icon" > < svg > < use href = "#svg-toc" > < / use > < / svg > < / i >
< / label >
< / div >
< / header >
< aside class = "sidebar-drawer" >
< div class = "sidebar-container" >
2023-06-20 02:21:17 +00:00
< div class = "sidebar-sticky" > < a class = "sidebar-brand" href = "../../index.html" >
2023-06-07 01:31:03 +00:00
< span class = "sidebar-brand-text" > p2p-ld 0.1.0 documentation< / span >
2023-06-20 02:21:17 +00:00
< / a > < form class = "sidebar-search-container" method = "get" action = "../../search.html" role = "search" >
2023-06-07 01:31:03 +00:00
< input class = "sidebar-search" placeholder = "Search" name = "q" aria-label = "Search" >
< input type = "hidden" name = "check_keywords" value = "yes" >
< input type = "hidden" name = "area" value = "default" >
< / form >
< div id = "searchbox" > < / div > < div class = "sidebar-scroll" > < div class = "sidebar-tree" >
2023-06-07 02:11:30 +00:00
< p class = "caption" role = "heading" > < span class = "caption-text" > Introduction< / span > < / p >
< ul class = "current" >
2023-06-20 02:21:17 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../../overview.html" > Overview< / a > < / li >
< li class = "toctree-l1 current has-children" > < a class = "reference internal" href = "../index.html" > Comparison< / a > < input checked = "" class = "toctree-checkbox" id = "toctree-checkbox-1" name = "toctree-checkbox-1" role = "switch" type = "checkbox" / > < label for = "toctree-checkbox-1" > < div class = "visually-hidden" > Toggle navigation of Comparison< / div > < i class = "icon" > < svg > < use href = "#svg-arrow-right" > < / use > < / svg > < / i > < / label > < ul class = "current" >
< li class = "toctree-l2 has-children" > < a class = "reference internal" href = "../p2p/index.html" > P2P< / a > < input class = "toctree-checkbox" id = "toctree-checkbox-2" name = "toctree-checkbox-2" role = "switch" type = "checkbox" / > < label for = "toctree-checkbox-2" > < div class = "visually-hidden" > Toggle navigation of P2P< / div > < i class = "icon" > < svg > < use href = "#svg-arrow-right" > < / use > < / svg > < / i > < / label > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../p2p/bittorrent.html" > BitTorrent< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../p2p/ipfs.html" > IPFS< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../p2p/hypercore.html" > Dat/Hypercore< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../p2p/spritely.html" > Spritely/Goblin< / a > < / li >
2023-06-09 04:19:31 +00:00
< / ul >
< / li >
2023-06-20 02:21:17 +00:00
< li class = "toctree-l2 current has-children" > < a class = "reference internal" href = "index.html" > Social< / a > < input checked = "" class = "toctree-checkbox" id = "toctree-checkbox-3" name = "toctree-checkbox-3" role = "switch" type = "checkbox" / > < label for = "toctree-checkbox-3" > < div class = "visually-hidden" > Toggle navigation of Social< / div > < i class = "icon" > < svg > < use href = "#svg-arrow-right" > < / use > < / svg > < / i > < / label > < ul class = "current" >
< li class = "toctree-l3" > < a class = "reference internal" href = "activitypub.html" > ActivityPub< / a > < / li >
< li class = "toctree-l3 current current-page" > < a class = "current reference internal" href = "#" > Secure Scuttlebutt< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "matrix.html" > Matrix< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "at_protocol.html" > AT Protocol/Bluesky< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "nostr.html" > Nostr< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "xmpp.html" > XMPP< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2 has-children" > < a class = "reference internal" href = "../ld/index.html" > Linked Data< / a > < input class = "toctree-checkbox" id = "toctree-checkbox-4" name = "toctree-checkbox-4" role = "switch" type = "checkbox" / > < label for = "toctree-checkbox-4" > < div class = "visually-hidden" > Toggle navigation of Linked Data< / div > < i class = "icon" > < svg > < use href = "#svg-arrow-right" > < / use > < / svg > < / i > < / label > < ul >
2023-06-28 04:35:44 +00:00
< li class = "toctree-l3" > < a class = "reference internal" href = "../ld/rdf.html" > RDF and Friends< / a > < / li >
2023-06-20 02:21:17 +00:00
< li class = "toctree-l3" > < a class = "reference internal" href = "../ld/solid.html" > SOLID< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../ld/ld_fragments.html" > Linked Data Fragments< / a > < / li >
2023-07-01 06:59:21 +00:00
< li class = "toctree-l3" > < a class = "reference internal" href = "../ld/hdt.html" > HDT< / a > < / li >
2023-06-20 02:21:17 +00:00
< li class = "toctree-l3" > < a class = "reference internal" href = "../ld/ld_platform.html" > Linked Data Platform< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../ld/nanopubs.html" > NanoPubs< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2 has-children" > < a class = "reference internal" href = "../data/index.html" > Data Structures< / a > < input class = "toctree-checkbox" id = "toctree-checkbox-5" name = "toctree-checkbox-5" role = "switch" type = "checkbox" / > < label for = "toctree-checkbox-5" > < div class = "visually-hidden" > Toggle navigation of Data Structures< / div > < i class = "icon" > < svg > < use href = "#svg-arrow-right" > < / use > < / svg > < / i > < / label > < ul >
2023-07-01 06:59:21 +00:00
< li class = "toctree-l3" > < a class = "reference internal" href = "../data/datalad.html" > DataLad< / a > < / li >
2023-06-20 02:21:17 +00:00
< li class = "toctree-l3" > < a class = "reference internal" href = "../data/dmc.html" > DMC< / a > < / li >
2023-07-01 06:59:21 +00:00
< li class = "toctree-l3" > < a class = "reference internal" href = "../data/eris.html" > ERIS< / a > < / li >
2023-11-28 07:26:49 +00:00
< li class = "toctree-l3" > < a class = "reference internal" href = "../data/graphdb.html" > Graph Databases< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../data/sqlite.html" > SQLite< / a > < / li >
2023-06-20 02:21:17 +00:00
< / ul >
< / li >
< / ul >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../p2p_concepts.html" > P2P Concepts< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../out_of_scope.html" > Out of Scope< / a > < / li >
2023-06-07 02:11:30 +00:00
< / ul >
< p class = "caption" role = "heading" > < span class = "caption-text" > Protocol< / span > < / p >
< ul >
2023-06-20 02:21:17 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../../definitions.html" > 1. Definitions< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../protocol.html" > 2. Protocol< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../identity.html" > 3. Identity< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../discovery.html" > 4. Discovery< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../data_structures.html" > 5. Data Structures< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../vocabulary.html" > 6. Vocabulary< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../querying.html" > 7. Querying< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../encryption.html" > 8. Encryption< / a > < / li >
2023-11-28 07:26:49 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../../federation.html" > 9. Federation< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../backwards_compatibility.html" > 10. Backwards Compatibility< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../evolvability.html" > 11. Evolvability< / a > < / li >
2023-06-07 02:11:30 +00:00
< / ul >
< p class = "caption" role = "heading" > < span class = "caption-text" > Ecosystem< / span > < / p >
< ul >
2023-06-20 02:21:17 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../../triplets.html" > Triplets< / a > < / li >
2023-07-01 06:59:21 +00:00
< li class = "toctree-l1 has-children" > < a class = "reference internal" href = "../../codecs/index.html" > Codecs< / a > < input class = "toctree-checkbox" id = "toctree-checkbox-6" name = "toctree-checkbox-6" role = "switch" type = "checkbox" / > < label for = "toctree-checkbox-6" > < div class = "visually-hidden" > Toggle navigation of Codecs< / div > < i class = "icon" > < svg > < use href = "#svg-arrow-right" > < / use > < / svg > < / i > < / label > < ul >
< li class = "toctree-l2" > < a class = "reference internal" href = "../../codecs/hdf5.html" > HDF5< / a > < / li >
< / ul >
< / li >
2023-06-20 02:21:17 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../../translation/index.html" > Translation< / a > < / li >
2023-06-07 02:11:30 +00:00
< / ul >
< p class = "caption" role = "heading" > < span class = "caption-text" > Drafting< / span > < / p >
< ul >
2023-06-20 02:21:17 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../../design.html" > Design Decisions< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../sketchpad.html" > Sketchpad< / a > < / li >
2023-06-07 02:11:30 +00:00
< / ul >
< p class = "caption" role = "heading" > < span class = "caption-text" > Meta< / span > < / p >
< ul >
2023-06-20 02:21:17 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../../genindex.html" > Index< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../references.html" > References< / a > < / li >
2023-11-28 07:26:49 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../../todo.html" > TODO< / a > < / li >
2023-06-07 02:11:30 +00:00
< / ul >
2023-06-07 01:31:03 +00:00
< / div >
< / div >
< / div >
< / div >
< / aside >
< div class = "main" >
< div class = "content" >
< div class = "article-container" >
< a href = "#" class = "back-to-top muted-link" >
< svg xmlns = "http://www.w3.org/2000/svg" viewBox = "0 0 24 24" >
< path d = "M13 20h-2V8l-5.5 5.5-1.42-1.42L12 4.16l7.92 7.92-1.42 1.42L13 8v12z" > < / path >
< / svg >
< span > Back to top< / span >
< / a >
< div class = "content-icon-container" >
< div class = "theme-toggle-container theme-toggle-content" >
< button class = "theme-toggle" >
< div class = "visually-hidden" > Toggle Light / Dark / Auto color theme< / div >
< svg class = "theme-icon-when-auto" > < use href = "#svg-sun-half" > < / use > < / svg >
< svg class = "theme-icon-when-dark" > < use href = "#svg-moon" > < / use > < / svg >
< svg class = "theme-icon-when-light" > < use href = "#svg-sun" > < / use > < / svg >
< / button >
< / div >
2023-06-19 19:04:24 +00:00
< label class = "toc-overlay-icon toc-content-icon" for = "__toc" >
2023-06-07 01:31:03 +00:00
< div class = "visually-hidden" > Toggle table of contents sidebar< / div >
< i class = "icon" > < svg > < use href = "#svg-toc" > < / use > < / svg > < / i >
< / label >
< / div >
< article role = "main" >
2023-06-09 04:19:31 +00:00
< section id = "secure-scuttlebutt" >
2023-06-20 02:21:17 +00:00
< span id = "ssb" > < / span > < span id = "index-0" > < / span > < h1 > Secure Scuttlebutt< a class = "headerlink" href = "#secure-scuttlebutt" title = "Permalink to this heading" > #< / a > < / h1 >
2023-06-19 19:04:24 +00:00
< section id = "feeds-metafeeds" >
< h2 > Feeds & Metafeeds< a class = "headerlink" href = "#feeds-metafeeds" title = "Permalink to this heading" > #< / a > < / h2 >
< ul class = "simple" >
< li > < p > Peers maintain a list of feeds they subscribe to< / p > < / li >
< li > < p > When peers connect, they ask for updates to subscribed feeds< / p > < / li >
< li > < p > Metafeeds can provide metadata about other feeds, and can form a tree structure with other Metafeeds as subfeeds.< / p >
< ul >
< li > < p > < span class = "target" id = "index-1" > < / span > Bencoded rather than JSON.< / p > < / li >
< / ul >
< / li >
< / ul >
< div class = "mermaid" >
flowchart LR
subgraph Main [Main Feed]
mf[" `Main Feed Posts
*metafeed/announce*
message`" ]
end
subgraph Meta [Meta feed]
direction TB
mf1[" `Metafeed posts
*metafeed/add/existing
message`" ]
mf2[" `Metafeed posts
*metafeed/add/existing
message`" ]
mf3[" `Metafeed posts
*metafeed/add/derived
message`" ]
mf4[" `Metafeed posts
*metafeed/add/existing
message`" ]
mf1 --> mf2
mf2 --> mf3
mf3 --> mf4
end
subgraph SubfeedA [Subfeed A]
direction LR
sfa1[" `Application specific
message in subfeed`" ]
sfa2[" `Application specific
message in subfeed`" ]
sfa1 --> sfa2
end
subgraph SubfeedB [Subfeed B]
direction LR
sfb1[" `Application specific
message in subfeed`" ]
sfb2[" `Application specific
message in subfeed`" ]
sfb1 --> sfb2
end
subgraph SubfeedC [Subfeed C]
direction LR
sfc1[" `Application specific
message in subfeed`" ]
sfc2[" `Application specific
message in subfeed`" ]
sfc1 --> sfc2
end
subgraph SubfeedD [Subfeed D]
direction LR
sfd1[" `Application specific
message in subfeed`" ]
sfd2[" `Application specific
message in subfeed`" ]
sfd1 --> sfd2
end
Main --> Meta
Meta --> SubfeedA
Meta --> SubfeedB
Meta --> SubfeedC
Meta --> SubfeedD
< / div > < p > Uses for metafeeds< / p >
< ul class = "simple" >
< li > < p > Storing multiple network identities with a special feed off the user’ s root metafeed. (contents of metafeed entries can be encrypted)< / p > < / li >
< li > < p > Allow for multiple devices to use the same identity - < a class = "reference external" href = "https://github.com/ssbc/fusion-identity-spec" > https://github.com/ssbc/fusion-identity-spec< / a > < / p >
< ul >
< li > < p > Device A < code class = "docutils literal notranslate" > < span class = "pre" > invite< / span > < / code > s Device B to identity< / p > < / li >
< li > < p > Device B < code class = "docutils literal notranslate" > < span class = "pre" > consent< / span > < / code > s< / p > < / li >
< li > < p > Device A < code class = "docutils literal notranslate" > < span class = "pre" > entrust< / span > < / code > s phone with private key< / p > < / li >
< li > < p > Device B posts a < code class = "docutils literal notranslate" > < span class = "pre" > proof-of-key< / span > < / code > message< / p > < / li >
< li > < p > If device B lost, < code class = "docutils literal notranslate" > < span class = "pre" > tombstone< / span > < / code > the fusion identity message< / p > < / li >
< / ul >
< / li >
< / ul >
< / section >
2023-06-20 02:21:17 +00:00
< section id = "implementations" >
< h2 > Implementations< a class = "headerlink" href = "#implementations" title = "Permalink to this heading" > #< / a > < / h2 >
< section id = "manyverse" >
< span id = "index-2" > < / span > < h3 > Manyverse< a class = "headerlink" href = "#manyverse" title = "Permalink to this heading" > #< / a > < / h3 >
< / section >
< / section >
2023-06-19 19:04:24 +00:00
< section id = "references" >
< h2 > References< a class = "headerlink" href = "#references" title = "Permalink to this heading" > #< / a > < / h2 >
< ul class = "simple" >
< li > < p > < a class = "reference external" href = "https://ssbc.github.io/scuttlebutt-protocol-guide/" > https://ssbc.github.io/scuttlebutt-protocol-guide/< / a > < / p > < / li >
< / ul >
< / section >
2023-06-07 01:31:03 +00:00
< / section >
2023-06-07 01:07:35 +00:00
2023-06-07 01:31:03 +00:00
< / article >
< / div >
< footer >
< div class = "related-pages" >
2023-06-09 04:19:31 +00:00
< a class = "next-page" href = "matrix.html" >
2023-06-07 02:11:30 +00:00
< div class = "page-info" >
< div class = "context" >
< span > Next< / span >
< / div >
2023-06-09 04:19:31 +00:00
< div class = "title" > Matrix< / div >
2023-06-07 02:11:30 +00:00
< / div >
< svg class = "furo-related-icon" > < use href = "#svg-arrow-right" > < / use > < / svg >
< / a >
2023-06-09 04:19:31 +00:00
< a class = "prev-page" href = "activitypub.html" >
2023-06-07 02:11:30 +00:00
< svg class = "furo-related-icon" > < use href = "#svg-arrow-right" > < / use > < / svg >
< div class = "page-info" >
< div class = "context" >
< span > Previous< / span >
< / div >
2023-06-09 04:19:31 +00:00
< div class = "title" > ActivityPub< / div >
2023-06-07 02:11:30 +00:00
< / div >
< / a >
2023-06-07 01:31:03 +00:00
< / div >
< div class = "bottom-of-page" >
< div class = "left-details" >
< div class = "copyright" >
Copyright © 2023, Jonny Saunders
2023-06-07 01:07:35 +00:00
< / div >
2023-06-07 01:31:03 +00:00
Made with < a href = "https://www.sphinx-doc.org/" > Sphinx< / a > and < a class = "muted-link" href = "https://pradyunsg.me" > @pradyunsg< / a > 's
< a href = "https://github.com/pradyunsg/furo" > Furo< / a >
< / div >
< div class = "right-details" >
< / div >
2023-06-07 01:07:35 +00:00
< / div >
2023-06-07 01:31:03 +00:00
< / footer >
2023-06-07 01:07:35 +00:00
< / div >
2023-06-19 19:04:24 +00:00
< aside class = "toc-drawer" >
2023-06-07 01:31:03 +00:00
2023-06-19 19:04:24 +00:00
< div class = "toc-sticky toc-scroll" >
< div class = "toc-title-container" >
< span class = "toc-title" >
On this page
< / span >
< / div >
< div class = "toc-tree-container" >
< div class = "toc-tree" >
< ul >
< li > < a class = "reference internal" href = "#" > Secure Scuttlebutt< / a > < ul >
< li > < a class = "reference internal" href = "#feeds-metafeeds" > Feeds & Metafeeds< / a > < / li >
2023-06-20 02:21:17 +00:00
< li > < a class = "reference internal" href = "#implementations" > Implementations< / a > < ul >
< li > < a class = "reference internal" href = "#manyverse" > Manyverse< / a > < / li >
< / ul >
< / li >
2023-06-19 19:04:24 +00:00
< li > < a class = "reference internal" href = "#references" > References< / a > < / li >
< / ul >
< / li >
< / ul >
< / div >
< / div >
< / div >
2023-06-07 01:31:03 +00:00
< / aside >
< / div >
2023-06-20 02:21:17 +00:00
< / div > < script data-url_root = "../../" id = "documentation_options" src = "../../_static/documentation_options.js" > < / script >
< script src = "../../_static/doctools.js" > < / script >
< script src = "../../_static/sphinx_highlight.js" > < / script >
< script src = "../../_static/scripts/furo.js" > < / script >
2023-06-28 04:35:44 +00:00
< script src = "../../_static/design-tabs.js" > < / script >
2023-06-19 19:04:24 +00:00
< script src = "https://unpkg.com/mermaid@10.2.0/dist/mermaid.min.js" > < / script >
< script >
mermaid.initialize({
"startOnLoad":true,
2023-06-20 02:21:17 +00:00
"theme": "dark"
2023-06-19 19:04:24 +00:00
})
< / script >
2023-06-07 01:07:35 +00:00
< / body >
2023-06-07 01:31:03 +00:00
< / html >