/r/Rad_Decentralization
Subverting traditional hierarchical systems in favor of a more resilient, innovative, networked, transparent and sustainable world.
Radical Decentralization - The Nature of the Future
Welcome to /r/Rad_Decentralization
This subreddit is dedicated to exploring the new Decentralization Revolution and how it's emerging through technology, politics, society and life.
Decentralized technologies are being developed in almost every industry and market worldwide, in both physical and digital forms. Collectively, these technologies have the potential to cause a "radical" shift from the status quo, hence the name: Radical Decentralization.
We welcome anything that has to do with subverting traditional hierarchical systems in favor of a more resilient, innovative, networked, transparent and sustainable future.
Enjoy!
Vision
Ray Kurzweil - On Decentralization
Andreas Antonopoulos - On Decentralization
Aldous Huxley - On Decentralization
Jeremy Rifkin - Global Networking
Story
We are privileged to be living in the midst of the greatest transformation in the history of mankind. After muddling through the controlled and structured television era, we have each gained a planetary voice and now have undreamed knowledge and resources at our fingertips.
Only twenty years ago all important media were one-way mass media: TV, radio, newspapers and magazines—giant corporations pushing their agendas to the masses.
All communication flowed down from the top of the pyramid, it was nearly impossible to have your voice heard. We were passive receivers of whatever they wanted to push on us.
In the blink of an eye, all that has changed. Information and communication have gone free. The Internet has allowed a complete rewiring of mankind. Cell phones have fully penetrated the developing world. In a couple more years, virtually everyone over the age of 10 on the entire planet will soon have the full power of the Internet in the palm of their hands.
This amounts to a massive decentralization of power, shifting away from the old hierarchical systems, like governments and large corporations, to individuals and small groups.
And the changes aren't stopping with the internet and communications.
We can see other changes emerging all around us: in agriculture, energy, politics, education, and everything in between.
Few have realized the massive personal empowerment now taking place. Technology is enabling us to have more control over our own lives than ever before, and it's getting easier to peacefully opt-out or outwit present circumstances.
Never before, in the history of the world, have so many people had the tools or ability to become so empowered. This truly is an exciting time in history.
By peacefully subverting established systems, decentralization promises to be the next big evolutionary leap for humanity and the revolution that will define the 21st century.
Related Subreddits
Decentralize all the things!
/r/Rad_Decentralization
(Cross-posted)
Hi everyone,
Possibly a silly question, but I’m new to the concept of self-hosting. Are there any cloud storage companies that post warrant canaries but also don’t work with big tech like Google or Amazon? I’m looking into Cloudfare which does post a warrant canary, but I’m assuming if a parent host like Amazon/AWS gets subpoenaed it wouldn’t warn Cloudfare itself, kind of circumventing the point. Is that right, and if so are there any companies or self-host techniques that don’t have that vulnerability?
Hi everyone! I just finished developing this feature for my platform and would love to get some feedback about it.
Platform is https://isari.ai
You can watch a demo on how to use it in the homepage 😊
If you want to collaborate or be part of this initiative, please send me a DM or join the Discord server, I will more than happy to respond!
I'd appreciate any and all feedback 🙏
Here's another story about a data breach.
https://techcrunch.com/2024/07/25/spytech-data-breach-windows-mac-android-chromebook-spyware/
These stories are not surprising anymore. The question is, how do we get Real Security & Real Privacy? Clearly, Silibandia (Silicon Valley + the Broadband & Media Industries) are only interested in making users think they have security and privacy, while that's not the case.
Silibandia's approach to security is CTBG (Catch the bad guys). It doesn't work, and Silibandia knows that. Real security and Real Privacy would end surveillance capitalism. Silibandia doesn't want that. Surveillance capitalism is Silibandia's business model.
Your personal information is a money-making asset in Silibandia's balance sheet. In this age of digital information, information about you is essentially you. Silibandia treats the digital you as an asset in their balance sheet. I don't know why everyone is so comfortable with that.
In an environment of Authenticity, you get Real accountability and Real privacy. Wouldn't you want to get accountability from others you encounter online, but everyone gets to keep their privacy?
Establishing and environment of Authenticity is how we all escape Silibandia (Silicon Valley + the Broadband and Media Industries)
Imagine online spaces that have;
And above all, you get to participate in the governance of that space.
Silibandia is the largest nation on Earth, with over 5 billion citizens – actually, think subjects.
Its name stands for Silicon Valley plus the broadband and media industries, but it’s really the whole feudal nation, where we peasants toil in the digital fields controlled by the institutional aristocracy, including the troll farm operators and the dark web mafia. (Really, it’s all one big Cosa Nostra – remember when one of them used to say “Do no evil”?)
In our concern for the privacy and autonomy of the person identified, we must keep in mind the needs of the relying party.
And we are all relying parties. We all need accountability from others we encounter online.
Accountability means that we must have measurable trust in the identity claims of others. Someone must attest to those claims.
PGP and GPG are examples of collegial attestation, where members of a community attest to each others’ identity claims.
Collegial attestation works in collegial settings, such as among academics and researchers and developers working to come up with solutions to challenges – such as our own DID community.
By contrast, collegial attestation tends to be easily corrupted when money and political power are involved. The simple fact is that collegial attestation does not work in the big bad world of commerce and politics. In that case the attestation must be like the attestation behind your birth certificate: objective DCPA – duly constituted public authority.
That implies governance by authority. Governance, not Govern*ment*.
As the decentralization authority Lawrence Lundy-Bryan notes, “There is no such thing as decentralized governance.”
So now we who are committed to peer-to-peer infrastructures and decentralization are confronted with a case for centralized authority.
BUT there is a way to do centralized authority while preserving not just privacy but anonymity. The basic idea of the system was invented in 1903 by Henry Lee Higgenson. It’s the car license plate. Anyone can see your license plate, making you accountable for what happens on public roadways. But no one gets to know the identity of the driver or owner unless there’s been an incident.
That system has a vulnerability in the world of physical license plates. Anyone calling the DMV claiming to be a police officer can get identity information.
Protection of digital identities using the license plate model do not have the same vulnerability. The way to do it is with a certificate stack, so that the utility certificate used for identification contains no information. However, behind the scenes it is connected to a foundational certificate that’s analogous to the driver’s license. No one gets to see the information in the foundational certificate unless they produce a court order attesting that they’ve been defrauded, defamed or otherwise injured or they’ve broken the law.
The individual can have as many utility certificates as they want, allowing them to use separate identities for different personas. Thus you don’t need to use the same utility certificate with your employer or school that you use with a dating site. The individual is in control of disclosure of connections among certificates except, as mentioned, if someone gets a court order.
And if the certification authority uses the IOP Protocol, the central authority has no identity information. The connection between the utility certificate and name, age, location etc. of the individual is in the custody of a legally accountable Attestation Officer, the professional who enrolled the individual and who established their identity quality score.
Could you recommend good resources that give a broad overview of recent advances and interesting projects in this area not focused exclusively on crypto currency? Thanks.
tldr; Radical decentralization of all the things.
I hope this isnt seen as spam, I have recently posted on this subreddit. the subject matter of my posts are looking to provide clarity on different aspects of the app. It would be too much for any single post.
Decentralization can mean a lot of things because it can be open to interpretation. In this article, we would like to talk about what decentralization means to us and how we are approaching our definition of decentralized. We are working on a typical chat app, but our approach is unique and may push the boundaries of what it means for something to be self-hosted.
Our decentralized chat application is built as a Progressive Web Apps (PWA) and leverages modern web technologies to deliver a user experience comparable to native apps. Unlike traditional centralized chat apps, our chat app is designed to operate independently of central servers, ensuring that user data remains private and secure. This article will delve into the various components and architectural decisions that make our app truly decentralized.
An overview of how our chat application leverages Progressive Web App (PWA) technology to provide a seamless user experience across different devices and platforms.
A typical app relies heavily on data storage and networking capabilities. In our decentralized chat application, we’ve implemented advanced solutions to handle these aspects efficiently and securely.
In our app, we use IndexedDB to store data directly in the browser’s storage. While browsers provide multiple options for storing information, ranging from cookies to local storage, IndexedDB offers a more advanced and robust solution.
Capacity: IndexedDB can store significantly larger amounts of data compared to cookies or local storage.
Structure: It allows for complex data structures, including collections of files and blobs.
Performance: IndexedDB operates asynchronously, meaning it won’t block the main thread of your application, leading to better performance for data-heavy applications.
Using IndexedDB, we ensure that user data is stored locally on their devices, providing both privacy and independence from central servers.
For networking, our app uses PeerJS-server as a connection broker to establish WebRTC connections between peers.
Direct Peer-to-Peer: WebRTC, provided by the browser, enables real-time communication between peers. This allows two users to connect directly and exchange data with minimal latency.
Efficient Routing: Once a connection is established, data is sent via the shortest possible network route, enhancing speed and efficiency.
Multiple Connections: Browsers can handle multiple WebRTC connections simultaneously, though the number of connections can vary depending on the device and network capabilities.
PeerJS-server helps in the initial connection setup by acting as a signaling server. It facilitates the exchange of connection information between peers, enabling them to establish a direct WebRTC connection.
By leveraging IndexedDB for data storage and WebRTC with PeerJS-server for networking, our chat application achieves a high level of decentralization, ensuring user data remains private and connections are efficient and reliable. These components form the backbone of our approach, pushing the boundaries of what it means for an app to be truly self-hosted and decentralized
Our app is essentially a bundle of static files, which makes it highly portable and easy to distribute. We leverage AWS services such as S3 and CloudFormation to deploy our app, ensuring it is distributed efficiently over a Content Delivery Network (CDN) across AWS servers.
AWS S3: We host our app on AWS S3, a scalable storage service that allows us to serve static files reliably. S3 ensures that our app is always available and can handle large numbers of requests without performance degradation.
CloudFormation: By using AWS CloudFormation, we automate the deployment process, managing our infrastructure as code. This makes it easy to replicate and manage our app’s deployment environment.
Hosting on S3 and using CloudFormation means our app benefits from AWS’s global CDN. This ensures that our static files are cached and served from servers closest to our users, reducing latency and improving load times.
We go a step further by providing users with the option to download a zip file of the app directly from within the app. This ensures that users can run the app locally without relying on our servers.
Direct from Index.html: Unlike some other apps, our app is a pure JavaScript implementation, designed to run directly from the index.html file. Users can simply open this file in their browser and start using the app without needing a server.
Docker Option: For users who prefer or require a server setup, we offer a Docker configuration. This allows the app to be run in a containerized environment, providing flexibility and ease of deployment for different use cases.
We believe in transparency and accessibility. Therefore, we run the app as unminified code. This has several advantages:
Ease of Download: Users can download the entire app using simple browser commands like Ctrl/Cmd+S.
Transparency: By providing unminified code, we ensure that users can inspect and understand the code they are running. This fosters trust and allows for easier customization and debugging.
By distributing our app as static files and offering multiple ways to run it, we ensure that users have maximum flexibility and control. Whether using AWS’s robust infrastructure or running the app locally, our approach embodies the principles of decentralization and user empowerment.
Our app leverages Webpack 5’s Module Federation feature to implement a microfrontend architecture. This approach allows us to modularize our application, making it easier to maintain, develop, and scale. You can explore our open-source implementation here: https://github.com/positive-intentions/frontend-base.
We have used Webpack 5 Module Federation to build the chat application, which you can find here: https://github.com/positive-intentions/chat. Additionally, we have created a federated module for cryptography that can be imported at runtime, available here: https://github.com/positive-intentions/cryptography. Our current setup is straightforward, allowing us to dynamically load different parts of the application as needed. This modular approach provides flexibility and efficiency in how we develop and deploy our app.
We plan to further decompose the application into separate microfrontends, each responsible for a specific aspect of the app. This will not only simplify maintenance but also enhance documentation and development processes for individual components.
Planned Modules:
1. UI Components: A collection of reusable UI components that can be shared across different parts of the application, promoting consistency and reducing duplication.
2. P2P Framework: The core framework for peer-to-peer networking, facilitating real-time communication between users.
3. State Management: This module will manage the application’s state, ensuring efficient data handling and synchronization across different components and peers.
4. Permission Manager: A dedicated module for managing user permissions and access control, enhancing security and user management.
Each module will have its own Storybook and module export, providing a dedicated space for documentation, testing, and showcasing individual components. This approach will:
Enhance Documentation: Each module will be well-documented, making it easier for developers to understand and use them.
Simplify Maintenance: By isolating modules, we can update and maintain them independently, reducing the risk of breaking changes affecting the entire app.
Promote Reusability: Well-defined modules can be reused across different projects, promoting a modular and efficient development approach.
By embracing Webpack 5 Module Federation and breaking down our app into distinct microfrontends, we aim to create a more robust, scalable, and maintainable architecture. This approach not only benefits our development process but also enhances the overall user experience by ensuring that each component is well-crafted and easily accessible.
In the past, we have encountered difficulties when deploying our app to AWS due to various technical issues. Given that our app functions as a self-hosted static application, we have started exploring alternative hosting options, such as GitHub Pages. You can view our deployment on GitHub Pages here: https://positive-intentions.github.io/chat.
Our microfrontend architecture allows us to deploy each module independently. This capability has enabled us to host copies of the app on GitHub Pages for each repository. While this approach is unconventional and can lead to redundant copies of the app, we believe it is a valuable exercise in exploring module federation redundancy.
Accessibility: Hosting on GitHub Pages makes the app easily accessible to users and developers.
Simplicity: GitHub Pages offers a straightforward deployment process, reducing the complexity often associated with other hosting solutions.
Cost-Effective: GitHub Pages is free, making it an economical choice for hosting static sites.
We aim to make our app interoperable across different hosting sources. By leveraging Webpack 5 Module Federation, we can ensure that the app works seamlessly whether it is served from AWS or GitHub Pages. This redundancy enhances the app’s reliability and availability.
Module Federation Redundancy: We are investigating ways to make modules interoperable between different sources, ensuring that the app remains functional even if one source becomes unavailable.
Interoperable Deployment: Our goal is to allow the app to fetch and integrate modules from both AWS and GitHub Pages dynamically.
To further enhance our deployment strategy, we plan to use a infrastructure as code tool, to deploy the app across multiple cloud service providers. This approach will increase the resilience of our deployment, ensuring the app remains online and functional even if one provider experiences downtime.
Multi-Cloud Deployment: We can deploy the app to various cloud service providers, including AWS, Azure, and Google Cloud. This will distribute the app’s load and reduce the risk of a single point of failure.
Scalability: This will enable us to scale the app easily across different providers, ensuring it can handle increased traffic without performance issues.
Cost Management: Static file hosting is relatively a cheap option for hosting a webapp, we can optimize costs and ensure that the app remains affordable to maintain.
By exploring these new hosting options and implementing a robust deployment strategy, we aim to make our decentralized chat app more resilient, scalable, and cost-effective. Our efforts in redundancy and interoperability will ensure that the app continues to function seamlessly, providing a reliable user experience regardless of the hosting source.
As our app continues to develop, we are excited to introduce the concept of a decentralized profile that can be shared across multiple devices. This feature is designed for individuals who want to use the same profile on all their devices, providing a seamless and integrated multi-platform chat experience, much like any modern chat application.
A decentralized profile allows users to maintain a consistent identity and settings across different devices. This means that whether you are using a smartphone, tablet, or desktop, your profile can remain synchronized and up-to-date.
Profile Synchronization: Users can access their chat history, contacts, and settings on any device by synchronizing their decentralized profile.
Data Consistency: Changes made on one device are automatically reflected on others, ensuring a consistent experience.
Implementing a decentralized profile enables us to offer a robust multi-platform chat experience. Users can switch between devices without losing their chat continuity or settings, enhancing the overall user experience.
Convenience: Users can start a conversation on one device and continue it on another without any interruptions.
Flexibility: The app adapts to various devices, providing a user-friendly interface and experience on each platform.
In addition to profile synchronization, we are exploring the potential of decentralized file storage. This feature would allow users to move large files between devices quickly, easily and securely.
Cross-Device Sharing: Users can share files between their devices effortlessly, whether they are transferring a document from their laptop to their phone or vice versa.
Collaborative Work: Teams can collaborate more effectively by sharing encrypted files directly through the app, regardless of the devices they are using.
By introducing a decentralized profile and exploring decentralized file storage, we aim to enhance our app’s functionality and user experience. These features will provide users with the convenience and flexibility expected from a modern chat application while maintaining the principles of decentralization and security.
Decentralized peer discovery is a critical component of our app’s architecture. By leveraging innovative technologies such as QR codes, NFC, and BLE, we facilitate seamless connections between peers without relying on a central authority.
QR codes provide a straightforward method for establishing peer connections. Users can generate a QR code that contains their connection details, which other users can scan to initiate a peer-to-peer connection.
Ease of Use: Users can quickly and easily share connection details.
Security: QR codes can be generated dynamically, reducing the risk of interception.
NFC allows devices to establish connections simply by being in close proximity. This technology is particularly useful for quick and secure peer discovery.
Speed: Connections are established almost instantly.
Convenience: Users can connect devices by simply bringing them close together, making it ideal for spontaneous interactions.
BLE enables devices to discover and communicate with each other over short distances with minimal power consumption. This makes it a suitable option for maintaining constant peer-to-peer connections.
Energy Efficiency: BLE conserves battery life, making it ideal for mobile devices.
Range: BLE provides a reliable connection over a short range, perfect for personal or localized networking.
By integrating QR codes, NFC, and BLE, we create a robust and versatile peer discovery mechanism. Users can choose the most convenient method for their situation, ensuring that connections are both seamless and secure.
Hybrid Approach: Users can combine different methods for an optimal connection experience. For instance, initial discovery via QR code followed by connection via BLE for sustained communication.
Adaptability: The app adapts to the available technologies on the user’s device, providing the best possible peer discovery experience.
These innovative approaches to peer discovery, coupled with our decentralized microfrontend architecture, form the backbone of our commitment to enhancing decentralization, scalability, and user experience. By continually exploring and implementing cutting-edge technologies, we ensure our app remains at the forefront of decentralized communication solutions
These sections outline the key aspects of our decentralized microfrontend architecture and provide a roadmap for our ongoing and future efforts to enhance decentralization, scalability, and user experience.
Our journey towards building a decentralized chat application has been driven by a desire to push the boundaries of what it means for an app to be truly self-hosted and independent of central servers. By leveraging modern web technologies such as Progressive Web Apps, IndexedDB, WebRTC, and Webpack 5 Module Federation, we have created a robust and scalable architecture that emphasizes privacy, security, and user empowerment.
We have explored innovative hosting solutions like GitHub Pages and plan to implement multi-cloud deployments to enhance resilience and scalability. Our vision for a multi-device architecture, incorporating decentralized profiles and encrypted file storage, aims to provide a seamless, cross-platform user experience. Additionally, our commitment to decentralized peer discovery using QR codes, NFC, and BLE ensures that users can connect easily and securely without relying on centralized authorities.
As we continue to develop and refine our app, we remain dedicated to the principles of decentralization, transparency, and user control. We invite you to join us on this journey, explore our open-source repositories, and contribute to the ongoing evolution of our decentralized chat application. Together, we can redefine what it means to communicate in a decentralized world.
Thank you for taking the time to read about our project. We look forward to your feedback and collaboration as we continue to innovate and improve our decentralized chat application.
Demo: https://chat.positive-intentions.com
I hope this isnt seen as spam. I previously posted the source code of my app which is pretty broad in functionality. In this post i was to discuss about my observations about how the app is managing data. for me it is working unintuitivly well.
Blockchain is a good way to order block of sequential data that can be validated by others. Countless real-world examples show that it scales pretty well.
In my app, I am testing the use of a blockchain for storing "chat app data" selfhosted-only. The app is a work-in-progress proof-of-concept and experimental. It is an investigation into creating a distributed and decentralized app.
Unlike traditional blockchains, the sole purpose of this blockchain is to keep messages between peers in sync. The implementation is have is far from finished, but i have a testable proof-of-concept. The blockchain is entirely in javascript running in a browser.
I have a few observations I would like to make:
I am very interested in the idea of blockchain as a datastructure and I would like to see it used more often. i think this datastructure will play an important role in my app as it will enable the app to move to a single-user-multi-platform architecture.
I would like to hear your thoughts on blockchain as a datastructure. Initially i did it investigating if it works on a basic level to help keep messages in sync, but i find that it is quite performant; especially considering it is only running in a browser. (i expect i can easily improve the performance)
This is my build of the BuckitUp project - the self-hosted Raspberry Pi app that does data storage and communications off-cloud. It is open source and may be usefull for many things from just havig an automated encrypted backup of a valueble files to having separate and decentralised data infrastructure for an entire buisness or community.
This thing is present is exploring the market fit, but anybody having a raspberry pi 4b may try it for free just with a few clicks. It gives you a local server with the wifi hotspot and works entirely offline, but you can also connect them to the same local network - so they sync togather. They are also available for sync over distance through ZeroTire, if you are willing to connect to the internet still.
Share your thoughts - do you find projects like this usefull, and what it may be good for?
I want to share with you a successful solution for secure messaging. My team has been using ADAMANT Messenger for over a year to exchange important information.
ADAMANT leverages blockchain technology to create a decentralized network free from government control, corporations, and even developers. Your communication remains truly anonymous.
ADAMANT's open-source code allows anyone to verify its functionality and security.
Businesses can utilize ADAMANT Business—a private blockchain network built on the underlying ADAMANT protocol—for secure internal communication.
The ADAMANT ecosystem operates on the ADM cryptocurrency.
It has its own wallet and the ability to transfer and exchange coins.