diff --git a/chapters/2.theoretical-background/2.0.theoretical-background.tex b/chapters/2.theoretical-background/2.0.theoretical-background.tex index a7faffd..0b2e43f 100644 --- a/chapters/2.theoretical-background/2.0.theoretical-background.tex +++ b/chapters/2.theoretical-background/2.0.theoretical-background.tex @@ -7,3 +7,4 @@ \input{chapters/2.theoretical-background/2.5.blockchain} \input{chapters/2.theoretical-background/2.6.ethereum} \input{chapters/2.theoretical-background/2.7.ipfs} +\input{chapters/2.theoretical-background/2.8.orbit-db} \ No newline at end of file diff --git a/chapters/2.theoretical-background/2.8.decentralized-apps.tex b/chapters/2.theoretical-background/2.8.decentralized-apps.tex deleted file mode 100644 index ca59465..0000000 --- a/chapters/2.theoretical-background/2.8.decentralized-apps.tex +++ /dev/null @@ -1 +0,0 @@ -\section{Αποκετροποιημένες εφαρμογές} diff --git a/chapters/2.theoretical-background/2.8.orbit-db.tex b/chapters/2.theoretical-background/2.8.orbit-db.tex new file mode 100644 index 0000000..b9c459b --- /dev/null +++ b/chapters/2.theoretical-background/2.8.orbit-db.tex @@ -0,0 +1,39 @@ +\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 + +\underline{\textbf{Stores}}\\ +Η OrbitDB παρέχει διάφορους τύπους βάσεων (stores) για διαφορετικά μοντέλα δεδομένων και περιπτώσεις χρήσης: + +\begin{itemize} + \item log: ένα αμετάβλητο (μόνο για προσάρτηση) ημερολόγιο με ανιχνεύσιμο ιστορικό. + \item feed: ένα μεταβλητό αρχείο καταγραφής με ανιχνεύσιμο ιστορικό, του οποίου οι καταχωρήσεις μπορούν να προστεθούν και να αφαιρεθούν. + \item keyvalue: μία βάση δεδομένων κλειδιών-τιμών. + \item docs: μία βάση δεδομένων εγγράφων στην οποία μπορούν να αρχειοθετηθούν έγγραφα JSON με ένα καθορισμένο κλειδί. + \item counter: μία βάση δεδομένων για καταμέτρηση συμβάντων. +\end{itemize} + +Όλα τα 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). + +\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} + +\underline{\textbf{Access Control}}\\ +Κατά τη δημιουργία μίας βάσης μπορούν να οριστούν όσοι θα έχουν δικαίωμα να γράψουν σε αυτήν μέσω ενός ελεγκτή πρόσβασης (access controller). Ο ελεγκτής θα περιλαμβάνει τα public keys τους, τα οποία μπορούν να ανακτηθούν από το identity του καθενός. Από προεπιλογή και αν δεν ορίζεται διαφορετικά, δίνεται πρόσβαση εγγραφής μόνο στον δημιουργό της βάσης. diff --git a/packages.tex b/packages.tex index 6dfee71..d61be55 100644 --- a/packages.tex +++ b/packages.tex @@ -14,6 +14,7 @@ \usepackage{biblatex} \usepackage{csquotes} +\usepackage{listings} % Typeset source code listings % Custom commands \input{custom-commands/custom-title} diff --git a/thesis.pdf b/thesis.pdf index 30e4220..9476a6c 100644 Binary files a/thesis.pdf and b/thesis.pdf differ