Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/wds4/pretty-good

a nostr desktop client for mac, windows and linux, motivated by the desire to build a decentralized web of trust
https://github.com/wds4/pretty-good

dcosl nostr reputation reputation-system web-of-trust

Last synced: about 2 months ago
JSON representation

a nostr desktop client for mac, windows and linux, motivated by the desire to build a decentralized web of trust

Awesome Lists containing this project

README

        

# Pretty Good Apps

A desktop client for linux, mac, and windows, embedded currently with two apps:
- a standard nostr client
- curated lists: an implementation of the [DCoSL](https://github.com/wds4/DCoSL) protocol (decentralized curation of simple lists)


This is a fork of my older project, [electron-nostr](https://github.com/wds4/electron-react-boilerplate-nostr), and is based on [electron-react-boilerplate](https://github.com/electron-react-boilerplate/electron-react-boilerplate).

# Purpose

The goal of this project is to explore two ideas, one more abstract, one more concrete.

### Concrete idea

The immediate goal of this project is to advocate the idea that genuinely decentralized curation of simple lists (DCoSL) is the atomic building block and the defining feature of the decentralized web. A simple list is exactly what it sounds like. Curation using the DCoSL method is a little harder to describe, which is why I built this app, to show it in action. In a nutshell: list curation is handled by each user's web of trust. In the DCoSL method, you are always at the center of your web of trust. No specific protocol, library, token, etc is required to implement the DCoSL method. Nevertheless, I believe it is well defined, with only a small handful of principles (like [this one](https://github.com/WebOfTrustInfo/rwot1-sf/blob/master/Principle-of-Relativity-for-WoT.md)) that must be followed.

I believe I have stripped the DCoSL method down to its bare essentials (though I welcome suggestions how to strip it down further, while retaining its essence). Ultimately, I want other developers to adapt and improve upon the DCoSL method in their own p2p projects. This does not require adoption of any specific library, protocol, etc. It means: identify one (or a few) simple lists in your project (example: a simple list of user profile properties, with the default list being: username, handle, location, description, etc.), the curation of which you'd like to hand over to your users and their communities, and then use the DCoSL method illustrated in this app to allow them to do so. Once your users learn to delegate curation of one simple list, you can add more lists. If lists are chosen carefully, this can become quite powerful.

I hope to convince developers that:

  • DCoSL is substantive and well defined.

  • DCoSL (single-list) is relatively straightforward to implement.

  • Scalable (multiple interacting lists) DCoSL is versatile and powerful, much more than it would seem at first glance.

  • Without DCoSL or something similar, there is no truly decentralized web.

  • As of May 2023, zero major projects (to my knowledge) have implemented single-list DCoSL or anything functionally equivalent; certainly no one has implemented scalable DCoSL. Many close, but no cigars.

  • On the topics of power, versatility, and scalability, consider that a simple "parent" list can be enriched (turned from a "simple" into a "complex" list) through utilization of multiple additional simple lists which act as accessories to the parent list. A simple list of nostr relays, for example, can be converted into a complex list by adding a simple list of subsets (default list: paid vs free), a simple list of relay properties (default list: name, url, array of supported nips, etc), and so on.

    Also consider that two simple lists is sufficient to specify a graph: one list for nodes, and one list for edges. (Optionally, a third and fourth list for node types and edge types.) A graph is a versatile tool, able to represent a data model (e.g. a verifiable credential), standards and specifications, an ontology, a schema, a context tree, etc. Currently, these tend to be curated by developer teams or by organizations such as the World Wide Web Consortium.

    But consider that anything that can be represented as a graph can in turn be represented as a small handful of simple lists, one, several, or all of which can be curated by your web of trust (WoT) using the DCoSL method. Alice's WoT and Bob's WoT, though they are not identical, are very likely to have significant overlap. For any given list, although there is no guarantee, there is a good chance that Alice and Bob will end up using the exact same (or at least almost the same) list! This is a vitally important attribute of the DCoSL method, one that I call loose consensus. You'll want to think deeply about loose consensus before incorporating decentralized list curation to your p2p platform, app or project.

    ### Abstract idea

    The broader goal of this project is to explore a theoretical model for decentralized knowledge representation and curation that I (currently) call the threaded tapestry. I argue the threaded tapestry model is particularly well suited to decentralized and distributed systems such as the decentralized web. I conjecture that some version of this model may have already been implemented by nature to represent and curate knowledge in the brain.

    What is our vision for the decentralized web? Billions of people, millions of developers, free to associate and interact as they wish. As cypherpunks we strive to build tools to enable their spontaneous, dynamic organization into networks both large and small, with or without overlap, each one of which is capable of highly sophisticated intra-network communication and coordinated action without ever putting one person, developer, or entity in charge of any given network, including the network's tools for communication and interaction.

    What is the brain? Billions of neurons, millions of cortical columns; capable of dynamic organization into specialized networks both large and small, sometimes overlapping, capable of highly sophisticated intra-network communication and coordinated action without ever putting a single neuron, column, or other discrete entity in charge of any given network. How does this work? In a nutshell: we do not know! Indeed, some of our leading theories could be described as unfalsifiable, not even wrong.

    Could it be that the decentralized web and the central nervous system will end up implementing more or less the same solution to more or less the same problem? How fucking cool would that be??!?

    ## Status of this project

    As of May 2023: *** still in alpha ***
    This is not quite ready for use by regular users. Still too many bugs and it's not always obvious how to find some of the features that do work. To any devs who are interested in decentralized web of trust: I am happy to get on a video call and walk you through how this works and what it can do. My long term goal is to see widespread adoption of the ideas and methods illustrated in this repo. (Not necessarily my code, but the ideas behind the code.)

    ## Nostr

    Basic nostr functionality is currently available. Features include:

  • create new profile
  • import profile
  • edit profile
  • manage multiple profiles
  • main feed
  • following, extended following, and "firehose" options all available for the main feed
  • post new note
  • find new users
  • look at user profiles
  • send / receive direct messages
  • manage relays

    This is still very much in alpha. Depending on their states of development, some features may be hidden behind developer modes which can be turned on/off in Pretty Good settings. Expect some things to break, even if they are currently working.

    Incomplete list of known issues:

  • extended following list seems to freeze up -- authors list too big?
  • view thread does not always pull the entire thread
  • likes, reposts, and zaps are not yet implemented
  • for the main feed, data persistence using redux works but is exceedingly slow; therefore currently off by default (can turn it on in settings)

    ## Curated Lists: decentralized web of trust

    You won't find this anywhere else.

    Curation of items on a list by a decentralized web of trust. This is the simplest demonstration of the threaded tapestry model I have been able to devise so far that demonstrates knowledge representation as well as knowledge curation.

    Current features:

  • anyone can create a new list
  • anyone can add items to any list
  • anyone can endorse (thumbs up or down) any item on any list
  • anyone can endorse (thumbs up or down) any user as a trusted curator of a given list
  • calculate weighted average scores of list items
  • calculate weighted average scores of curators (to determine influence)
  • graphical visualization of how average scores are calculated (see image below)

    Incomplete

  • listener functions need to be moved to the background
  • lots of other things

    Known issues/bugs

  • summary views are incomplete and/or hard to find
  • several deprecated pages that need to be removed
  • may others, to be added

    In the example shown below (currently live, although still in testnet), your web of trust tells you which nostr clients are the best nostr clients! Hooray Iris!

    Anyone can rate items on any list. For now, ratings consist of a simple thumbs up or down. The system is designed so that more complex ratings (e.g., rate from 1-5 stars or rate 0-100) will be simple to incorporate.

    Users can designate other users to be trusted curators. Again, for now, attestations are simple thumbs up or down. Attestations are designated to apply to a specified list (currently working) or to lists in general (in progress).

    One of the principle functions of the grapevine is to resist influence by sybil attacks or other bad actors. Multiple adjustable parameters are provided, some of which are depicted in the screenshots above, including the default user parameters which determine how much influence to allow for completely unvetted users.

    There is no universal arbiter of truth. Instead, all calculations are performed from the perspective of a given user, the "seed user." By default, the seed user is YOU, but different seed users can be selected, as depicted in the screenshot.

    ## the threaded tapestry model ##

    The threaded tapestry model is broken down into two parts: 1) decentralized knowledge representation and 2) decentralized knowledge curation.

    ### decentralized knowledge representation: the concept graph ###

    A list is a stripped-down version of what I call a concept. Eventually, this will mature into what I call the concept graph.

    ### decentralized knowledge curation: the grapevine

    When calculating weighted average scores, the trick is to determine how much weight to give to any single user's rating, to do so in a way that is contextual, and to do so in a way that resists sybil and other forms of attacks. Calculation of these weights is the purvue of the grapevine. A working implementation of the grapevine is seen in the above screenshots.

    ## abstract overview of the threaded tapestry model

    ### knowledge representation in the TT model

    Knowledge is represented in a graph, where nodes in the graph are chunks of information, and edges in the graph are specialised relationships between those chunks of information. In the decentralized web, a chunk is typically a file. (I speculate that in the cerebral cortex -- another example of a decentralized, distributed system -- a cortical column [an arrangement of typically about 1000 neurons] may play the role of a chunk. Axonal projections from one column directly to another would naturally function as edges.)

    Any relationship between two chunks is called a hop.

    Any continguous series of hops is called a thread.

    There are many categories of threads. The threaded tapestry model relies upon a special category of thread, called the class thread. The hallmark feature of a class thread is that the node at one end of the thread (the class node) provides information on how information is encoded in the node at the opposite end of the thread (the instance node).

    As an example of a class thread, consider the class node "dog" and the instance node "Fido," each of which is a JSON file, with the class node stipulating that each instance node contains a property called "name" (Fido) and "owner" (Alice).

    Any given class node likely gives rise to multiple class threads. The collection of all class threads emanating from one class node is called a concept.

    The class thread is so named because it may be thought of as a generalization of the notion of a class in an object oriented programming language such as javascript. In the above example, consider a javascript Class called "dog" with instances "Fido," "Spot," etc.

    Class threads connect to each other in a variety of ways. A collection of interconnected class threads may be referred to as a tapestry, or (equivalently) a concept graph. Class threads provide the scaffolding for the concept graph. Although other categories of threads exist, the class thread is the most important category of thread.

    ### knowledge curation in the TT model

    (best way to understand this is to see it in action. Which is why I'm coding this app. See the screenshots above showing how the grapevine curates a list.)

    ## Install Pretty Good

    Clone this repo and install dependencies:

    ```bash
    git clone --depth 1 --branch main https://github.com/wds4/pretty-good.git pretty-good
    cd pretty-good
    npm install
    ```

    You MAY also need to do this to install sqlite3:

    ```bash
    cd release/app
    npm install sqlite3
    npm run postinstall
    cd ../..
    ```

    ## Development

    Start the app in the `dev` environment:

    ```bash
    npm start
    ```

    ## Packaging for Production

    To package apps for the local platform:

    ```bash
    npm run package
    ```

    The packaged app can now be found in release/app/build.

    For more packaging options, including packaging for other platforms and debugging production build with devtools, see [erb packaging options](https://electron-react-boilerplate.js.org/docs/packaging).

    ## License

    GNU Affero General Public License v3.0 © [Pretty Good](https://github.com/wds4/pretty-good)