add a datamanager to handle subprocesses
This commit is contained in:
parent
ebaaa23553
commit
3d7247f18c
3 changed files with 307 additions and 236 deletions
272
dataManager.js
Normal file
272
dataManager.js
Normal file
|
|
@ -0,0 +1,272 @@
|
||||||
|
const axios = require('axios')
|
||||||
|
const { Config, System, Util } = require('SimplyAPI')
|
||||||
|
|
||||||
|
const pkUrl = Config.pk_url
|
||||||
|
const pkHeader = {
|
||||||
|
'Content-Type': 'application/json',
|
||||||
|
'Authorization': Config.pk_token
|
||||||
|
}
|
||||||
|
|
||||||
|
let cache = {}
|
||||||
|
async function initializeCache() {
|
||||||
|
let system = new System(Config)
|
||||||
|
cache.frontHistory = await system.getFronters()
|
||||||
|
}
|
||||||
|
|
||||||
|
function unknownError400() {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
function unknownTarget(target) {
|
||||||
|
console.log('::SimplyWS:: Unknown update target: ' + target + '\n::SimplyWS:: Full message: ' + e)
|
||||||
|
}
|
||||||
|
|
||||||
|
function unrecognizedMessage(msg) {
|
||||||
|
console.log('::SimplyWS:: Unrecognized message: ' + msg + '\n::SimplyWS:: Full message: ' + e)
|
||||||
|
}
|
||||||
|
|
||||||
|
// async function asyncForEach(array, callback) {
|
||||||
|
// for (let index = 0; index < array.length; index++) {
|
||||||
|
// await callback(array[index], index, array)
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
async function getPKFronters() {
|
||||||
|
let members = []
|
||||||
|
let fronters = await axios.get(`${pkUrl}/systems/${Config.pk_system}/fronters`, {
|
||||||
|
headers: pkHeader
|
||||||
|
})
|
||||||
|
.catch((err) => {
|
||||||
|
if (err.toJSON().status == 429)
|
||||||
|
// Too many requests
|
||||||
|
setTimeout(async () => {
|
||||||
|
return await getPKFronters()
|
||||||
|
}, 1500)
|
||||||
|
})
|
||||||
|
|
||||||
|
if (fronters != undefined) {
|
||||||
|
fronters.data.members.forEach((key, value) => {
|
||||||
|
members.push(key.id)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
return members
|
||||||
|
}
|
||||||
|
|
||||||
|
async function findPrimary() {
|
||||||
|
let found = false
|
||||||
|
let system = new System(Config)
|
||||||
|
let fronters = await system.getFronters()
|
||||||
|
return new Promise(async (resolve) => {
|
||||||
|
await Util.asyncForEach(fronters, async (fronter) => {
|
||||||
|
if (fronter.content.customStatus) {
|
||||||
|
if (fronter.content.customStatus.toLowerCase().includes("primary")) {
|
||||||
|
let member = await system.getMemberById(fronter.content.member)
|
||||||
|
resolve(member.content.pkId)
|
||||||
|
found = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
if (!found)
|
||||||
|
resolve(false)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
async function determineAction(eventData, frontData = []) {
|
||||||
|
if (frontData.length == 0)
|
||||||
|
return 'remove'
|
||||||
|
let action = ''
|
||||||
|
|
||||||
|
// check for cache
|
||||||
|
if (!cache.frontHistory) {
|
||||||
|
let system = new System(Config)
|
||||||
|
let frontHistory = await system.getFronters()
|
||||||
|
cache.frontHistory = frontHistory
|
||||||
|
}
|
||||||
|
|
||||||
|
// get the difference between cached history and current front
|
||||||
|
let diff = await calculateDiff(cache.frontHistory, frontData)
|
||||||
|
// we handle one thing at a time, although this should be expanded since you can modify multiple custom statuses at once
|
||||||
|
if (diff.length >= 1) {
|
||||||
|
if (diff[0].content.customStatus || eventData.content.customStatus || diff[0].content.customStatus == "" || eventData.content.customStatus == "") {
|
||||||
|
// check if customStatus value is in cache
|
||||||
|
let foundInCache = Object.keys(cache.frontHistory).filter((key) => {
|
||||||
|
return cache.frontHistory[key] === diff[0].content.customStatus
|
||||||
|
})
|
||||||
|
|
||||||
|
// if value is unique, publish action
|
||||||
|
if (foundInCache.length == 0) {
|
||||||
|
action = 'customStatus'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (eventData.content.customStatus == '')
|
||||||
|
return 'customStatus'
|
||||||
|
console.error('::SimplyWS:: Unrecognized diff: ' + JSON.stringify(diff))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// if there's an endTime, it was a removal event
|
||||||
|
if (eventData.content.endTime && !eventData.content.live) {
|
||||||
|
action = 'remove'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return action
|
||||||
|
}
|
||||||
|
|
||||||
|
async function insertFront(member) {
|
||||||
|
// get current fronters and add new fronter
|
||||||
|
let system = new System(Config)
|
||||||
|
let fronters = await getPKFronters()
|
||||||
|
fronters.push(member.content.pkId)
|
||||||
|
|
||||||
|
// find the "primary" fronter to move to the first element in the list
|
||||||
|
let primary = await findPrimary()
|
||||||
|
if (primary) {
|
||||||
|
if (fronters.indexOf(primary) > 0) {
|
||||||
|
fronters.splice(fronters.indexOf(primary), 1)
|
||||||
|
fronters.unshift(primary)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// cache front
|
||||||
|
cache.frontHistory = await system.getFronters()
|
||||||
|
|
||||||
|
// post the new switch
|
||||||
|
axios.post(`${pkUrl}/systems/${Config.pk_system}/switches`, JSON.stringify({ "members": fronters }), {
|
||||||
|
headers: pkHeader
|
||||||
|
})
|
||||||
|
.catch(err => {
|
||||||
|
if (err.toJSON().status == 400)
|
||||||
|
unknownError400()
|
||||||
|
else if (err.toJSON().status == 429)
|
||||||
|
// Too many requests
|
||||||
|
setTimeout(function () {
|
||||||
|
insertFront(member)
|
||||||
|
}, 1000)
|
||||||
|
return
|
||||||
|
})
|
||||||
|
|
||||||
|
let checkFront = await getPKFronters()
|
||||||
|
if (!checkFront.includes(member.content.pkId)) {
|
||||||
|
await insertFront(member)
|
||||||
|
return
|
||||||
|
} else {
|
||||||
|
console.log('::SimplyWS:: ' + member.content.name + ' was added to the front.')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function removeFront(member) {
|
||||||
|
let system = new System(Config)
|
||||||
|
let fronters = await getPKFronters()
|
||||||
|
let index = fronters.indexOf(member.content.pkId)
|
||||||
|
fronters.splice(index, 1)
|
||||||
|
|
||||||
|
// find the "primary" fronter to move to the first element in the list
|
||||||
|
let p = await findPrimary()
|
||||||
|
if (p) {
|
||||||
|
if (fronters.indexOf(p) > 0) {
|
||||||
|
fronters.splice(fronters.indexOf(p), 1)
|
||||||
|
fronters.unshift(p)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// cache front
|
||||||
|
cache.frontHistory = await system.getFronters()
|
||||||
|
|
||||||
|
// post the new switch
|
||||||
|
axios.post(`${pkUrl}/systems/${Config.pk_system}/switches`, JSON.stringify({ "members": fronters }), {
|
||||||
|
headers: pkHeader
|
||||||
|
})
|
||||||
|
.catch(err => {
|
||||||
|
if (err.toJSON().status == 400)
|
||||||
|
unknownError400()
|
||||||
|
else if (err.toJSON().status == 429)
|
||||||
|
// Too many requests
|
||||||
|
setTimeout(function () {
|
||||||
|
removeFront(member)
|
||||||
|
}, 1000)
|
||||||
|
return
|
||||||
|
})
|
||||||
|
|
||||||
|
let checkFront = await getPKFronters()
|
||||||
|
if (checkFront.includes(member.content.pkId)) {
|
||||||
|
await removeFront(member)
|
||||||
|
return
|
||||||
|
} else {
|
||||||
|
console.log('::SimplyWS:: ' + member.content.name + ' was removed from the front.')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function updateCustomStatus(member) {
|
||||||
|
// find the "primary" fronter to move to the first element in the list
|
||||||
|
let system = new System(Config)
|
||||||
|
let fronters = await getPKFronters()
|
||||||
|
let primary = await findPrimary()
|
||||||
|
if (primary && fronters.length > 1) {
|
||||||
|
if (fronters.indexOf(primary) >= 0) {
|
||||||
|
fronters.splice(fronters.indexOf(primary), 1)
|
||||||
|
fronters.unshift(primary)
|
||||||
|
|
||||||
|
// cache front
|
||||||
|
cache.frontHistory = await system.getFronters()
|
||||||
|
|
||||||
|
// post the new switch
|
||||||
|
axios.post(`${pkUrl}/systems/${Config.pk_system}/switches`, JSON.stringify({ "members": fronters }), {
|
||||||
|
headers: pkHeader
|
||||||
|
})
|
||||||
|
.catch(err => {
|
||||||
|
if (err.toJSON().status == 400)
|
||||||
|
unknownError400()
|
||||||
|
else if (err.toJSON().status == 429)
|
||||||
|
// Too many requests
|
||||||
|
setTimeout(function () {
|
||||||
|
updateCustomStatus(member)
|
||||||
|
}, 1000)
|
||||||
|
return
|
||||||
|
})
|
||||||
|
|
||||||
|
console.log('::SimplyWS:: ' + member.content.name + ' is now the primary fronter.')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
console.log('::SimplyWS:: ' + member.content.name + ' changed custom status.')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const { inspect } = require('util')
|
||||||
|
const transform = require('lodash.transform')
|
||||||
|
const isEqual = require('lodash.isequal')
|
||||||
|
const isArray = require('lodash.isarray')
|
||||||
|
const isObject = require('lodash.isobject')
|
||||||
|
const { PassThrough } = require('stream')
|
||||||
|
async function calculateDiff(origObj, newObj) {
|
||||||
|
return new Promise(function (resolve) {
|
||||||
|
changes = (newObj, origObj) => {
|
||||||
|
let arrayIndexCounter = 0
|
||||||
|
return transform(newObj, function (result, value, key) {
|
||||||
|
if (!isEqual(value, origObj[key])) {
|
||||||
|
let resultKey = isArray(origObj) ? arrayIndexCounter++ : key
|
||||||
|
result[resultKey] = (isObject(value) && isObject(origObj[key])) ? changes(value, origObj[key]) : value
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
resolve(changes(newObj, origObj))
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
initializeCache,
|
||||||
|
unknownError400,
|
||||||
|
unknownTarget,
|
||||||
|
unrecognizedMessage,
|
||||||
|
getPKFronters,
|
||||||
|
findPrimary,
|
||||||
|
determineAction,
|
||||||
|
insertFront,
|
||||||
|
removeFront,
|
||||||
|
updateCustomStatus,
|
||||||
|
calculateDiff
|
||||||
|
}
|
||||||
270
index.js
270
index.js
|
|
@ -1,18 +1,11 @@
|
||||||
const dotenv = require('dotenv')
|
const dotenv = require('dotenv')
|
||||||
dotenv.config()
|
dotenv.config()
|
||||||
//const config = process.env
|
|
||||||
|
|
||||||
const axios = require('axios')
|
const { Config, System } = require('SimplyAPI')
|
||||||
const { Config, System, FrontHistory } = require('SimplyAPI')
|
const { Util } = require('SimplyAPI')
|
||||||
|
const { initializeCache, determineAction, insertFront, removeFront, updateCustomStatus } = require('./dataManager')
|
||||||
const pkUrl = Config.pk_url
|
|
||||||
const pkHeader = {
|
|
||||||
'Content-Type': 'application/json',
|
|
||||||
'Authorization': Config.pk_token
|
|
||||||
}
|
|
||||||
|
|
||||||
let e
|
let e
|
||||||
let cache = {}
|
|
||||||
main = async () => {
|
main = async () => {
|
||||||
openWebSocket()
|
openWebSocket()
|
||||||
}
|
}
|
||||||
|
|
@ -25,258 +18,63 @@ openWebSocket = async () => {
|
||||||
wss.onClose = (e) => { console.log('SimplyWS/onClose :: %s', e); e = '' }
|
wss.onClose = (e) => { console.log('SimplyWS/onClose :: %s', e); e = '' }
|
||||||
wss.onError = (e) => { console.log('SimplyWS/onError :: %s', e) }
|
wss.onError = (e) => { console.log('SimplyWS/onError :: %s', e) }
|
||||||
|
|
||||||
wss.onMessage = async (raw) => {
|
wss.onMessage = (raw) => {
|
||||||
e = raw
|
e = raw
|
||||||
let data = JSON.parse(e)
|
let data = JSON.parse(e)
|
||||||
if (Object.keys(data).length === 0) return
|
if (Object.keys(data).length === 0) return
|
||||||
|
|
||||||
switch (data.msg) {
|
switch (data.msg) {
|
||||||
case "Successfully authenticated":
|
case "Successfully authenticated":
|
||||||
console.log('::SimplyWS:: authenticated')
|
console.log('::SimplyWS:: authenticated')
|
||||||
// cache current front
|
// cache current front
|
||||||
let system = new System(Config)
|
initializeCache()
|
||||||
cache.frontHistory = await system.getFronters()
|
break
|
||||||
break;
|
|
||||||
case "Authentication violation: Token is missing or invalid. Goodbye :)":
|
case "Authentication violation: Token is missing or invalid. Goodbye :)":
|
||||||
console.log('::SimplyWS:: invalid token, exiting..')
|
console.log('::SimplyWS:: invalid token, exiting..')
|
||||||
process.exit(1)
|
process.exit(1)
|
||||||
case "update":
|
case "update":
|
||||||
let response = await generateResponse(data.target, data);
|
update(data)
|
||||||
if (response) console.log('::SimplyWS:: ' + response)
|
break
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
//unrecognizedMessage(data.msg)
|
//unrecognizedMessage(data.msg)
|
||||||
break;
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
generateResponse = async (target, data) => {
|
update = async (data) => {
|
||||||
let response = ''
|
let target = data.target
|
||||||
switch (target) {
|
switch (target) {
|
||||||
case 'frontHistory':
|
case 'frontHistory':
|
||||||
//response += 'Front has changed!'
|
//response += 'Front has changed!'
|
||||||
await asyncForEach(data.results, async (o) => {
|
await Util.asyncForEach(data.results, async (o) => {
|
||||||
let system = new System(Config)
|
let system = new System(Config)
|
||||||
await system.getMemberById(o.content.member)
|
let member = await system.getMemberById(o.content.member)
|
||||||
.then(async (member) => {
|
// insert
|
||||||
if (o.operationType == "insert") {
|
if (o.operationType == "insert") {
|
||||||
// get current fronters and add new fronter
|
insertFront(member)
|
||||||
let fronters = await getPKFronters()
|
}
|
||||||
fronters.push(member.content.pkId)
|
else {
|
||||||
|
// get current fronters and patch the list
|
||||||
|
let frontData = await system.getFronters()
|
||||||
|
let action = await determineAction(o, frontData)
|
||||||
|
// if delete operation, remove the member from the list
|
||||||
|
switch (action) {
|
||||||
|
case "remove":
|
||||||
|
removeFront(member)
|
||||||
|
break
|
||||||
|
|
||||||
// find the "primary" fronter to move to the first element in the list
|
case "customStatus":
|
||||||
let primary = findPrimary()
|
updateCustomStatus(member)
|
||||||
if (primary) {
|
break
|
||||||
if (fronters.indexOf(primary) > 0) {
|
}
|
||||||
fronters.splice(fronters.indexOf(primary), 1)
|
}
|
||||||
fronters.unshift(primary)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// cache front
|
|
||||||
cache.frontHistory = await system.getFronters()
|
|
||||||
|
|
||||||
// post the new switch
|
|
||||||
axios.post(`${pkUrl}/systems/${Config.pk_system}/switches`, JSON.stringify({"members": fronters}), {
|
|
||||||
headers: pkHeader
|
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
if (err.toJSON().status == 400) unknownError400()
|
|
||||||
else console.error(err.message)
|
|
||||||
})
|
|
||||||
|
|
||||||
response += '' + member.content.name + ' was added to the front.'
|
|
||||||
return
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
// get current fronters and patch the list
|
|
||||||
let fronters = await getPKFronters()
|
|
||||||
let frontData = await system.getFronters()
|
|
||||||
let action = await determineAction(o, frontData)
|
|
||||||
// if delete operation, remove the member from the list
|
|
||||||
switch (action) {
|
|
||||||
case "remove":
|
|
||||||
let index = fronters.indexOf(member.content.pkId)
|
|
||||||
fronters.splice(index, 1)
|
|
||||||
|
|
||||||
// find the "primary" fronter to move to the first element in the list
|
|
||||||
let p = findPrimary()
|
|
||||||
if (p) {
|
|
||||||
if (fronters.indexOf(p) > 0) {
|
|
||||||
fronters.splice(fronters.indexOf(p), 1)
|
|
||||||
fronters.unshift(p)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// cache front
|
|
||||||
cache.frontHistory = await system.getFronters()
|
|
||||||
|
|
||||||
// post the new switch
|
|
||||||
axios.post(`${pkUrl}/systems/${Config.pk_system}/switches`, JSON.stringify({ "members": fronters }), {
|
|
||||||
headers: pkHeader
|
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
if (err.toJSON().status == 400) unknownError400()
|
|
||||||
else console.error(err.message)
|
|
||||||
})
|
|
||||||
|
|
||||||
response += '' + member.content.name + ' was removed from the front.'
|
|
||||||
break;
|
|
||||||
|
|
||||||
case "customStatus":
|
|
||||||
// find the "primary" fronter to move to the first element in the list
|
|
||||||
let primary = await findPrimary()
|
|
||||||
if (primary && fronters.length > 1) {
|
|
||||||
if (fronters.indexOf(primary) >= 0) {
|
|
||||||
fronters.splice(fronters.indexOf(primary), 1)
|
|
||||||
fronters.unshift(primary)
|
|
||||||
|
|
||||||
// cache front
|
|
||||||
cache.frontHistory = await system.getFronters()
|
|
||||||
|
|
||||||
// post the new switch
|
|
||||||
axios.post(`${pkUrl}/systems/${Config.pk_system}/switches`, JSON.stringify({ "members": fronters }), {
|
|
||||||
headers: pkHeader
|
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
if (err.toJSON().status == 400) unknownError400()
|
|
||||||
else console.error(err.message)
|
|
||||||
})
|
|
||||||
response += '' + member.content.name + ' is now the primary fronter.'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
response += '' + member.content.name + ' changed custom status.'
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
console.log('::SimplyWS:: Error finding member: ' + err)
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
break;
|
break
|
||||||
default:
|
default:
|
||||||
//unknownTarget(data.target)
|
//unknownTarget(data.target)
|
||||||
break;
|
break
|
||||||
}
|
}
|
||||||
return response
|
|
||||||
}
|
|
||||||
|
|
||||||
unknownError400 = () => {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
unknownTarget = (target) => {
|
|
||||||
console.log('::SimplyWS:: Unknown update target: ' + target + '\n::SimplyWS:: Full message: ' + e)
|
|
||||||
}
|
|
||||||
|
|
||||||
unrecognizedMessage = (msg) => {
|
|
||||||
console.log('::SimplyWS:: Unrecognized message: ' + msg + '\n::SimplyWS:: Full message: ' + e)
|
|
||||||
}
|
|
||||||
|
|
||||||
getPKFronters = async () => {
|
|
||||||
let members = []
|
|
||||||
let fronters = await axios.get(`${pkUrl}/systems/${Config.pk_system}/fronters`, {
|
|
||||||
headers: pkHeader
|
|
||||||
})
|
|
||||||
.catch(err => console.error("An error occured while getting current fronters: " + err.message))
|
|
||||||
|
|
||||||
fronters.data.members.forEach((key, value) => {
|
|
||||||
members.push(key.id)
|
|
||||||
})
|
|
||||||
|
|
||||||
return members
|
|
||||||
}
|
|
||||||
|
|
||||||
findPrimary = async () => {
|
|
||||||
let found = false
|
|
||||||
let system = new System(Config)
|
|
||||||
let fronters = await system.getFronters()
|
|
||||||
return new Promise(async (resolve) => {
|
|
||||||
await asyncForEach(fronters, async (fronter) => {
|
|
||||||
if (fronter.content.customStatus) {
|
|
||||||
if (fronter.content.customStatus.toLowerCase().includes("primary")) {
|
|
||||||
let member = await system.getMemberById(fronter.content.member)
|
|
||||||
resolve(member.content.pkId)
|
|
||||||
found = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
if (!found) resolve(false)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
determineAction = async (eventData, frontData = []) => {
|
|
||||||
if (frontData.length == 0) return 'remove'
|
|
||||||
let action = ''
|
|
||||||
|
|
||||||
// check for cache
|
|
||||||
if (!cache.frontHistory) {
|
|
||||||
let system = new System(Config)
|
|
||||||
let frontHistory = await system.getFronters()
|
|
||||||
cache.frontHistory = frontHistory
|
|
||||||
}
|
|
||||||
|
|
||||||
// get the difference between cached history and current front
|
|
||||||
let diff = await calculateDiff(cache.frontHistory, frontData)
|
|
||||||
// we handle one thing at a time, although this should be expanded since you can modify multiple custom statuses at once
|
|
||||||
if (diff.length >= 1) {
|
|
||||||
if (diff[0].content.customStatus || eventData.content.customStatus || diff[0].content.customStatus == "" || eventData.content.customStatus == "") {
|
|
||||||
// check if customStatus value is in cache
|
|
||||||
let foundInCache = Object.keys(cache.frontHistory).filter((key) => {
|
|
||||||
return cache.frontHistory[key] === diff[0].content.customStatus
|
|
||||||
})
|
|
||||||
|
|
||||||
// if value is unique, publish action
|
|
||||||
if (foundInCache.length == 0) {
|
|
||||||
action = 'customStatus'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if (eventData.content.customStatus == '') return 'customStatus'
|
|
||||||
console.error('::SimplyWS:: Unrecognized diff: ' + JSON.stringify(diff))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
// if there's an endTime, it was a removal event
|
|
||||||
if (eventData.content.endTime && !eventData.content.live) {
|
|
||||||
action = 'remove'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return action
|
|
||||||
}
|
|
||||||
|
|
||||||
asyncForEach = async (array, callback) => {
|
|
||||||
for (let index = 0; index < array.length; index++) {
|
|
||||||
await callback(array[index], index, array);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const { inspect } = require('util')
|
|
||||||
const transform = require('lodash.transform')
|
|
||||||
const isEqual = require('lodash.isequal')
|
|
||||||
const isArray = require('lodash.isarray')
|
|
||||||
const isObject = require('lodash.isobject')
|
|
||||||
const { PassThrough } = require('stream')
|
|
||||||
calculateDiff = async (origObj, newObj) => {
|
|
||||||
return new Promise(function (resolve) {
|
|
||||||
changes = (newObj, origObj) => {
|
|
||||||
let arrayIndexCounter = 0
|
|
||||||
return transform(newObj, function (result, value, key) {
|
|
||||||
if (!isEqual(value, origObj[key])) {
|
|
||||||
let resultKey = isArray(origObj) ? arrayIndexCounter++ : key
|
|
||||||
result[resultKey] = (isObject(value) && isObject(origObj[key])) ? changes(value, origObj[key]) : value
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
resolve(changes(newObj, origObj))
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
main()
|
main()
|
||||||
|
|
@ -9,6 +9,7 @@
|
||||||
},
|
},
|
||||||
"author": "padlocks",
|
"author": "padlocks",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
"repository": "github:padlocks/Compatiplural",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"ajv": "^8.10.0",
|
"ajv": "^8.10.0",
|
||||||
"axios": "^0.26.0",
|
"axios": "^0.26.0",
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue