or
or
By clicking below, you agree to our terms of service.
New to HackMD? Sign up
Syntax | Example | Reference | |
---|---|---|---|
# Header | Header | 基本排版 | |
- Unordered List |
|
||
1. Ordered List |
|
||
- [ ] Todo List |
|
||
> Blockquote | Blockquote |
||
**Bold font** | Bold font | ||
*Italics font* | Italics font | ||
~~Strikethrough~~ | |||
19^th^ | 19th | ||
H~2~O | H2O | ||
++Inserted text++ | Inserted text | ||
==Marked text== | Marked text | ||
[link text](https:// "title") | Link | ||
 | Image | ||
`Code` | Code |
在筆記中貼入程式碼 | |
```javascript var i = 0; ``` |
|
||
:smile: | ![]() |
Emoji list | |
{%youtube youtube_id %} | Externals | ||
$L^aT_eX$ | LaTeX | ||
:::info This is a alert area. ::: |
This is a alert area. |
On a scale of 0-10, how likely is it that you would recommend HackMD to your friends, family or business associates?
Please give us some advice and help us improve HackMD.
Syncing
xxxxxxxxxx
Secure Data Storage Features
EDV Client Features
EDV Server Features
Hub Features
Decentralized Twitter (Dewitter) Requirements List
Assumptions, Principles, Requirements, and Other Considerations
Abbreviations
• EDV = Encrypted Data Vault
• EDV App = Encrypted Data Vault-based App (Application or Service)
General Assumptions
Dewitter Use Cases: 1
A. User Case 1b. No centralized servers are required to Encrypted Data Vaults for phone, tablet, or laptop-based application
Actors, Roles (Personas), and Roles (Followers, Following, Neighborhoods)
Dewitter Use Cases: 2-4
B. Use Case 2. Users of an EDV-based application can have multiple accounts (identities) associated with themselves and their EDV Apps.
EDV Server Instances, EDV Data Vaults, and Containers
Dewitter Use Cases: 5
C. Use Case 5a. Local EDV Service Instances are capable of running standalone on a personal device (e.g. phone, laptop, or tablet).
D. User Case 5c. Each Local EDV Service Instance can host (have attached to it) 1 or more EDVs
E. Use Case 5d. Each EDV has the capability of storing resources into separate and secure resource Container (or the equivalent). An EDV can container 1 or more Containers.
F. Use Case 5x. Local EDV Service Instances automatically start and restart (after the device resumes from hibernation).
Personal Data Vaults and Containers
Dewitter Use Cases: 6
G. Use Case 6d. A resource is securely stored in a Container in an EDV.
Personal Agents
Dewitter Use Cases: 7
H. Use Case 7e. Personal Agents can talk to each other and exchange messages (e.g. using DIDCOMM).
I. Use Case 7f. A Personal Agent (or the equivalent) mediates all access to a personal Local EDV Service Instance, the attached EDVs, the Containers of resources contained in the EDVs.
J. Use Case 7h. Personal Agents automatically start and restart (after the device resumes from hibernation).
Dewitter Data Vault
Dewitter Use Cases: 8
• No requirement items
Dewitter Data Model Definitions
This section describes how tweets are stored in Dewitter’s fully decentralized architecture.
Dewitter Use Cases: 9-18 (Use Cases: 19-22 Reserved)
K. Use Case 10. Any resource, optionally, can have plain-text properties associated with the resource for the purpose of querying and retrieving a single resource or a collection of resources (Simple Resource Key).
L. Use Case 10. A resource property (Simple Resource Key) can have sub-properties (Resource Subkeys) – called a Resource Complex Key.
M. Use Case 10. A specific Container can be queried for a single resource or a collection of resources given a Simple Resource Key or a Complex Resource Key.
N. Use Case 14. A Local EDV Service Instance has an atomic, transaction-safe capability for updating the value of a property on a resource in a Container (e.g. incrementing the value of “counter” property on a resource).
O. Use Case 14. A Local EDV Service Instance supports a general-purpose, atomic, transaction-safe capability for updating the value of a property on a resource in a Container based on an arbitrary property value changing computation on the specific resource.
P. Use Case 15. A Local EDV Service Instance has a capability for storing, updating, querying, and retrieving stream resources to a client app or service (e.g. images, audio streams, video streams).
Personal Agent to Local EDV Server Instance Communications
Use Cases: 23
Q. Use Case 23a. Capability for a Personal Agent to directly access a Local EDV Server Instance running on the same device using the Layer B EDV Trusted Content Storage Services API (not via one of the Layer B Trusted Content Storage Service remote access service endpoints (e.g. HTTP, Bluetooth, etc.).
R. Use Case 23b. Capability for a Local EDV Server Instance to talk directly to the Layer A Trusted Content Storage Kernel via an API (which, in turn, talks directly to the EDV Microkernel).
S. Use Case 23c. An EDV Microkernel securely manages all access and operations against each of the attached EDVs.
Dewitter Protocol Operations
NOTE: A Compound Query is a query parameter that includes multiple Resource Keys (Simple and Complex) and their key values.
Use Cases: 24-35
Create/Update a Tweet Item or Stream Item in a Personal Local EDV Service Instance
T. Use Case 24a. Capability to create a new resource in a Container in a Data Vault attached to the Local EDV Service Instance.
U. Use Case 24b. Capability to update a new resource in a Container in a Data Vault attached to the Local EDV Service Instance.
V. Use Case 24c. Capability to tombstone a new resource in a Container in a Data Vault attached to the Local EDV Service Instance.
W. Use Case 24x. Capability to ensure no one but the owner can update a resource in a Container in the Data Vault attached to the Local EDV Service Instance.
Query a Personal Local EDV Server Instance for a List of Tweet Keys or a Collection of Tweet Items
X. Use Case 25a. Capability to query a Local EDV Server Instance for a list of Resource Keys given a Simple Resource Key or a Complex Resource Key or a Compound Query.
Y. Use Case 25b. Capability to query a Local EDV Service Instance for a list of Resource Items given a Simple Resource Key or a Complex Resource Key or a Compound Query.
Z. Reserved
Query Another Personal Agent or List of Personal Agents for a List of Tweet Keys
AA. Use Case 26a. Capability to query another Personal Agent for a list of Resource Keys given a Simple Resource Key or a Complex Resource Key or a Compound Query.
BB. Use Case 26b. Capability to query a List of Personal Agents for a list of Resource Keys given a list of Simple Resource Keys or a Complex Resource Keys or a Compound Queries.
Query Another Personal Agent or List of Personal Agents for a List of Tweet Items
CC. Use Case 27a. Capability to query another Personal Agent for a list of Resource Items given a Simple Resource Key or a Complex Resource Key or a Compound Query.
DD. Use Case 27b. Capability to query a List of Personal Agents for a list of Resource Items given a list of Simple Resource Keys or a Complex Resource Keys or a Compound Queries.
Block a Query from Another Personal Agent
EE. Use Case 28a. Capability for a receiving Personal Agent to block the receipt and acceptance of a query for a resource from another Personal Agent.
Query a Personal Local EDV Server Instance for a List of Stream Keys or a Collection of Stream Items
FF. Use Case 29a. Capability to query a Local EDV Server Instance for a list of Resource Keys given a Simple Resource Key or a Complex Resource Key or a Compound Query.
GG. Use Case 29b. Capability to query a Local EDV Service Instance for a list of Resource Items given a Simple Resource Key or a Complex Resource Key or a Compound Query.
Query Another Personal Agent or List of Personal Agents for a List of Stream Keys
HH. Use Case 29y. Capability to query another Personal Agent fora list of Resource Keys given a Simple Resource Key or a Complex Resource Key or a Compound Query.
II. Use Case 29z. Capability to query a List of Personal Agents for a list of Resource Keys given a list of Simple Resource Keys or a Complex Resource Keys or a Compound Queries.
Query Another Personal Agent or List of Personal Agents for a List of Stream Items
JJ. Use Case 30a. Capability to query another Personal Agent for a list of Resource Items given a Simple Resource Key or a Complex Resource Key or a Compound Query.
KK. Use Case 30b. Capability to query a List of Personal Agents for a list of Resource Items given a list of Simple Resource Keys or a Complex Resource Keys or a Compound Queries.
Update a Resource Item in Another Personal Local EDV Service Instance
LL. Use Case 35. Capability, given a Resource Key, update an existing Resource Item in a Container in an EDV Data Vault attached to a personal Local EDV Server Instance.
Dewitter Use Cases
Use Cases: 36-51
MM. Use Case 48. A Local EDV Service Instance has an atomic, transaction-safe capability for updating the value of a property on a resource in a Container (e.g. incrementing the value of “counter” property on a resource). (Same as Requirement Item N.)
Notes on Notes
Dewitter Notes: 1-4
NN. Note 1. Support for offline Personal Agents.
OO. Note 2. Support for offline Local EDV Server Instances.
PP. Note 3. For secure logging on an EDV-by-EDV basis: all actions against the Containers in a particular EDV stored in a secure Logging Container for that EDV.
QQ. Note 3. Support for EDV-to-EDV replication at the Container-by-Container level.
DO NOT EDIT BELOW
Identity Hub Requirements OLD PLEASE DONT EDIT - FOR POSTERITY
replication on an EDV server, the server could ensure certain documents are replicated to other EDVs when
encrypted attributes match