diff --git a/assets/figures/orbitdb-identity.png b/assets/figures/orbitdb-identity.png new file mode 100644 index 0000000..ef6eeb0 Binary files /dev/null and b/assets/figures/orbitdb-identity.png differ diff --git a/assets/figures/orbitdb-logo.png b/assets/figures/orbitdb-logo.png new file mode 100644 index 0000000..39dc99c Binary files /dev/null and b/assets/figures/orbitdb-logo.png differ diff --git a/bibliography/references.bib b/bibliography/references.bib index f85f610..39c1321 100644 --- a/bibliography/references.bib +++ b/bibliography/references.bib @@ -4,3 +4,12 @@ % proposed label naming convention: "chapter.subchapter-descriptive_name" % for example: "2.2.2-why-gpg-is-awesome" +@misc{orbitdb, + title = {OrbitDB}, + url = {https://orbitdb.org} +} + +@misc{orbitdb-guide, + title = {Getting Started with OrbitDB}, + url = {https://github.com/orbitdb/orbit-db/blob/main/GUIDE.md} +} diff --git a/chapters/2.theoretical-background/2.8.orbit-db.tex b/chapters/2.theoretical-background/2.8.orbit-db.tex index b9c459b..1f133f7 100644 --- a/chapters/2.theoretical-background/2.8.orbit-db.tex +++ b/chapters/2.theoretical-background/2.8.orbit-db.tex @@ -1,6 +1,12 @@ \section{OrbitDB} -Η OrbitDB είναι μία P2P βάση δεδομένων. Χρησιμοποιεί το IPFS για την αποθήκευση των δεδομένων και το IPFS Pubsub για τον αυτόματο συγχρονισμό των βάσεων δεδομένων μεταξύ των peers. Είναι μία τελικά συνεπής (eventually consistent) και χρησιμοποιεί CRDTs (Conflict-Free Replicated Data Types) για συγχωνεύσεις βάσεων δεδομένων χωρίς συγκρούσεις, πράγμα που την καθιστά εξαιρετική επιλογή για DApps και offline-first web applications. %TODO add [https://orbitdb.org] and logo +Η OrbitDB είναι μία P2P βάση δεδομένων. Χρησιμοποιεί το IPFS για την αποθήκευση των δεδομένων και το IPFS Pubsub για τον αυτόματο συγχρονισμό των βάσεων δεδομένων μεταξύ των peers. Είναι μία τελικά συνεπής (eventually consistent) και χρησιμοποιεί CRDTs (Conflict-Free Replicated Data Types) για συγχωνεύσεις βάσεων δεδομένων χωρίς συγκρούσεις, πράγμα που την καθιστά εξαιρετική επιλογή για DApps και offline-first web applications.\cite{orbitdb} + +\begin{figure}[H] + \centering + \includegraphics[width=2cm]{orbitdb-logo.png} + \caption{OrbitDB logo} +\end{figure} \underline{\textbf{Stores}}\\ Η OrbitDB παρέχει διάφορους τύπους βάσεων (stores) για διαφορετικά μοντέλα δεδομένων και περιπτώσεις χρήσης: @@ -16,24 +22,17 @@ Όλα τα stores υλοποιούνται πάνω στο \texttt{ipfs-log}, μία αμετάβλητη, operation-based CRDT για κατανεμημένα συστήματα, ενώ υπάρχει και η δυνατότητα δημιουργίας προσαρμοσμένων stores ανάλογα με την περίπτωση. \underline{\textbf{Address}}\\ -Κάθε βάση δεδομένων λαμβάνει κατά τη δημιουργία της μία διεύθυνση της μορφής: \texttt{/orbitdb/CID/DATABASE\_NAME}, όπου CID είναι το IPFS multihash του μανιφέστου της, ενώ το DATABASE\_NAME είναι το όνομα της βάσης %TODO add [https://github.com/orbitdb/orbit-db/blob/main/GUIDE.md] -. Το μανιφέστο είναι ένα IPFS object που περιέχει πληροφορίες της βάσης όπως το όνομα, τον τύπο και έναν δείκτη στον ελεγκτή πρόσβασης (access controller). +Κάθε βάση δεδομένων λαμβάνει κατά τη δημιουργία της μία διεύθυνση της μορφής: \texttt{/orbitdb/CID/DATABASE\_NAME}, όπου CID είναι το IPFS multihash του μανιφέστου της, ενώ το DATABASE\_NAME είναι το όνομα της βάσης\cite{orbitdb-guide}. Το μανιφέστο είναι ένα IPFS object που περιέχει πληροφορίες της βάσης όπως το όνομα, τον τύπο και έναν δείκτη στον ελεγκτή πρόσβασης (access controller). \underline{\textbf{Identity}}\\ -Κάθε φορά που προστίθεται μία εγγραφή στη βάση υπογράφεται από τον δημιουργό της, ο οποίος προσδιορίζεται από μία ταυτότητα (identity). Το Identity object, πέρα από τον προεπιλεγμένο τρόπο λειτουργίας, μπορεί να προσαρμοστεί έτσι ώστε να συνδέεται με κάποιο εξωτερικό αναγνωριστικό. %TODO add [https://github.com/orbitdb/orbit-db-identity-provider] -Η μορφή του έχει ως εξής: - -\begin{lstlisting}[breaklines=true] - { - _id: , - _publicKey: , - signatures: { - id: , //Allows the owner of _id to prove they own the private key associated with _publicKey - publicKey: //This links the two ids - }, - type: 'orbitdb' - } -\end{lstlisting} +Κάθε φορά που προστίθεται μία εγγραφή στη βάση υπογράφεται από τον δημιουργό της, ο οποίος προσδιορίζεται από μία ταυτότητα (identity). Το Identity object, πέρα από τον προεπιλεγμένο τρόπο λειτουργίας, μπορεί να προσαρμοστεί έτσι ώστε να συνδέεται με κάποιο εξωτερικό αναγνωριστικό. +Η μορφή του έχει ως εξής (βλ. και https://github.com/orbitdb/orbit-db-identity-provider): + +\begin{figure}[H] + \centering + \includegraphics[width=12cm]{orbitdb-identity.png} + \caption{OrbitDB Identity} +\end{figure} \underline{\textbf{Access Control}}\\ Κατά τη δημιουργία μίας βάσης μπορούν να οριστούν όσοι θα έχουν δικαίωμα να γράψουν σε αυτήν μέσω ενός ελεγκτή πρόσβασης (access controller). Ο ελεγκτής θα περιλαμβάνει τα public keys τους, τα οποία μπορούν να ανακτηθούν από το identity του καθενός. Από προεπιλογή και αν δεν ορίζεται διαφορετικά, δίνεται πρόσβαση εγγραφής μόνο στον δημιουργό της βάσης. diff --git a/thesis.pdf b/thesis.pdf index 9476a6c..7250c21 100644 Binary files a/thesis.pdf and b/thesis.pdf differ