js-mafmt/src/index.js

249 lines
5.0 KiB
JavaScript
Raw Normal View History

2016-03-23 15:07:25 +01:00
'use strict'
const multiaddr = require('multiaddr')
/*
* Valid combinations
*/
2017-01-22 14:36:58 +00:00
const DNS4 = base('dns4')
const DNS6 = base('dns6')
2019-08-08 12:02:02 +02:00
const DNS = or(
base('dns'),
base('dnsaddr'),
2017-01-22 14:36:58 +00:00
DNS4,
DNS6
)
const IP = or(base('ip4'), base('ip6'))
2018-09-12 11:21:52 +02:00
const TCP = or(
and(IP, base('tcp')),
2019-08-08 12:02:02 +02:00
and(DNS, base('tcp'))
2018-09-12 11:21:52 +02:00
)
const UDP = and(IP, base('udp'))
const UTP = and(UDP, base('utp'))
const WebSockets = or(
and(TCP, base('ws')),
and(DNS, base('ws'))
)
2017-01-20 17:46:26 +00:00
const WebSocketsSecure = or(
and(TCP, base('wss')),
and(DNS, base('wss'))
)
const HTTP = or(
and(TCP, base('http')),
and(IP, base('http')),
2019-08-08 12:02:02 +02:00
and(DNS, base('http'))
)
const HTTPS = or(
and(TCP, base('https')),
and(IP, base('https')),
and(DNS, base('https'))
)
2017-01-20 17:46:26 +00:00
const WebRTCStar = or(
and(WebSockets, base('p2p-webrtc-star'), base('ipfs')),
and(WebSocketsSecure, base('p2p-webrtc-star'), base('ipfs')),
2019-08-08 12:02:02 +02:00
and(WebSockets, base('p2p-webrtc-star'), base('p2p')),
and(WebSocketsSecure, base('p2p-webrtc-star'), base('p2p'))
2017-01-20 17:46:26 +00:00
)
const WebSocketStar = or(
and(WebSockets, base('p2p-websocket-star'), base('ipfs')),
and(WebSocketsSecure, base('p2p-websocket-star'), base('ipfs')),
2019-08-08 12:02:02 +02:00
and(WebSockets, base('p2p-websocket-star'), base('p2p')),
and(WebSocketsSecure, base('p2p-websocket-star'), base('p2p')),
and(WebSockets, base('p2p-websocket-star')),
and(WebSocketsSecure, base('p2p-websocket-star'))
)
const WebRTCDirect = or(
and(HTTP, base('p2p-webrtc-direct')),
and(HTTPS, base('p2p-webrtc-direct'))
)
2017-01-20 17:46:26 +00:00
const Reliable = or(
WebSockets,
WebSocketsSecure,
HTTP,
HTTPS,
2017-01-20 17:46:26 +00:00
WebRTCStar,
WebRTCDirect,
TCP,
UTP
)
// Unlike ws-star, stardust can run over any transport thus removing the requirement for websockets (but don't even think about running a stardust server over webrtc-star ;) )
const Stardust = or(
and(Reliable, base('p2p-stardust'), base('ipfs')),
and(Reliable, base('p2p-stardust'))
)
2019-08-08 12:02:02 +02:00
const _P2P = or(
and(Reliable, base('ipfs')),
2019-08-08 12:02:02 +02:00
and(Reliable, base('p2p')),
2017-02-25 23:41:14 -08:00
WebRTCStar,
base('ipfs'),
2019-08-08 12:02:02 +02:00
base('p2p')
2017-02-25 23:41:14 -08:00
)
const _Circuit = or(
2019-08-08 12:02:02 +02:00
and(_P2P, base('p2p-circuit'), _P2P),
and(_P2P, base('p2p-circuit')),
and(base('p2p-circuit'), _P2P),
and(Reliable, base('p2p-circuit')),
and(base('p2p-circuit'), Reliable),
2017-02-25 23:41:14 -08:00
base('p2p-circuit')
)
const CircuitRecursive = () => or(
and(_Circuit, CircuitRecursive),
_Circuit
)
const Circuit = CircuitRecursive()
2019-08-08 12:02:02 +02:00
const P2P = or(
and(Circuit, _P2P, Circuit),
and(_P2P, Circuit),
and(Circuit, _P2P),
2017-02-26 00:07:33 -08:00
Circuit,
2019-08-08 12:02:02 +02:00
_P2P
)
exports.DNS = DNS
2017-01-22 14:36:58 +00:00
exports.DNS4 = DNS4
exports.DNS6 = DNS6
2016-01-19 17:23:52 +01:00
exports.IP = IP
exports.TCP = TCP
exports.UDP = UDP
exports.UTP = UTP
exports.HTTP = HTTP
exports.HTTPS = HTTPS
2016-03-12 12:36:19 +00:00
exports.WebSockets = WebSockets
2017-01-20 17:46:26 +00:00
exports.WebSocketsSecure = WebSocketsSecure
exports.WebSocketStar = WebSocketStar
2016-05-21 19:57:26 +01:00
exports.WebRTCStar = WebRTCStar
exports.WebRTCDirect = WebRTCDirect
2016-01-19 17:23:52 +01:00
exports.Reliable = Reliable
exports.Stardust = Stardust
2017-02-25 23:41:14 -08:00
exports.Circuit = Circuit
2019-08-08 12:02:02 +02:00
exports.P2P = P2P
exports.IPFS = P2P
2016-01-19 17:23:52 +01:00
/*
* Validation funcs
*/
function makeMatchesFunction (partialMatch) {
return function matches (a) {
if (!multiaddr.isMultiaddr(a)) {
try {
a = multiaddr(a)
} catch (err) { // catch error
return false // also if it's invalid it's propably not matching as well so return false
}
2016-01-19 17:23:52 +01:00
}
2019-08-08 12:02:02 +02:00
const out = partialMatch(a.protoNames())
2016-01-19 17:23:52 +01:00
if (out === null) {
return false
}
return out.length === 0
}
}
2016-01-19 17:23:52 +01:00
function and () {
const args = Array.from(arguments)
2016-01-19 17:23:52 +01:00
function partialMatch (a) {
if (a.length < args.length) {
return null
}
args.some((arg) => {
a = typeof arg === 'function'
? arg().partialMatch(a)
: arg.partialMatch(a)
2016-01-19 17:23:52 +01:00
if (a === null) {
return true
}
})
return a
}
return {
toString: function () { return '{ ' + args.join(' ') + ' }' },
2016-01-19 17:23:52 +01:00
input: args,
matches: makeMatchesFunction(partialMatch),
2016-01-19 17:23:52 +01:00
partialMatch: partialMatch
}
}
function or () {
const args = Array.from(arguments)
2016-01-19 17:23:52 +01:00
function partialMatch (a) {
let out = null
args.some((arg) => {
const res = typeof arg === 'function'
? arg().partialMatch(a)
: arg.partialMatch(a)
2016-01-19 17:23:52 +01:00
if (res) {
out = res
return true
}
})
return out
}
const result = {
2016-01-19 17:23:52 +01:00
toString: function () { return '{ ' + args.join(' ') + ' }' },
input: args,
matches: makeMatchesFunction(partialMatch),
2016-01-19 17:23:52 +01:00
partialMatch: partialMatch
}
return result
2016-01-19 17:23:52 +01:00
}
function base (n) {
const name = n
2016-01-19 17:23:52 +01:00
function matches (a) {
if (typeof a === 'string') {
try {
a = multiaddr(a)
} catch (err) { // catch error
return false // also if it's invalid it's propably not matching as well so return false
}
2016-01-19 17:23:52 +01:00
}
const pnames = a.protoNames()
2016-01-19 17:23:52 +01:00
if (pnames.length === 1 && pnames[0] === name) {
return true
}
return false
}
function partialMatch (protos) {
if (protos.length === 0) {
return null
}
if (protos[0] === name) {
return protos.slice(1)
}
return null
}
return {
toString: function () { return name },
matches: matches,
partialMatch: partialMatch
}
}