mirror of
https://github.com/orbitdb/orbitdb.git
synced 2025-05-19 13:26:37 +00:00

Use latest store modules from npm Update README Update docs Update examples Update benchmarks Update dependencies Add Getting Started guide Add new a screenshot Add a new live demo Add persistency tests for snapshot saving/loading and events Add network stress tests (but skip them by default as they're very heavy and lengthy) Add browser benchmarks Add log() alias for eventlog() database Add possibility to create database if it doesn't exist yet Add support for orbitdb addresses Add a test for starting replication when peers connect Add debug build Use IPFS nodeID as default user id Use ipfs-pubsub-room Handle closing of databases properly Handle cache errors Clean up tests, re-organize code files Clean up code style Support for CLI Remove obsolete scripts
86 lines
1.8 KiB
JavaScript
86 lines
1.8 KiB
JavaScript
'use strict'
|
|
|
|
class AccessController {
|
|
constructor () {
|
|
this._access = {
|
|
admin: [],
|
|
write: [],
|
|
read: [], // Not used atm
|
|
}
|
|
}
|
|
|
|
/* Overridable functions */
|
|
async load (address) {}
|
|
async save () {}
|
|
|
|
/* Properties */
|
|
get admin () {
|
|
return this._access.admin
|
|
}
|
|
|
|
get write () {
|
|
// Both admins and write keys can write
|
|
return this._access.write.concat(this._access.admin)
|
|
}
|
|
|
|
// Not used atm
|
|
get read () {
|
|
return this._access.read
|
|
}
|
|
|
|
/* Public Methods */
|
|
add (access, key) {
|
|
// if(!Object.keys(this._access).includes(access))
|
|
// throw new Error(`unknown access level: ${access}`)
|
|
// if (!this._access[access].includes(key))
|
|
// this._access[access].push(key)
|
|
|
|
// TODO: uniques only
|
|
switch (access) {
|
|
case 'admin':
|
|
this._access.admin.push(key)
|
|
break
|
|
case 'write':
|
|
this._access.write.push(key)
|
|
break
|
|
case 'read':
|
|
this._access.read.push(key)
|
|
break
|
|
default:
|
|
break
|
|
}
|
|
}
|
|
|
|
remove (access, key) {
|
|
const without = (arr, e) => {
|
|
const reducer = (res, val) => {
|
|
if (val !== key)
|
|
res.push(val)
|
|
return res
|
|
}
|
|
return arr.reduce(reducer, [])
|
|
}
|
|
|
|
// if(!Object.keys(this._access).includes(access))
|
|
// throw new Error(`unknown access level: ${access}`)
|
|
// if (this._access[access].includes(key))
|
|
// this._access[access] = without(this._access[access], key)
|
|
|
|
switch (access) {
|
|
case 'admin':
|
|
this._access.admin = without(this._access.admin, key)
|
|
break
|
|
case 'write':
|
|
this._access.write = without(this._access.write, key)
|
|
break
|
|
case 'read':
|
|
this._access.read = without(this._access.read, key)
|
|
break
|
|
default:
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
module.exports = AccessController
|