This repository has been archived by the owner on Nov 27, 2024. It is now read-only.
generated from aaranxu/adidoks
-
Notifications
You must be signed in to change notification settings - Fork 0
Blog: 01-About #14
Open
kirillt
wants to merge
1
commit into
main
Choose a base branch
from
blog/1-onboarding
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Blog: 01-About #14
Changes from all commits
Commits
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
+++ | ||
title = "What is ARK Builders project?" | ||
date = 2023-10-08 | ||
template = "blog/page.html" | ||
|
||
description = "" | ||
|
||
[extra] | ||
#updated = "2023-10-08" | ||
author = "Kirill" | ||
+++ | ||
|
||
about async-first working culture: https://hypercontext.com/blog/communication/asynchronous-communication-culture | ||
|
||
about local-first software: https://www.inkandswitch.com/local-first/ | ||
|
||
all apps store internal data as plain files in user-selected folders, easy to sync. but we are working on sync library too, to remove necessity to install another software. for this moment, we use Syncthing to sync internal files between devices: https://syncthing.net | ||
|
||
we use "content-addressing" it to make our apps work with data identifying it by its content instead of location. it makes some things easier, too. this concept was introduced by IPFS: https://www.ipfs.tech/ | ||
|
||
about unit-testing: https://www.toptal.com/qa/how-to-write-testable-code-and-why-it-matters | ||
|
||
|
||
--- | ||
|
||
https://www.yac.com/blog/asynchronous-communication | ||
https://lattice.com/library/what-is-asynchronous-work-heres-everything-you-need-to-know-to-implement-it-at-your-organization | ||
https://www.entrepreneur.com/growing-a-business/how-to-create-an-asynchronous-work-culture/375696 | ||
https://blog.kickresume.com/async-work/ | ||
https://discover.techsmith.com/async-first/ | ||
https://www.staffing.com/asynchronous-culture/ | ||
https://www.float.com/blog/leaders-embrace-async-culture/ |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is the essence of the technical side of our project. The project started in 2020 and was really slow-paced while we were developing the very first prototype of Navigator. It probably was not really good decision to develop it as an Android app first, because Android development appeared to be pretty challenging. The decision was made because state of GUI frameworks for Rust was pretty poor at that time and since the project aims at being cross-platform, it seemed to be OKish option to develop mobile GUI instead... So, this summer I've finally discovered the term "Local-first Software" and the website and it really describes what I wanted to achieve since 2020. I really recommend reading their article "7 ideals of Local-first Software".
In fact, we're designing Desktop version now and it's going to be better fit for the target audience. Tagging resources takes some time and on Mobile it's worth for important personal documents, while on Desktop it's more about "office work", study and scientific research.
But we still have the key component missing, which is P2P sync... I want to build a library for P2P sync which can be used both for generic file sync (i.e. private cloud consisting of user's devices), and by apps to sync app-specific data (e.g. notes, bookmarks, geolocations, etc.). This idea intersects with IPFS in some way, but the key feature is that each app could use the lib to sync with other user's devices under the hood without making the user to install or setup anything. It could also be used to implement sort of P2P CDN to distribute images, videos and other resources between app instances, not only belonging to same user.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Probably we should be more careful about cloud part. Cloud is more robust, but less performant and less secure in theory. I think, when we implement our own sync, all our apps will have free Wi-Fi sync (so you come home and your phone get synced with laptop, for instance). But we might provide our servers as paid backup + additional sync when the user is not around Wi-Fi.
"Navigator" app is more about UX of workflows with local files. In my opinion, on mobile devices it's so painful to work with local files of any kind. All apps are built assuming users only play with their devices (including Instagram and Facebook). Desktop still remains preferred platform for "real work" but even there file browsing experience is pretty outdated. In my opinion, filesystems are made for machines and humans are not really adapted to interact with it. It's better on macOS since it has tags but Apple's software isn't opensource, right? Although, honestly, I lack experience with Apple devices and need to catch up with it. Also curious about your opinion.
Other apps, e.g. "Shelf" and "Memo" are more use-case oriented. "Shelf" is a bookmarks keeper, we have it on Android and Desktop. "Memo" is versatile notes maker. Both will have W-Fi sync for complete local-first experience, and cloud/self-hosted backup. By the way, ability to self-host backup server is also very important for the project.
And last, we develop the core for all apps in Rust: https://github.com/ARK-Builders/arklib This core is opensource and should become the backbone for cross-platform local-first apps.