using kstate with power levels should mix them
This commit is contained in:
parent
458a620f4a
commit
8d536d5ef2
7 changed files with 87 additions and 14 deletions
|
@ -34,6 +34,7 @@ CREATE TABLE IF NOT EXISTS "channel_room" (
|
||||||
"name" TEXT,
|
"name" TEXT,
|
||||||
"nick" TEXT,
|
"nick" TEXT,
|
||||||
"thread_parent" TEXT,
|
"thread_parent" TEXT,
|
||||||
|
"custom_avatar" TEXT,
|
||||||
PRIMARY KEY("channel_id")
|
PRIMARY KEY("channel_id")
|
||||||
);
|
);
|
||||||
CREATE TABLE IF NOT EXISTS "event_message" (
|
CREATE TABLE IF NOT EXISTS "event_message" (
|
||||||
|
@ -55,11 +56,11 @@ BEGIN TRANSACTION;
|
||||||
INSERT INTO guild_space (guild_id, space_id) VALUES
|
INSERT INTO guild_space (guild_id, space_id) VALUES
|
||||||
('112760669178241024', '!jjWAGMeQdNrVZSSfvz:cadence.moe');
|
('112760669178241024', '!jjWAGMeQdNrVZSSfvz:cadence.moe');
|
||||||
|
|
||||||
INSERT INTO channel_room (channel_id, room_id, name, nick, thread_parent) VALUES
|
INSERT INTO channel_room (channel_id, room_id, name, nick, thread_parent, custom_avatar) VALUES
|
||||||
('112760669178241024', '!kLRqKKUQXcibIMtOpl:cadence.moe', 'heave', 'main', NULL),
|
('112760669178241024', '!kLRqKKUQXcibIMtOpl:cadence.moe', 'heave', 'main', NULL, NULL),
|
||||||
('497161350934560778', '!edUxjVdzgUvXDUIQCK:cadence.moe', 'amanda-spam', NULL, NULL),
|
('497161350934560778', '!edUxjVdzgUvXDUIQCK:cadence.moe', 'amanda-spam', NULL, NULL, NULL),
|
||||||
('160197704226439168', '!uCtjHhfGlYbVnPVlkG:cadence.moe', 'the-stanley-parable-channel', 'bots', NULL),
|
('160197704226439168', '!uCtjHhfGlYbVnPVlkG:cadence.moe', 'the-stanley-parable-channel', 'bots', NULL, NULL),
|
||||||
('1100319550446252084', '!PnyBKvUBOhjuCucEfk:cadence.moe', 'worm-farm', NULL, NULL);
|
('1100319550446252084', '!PnyBKvUBOhjuCucEfk:cadence.moe', 'worm-farm', NULL, NULL, NULL);
|
||||||
|
|
||||||
INSERT INTO sim (discord_id, sim_name, localpart, mxid) VALUES
|
INSERT INTO sim (discord_id, sim_name, localpart, mxid) VALUES
|
||||||
('0', 'bot', '_ooye_bot', '@_ooye_bot:cadence.moe'),
|
('0', 'bot', '_ooye_bot', '@_ooye_bot:cadence.moe'),
|
||||||
|
|
|
@ -169,7 +169,7 @@ async function profileSetAvatarUrl(mxid, avatar_url) {
|
||||||
async function setUserPower(roomID, mxid, power) {
|
async function setUserPower(roomID, mxid, power) {
|
||||||
assert(roomID[0] === "!")
|
assert(roomID[0] === "!")
|
||||||
assert(mxid[0] === "@")
|
assert(mxid[0] === "@")
|
||||||
// Yes it's this hard https://github.com/matrix-org/matrix-appservice-bridge/blob/2334b0bae28a285a767fe7244dad59f5a5963037/src/components/intent.ts#L352
|
// Yes there's no shortcut https://github.com/matrix-org/matrix-appservice-bridge/blob/2334b0bae28a285a767fe7244dad59f5a5963037/src/components/intent.ts#L352
|
||||||
const powerLevels = await getStateEvent(roomID, "m.room.power_levels", "")
|
const powerLevels = await getStateEvent(roomID, "m.room.power_levels", "")
|
||||||
const users = powerLevels.users || {}
|
const users = powerLevels.users || {}
|
||||||
if (power != null) {
|
if (power != null) {
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// @ts-check
|
// @ts-check
|
||||||
|
|
||||||
const assert = require("assert")
|
const assert = require("assert").strict
|
||||||
|
const mixin = require("mixin-deep")
|
||||||
|
|
||||||
/** Mutates the input. */
|
/** Mutates the input. */
|
||||||
function kstateStripConditionals(kstate) {
|
function kstateStripConditionals(kstate) {
|
||||||
|
@ -43,18 +44,34 @@ function diffKState(actual, target) {
|
||||||
// go through each key that it should have
|
// go through each key that it should have
|
||||||
for (const key of Object.keys(target)) {
|
for (const key of Object.keys(target)) {
|
||||||
if (!key.includes("/")) throw new Error(`target kstate's key "${key}" does not contain a slash separator; if a blank state_key was intended, add a trailing slash to the kstate key.`)
|
if (!key.includes("/")) throw new Error(`target kstate's key "${key}" does not contain a slash separator; if a blank state_key was intended, add a trailing slash to the kstate key.`)
|
||||||
if (key in actual) {
|
|
||||||
|
if (key === "m.room.power_levels/") {
|
||||||
|
// Special handling for power levels, we want to deep merge the actual and target into the final state.
|
||||||
|
console.log(actual[key])
|
||||||
|
const temp = mixin({}, actual[key], target[key])
|
||||||
|
console.log(actual[key])
|
||||||
|
console.log(temp)
|
||||||
|
try {
|
||||||
|
assert.deepEqual(actual[key], temp)
|
||||||
|
} catch (e) {
|
||||||
|
// they differ. use the newly prepared object as the diff.
|
||||||
|
diff[key] = temp
|
||||||
|
}
|
||||||
|
|
||||||
|
} else if (key in actual) {
|
||||||
// diff
|
// diff
|
||||||
try {
|
try {
|
||||||
assert.deepEqual(actual[key], target[key])
|
assert.deepEqual(actual[key], target[key])
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
// they differ. reassign the target
|
// they differ. use the target as the diff.
|
||||||
diff[key] = target[key]
|
diff[key] = target[key]
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// not present, needs to be added
|
// not present, needs to be added
|
||||||
diff[key] = target[key]
|
diff[key] = target[key]
|
||||||
}
|
}
|
||||||
|
|
||||||
// keys that are missing in "actual" will not be deleted on "target" (no action)
|
// keys that are missing in "actual" will not be deleted on "target" (no action)
|
||||||
}
|
}
|
||||||
return diff
|
return diff
|
||||||
|
|
|
@ -92,3 +92,57 @@ test("diffKState: detects new properties", t => {
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
test("diffKState: power levels are mixed together", t => {
|
||||||
|
const original = {
|
||||||
|
"m.room.power_levels/": {
|
||||||
|
"ban": 50,
|
||||||
|
"events": {
|
||||||
|
"m.room.name": 100,
|
||||||
|
"m.room.power_levels": 100
|
||||||
|
},
|
||||||
|
"events_default": 0,
|
||||||
|
"invite": 50,
|
||||||
|
"kick": 50,
|
||||||
|
"notifications": {
|
||||||
|
"room": 20
|
||||||
|
},
|
||||||
|
"redact": 50,
|
||||||
|
"state_default": 50,
|
||||||
|
"users": {
|
||||||
|
"@example:localhost": 100
|
||||||
|
},
|
||||||
|
"users_default": 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const result = diffKState(original, {
|
||||||
|
"m.room.power_levels/": {
|
||||||
|
"events": {
|
||||||
|
"m.room.avatar": 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.deepEqual(result, {
|
||||||
|
"m.room.power_levels/": {
|
||||||
|
"ban": 50,
|
||||||
|
"events": {
|
||||||
|
"m.room.name": 100,
|
||||||
|
"m.room.power_levels": 100,
|
||||||
|
"m.room.avatar": 0
|
||||||
|
},
|
||||||
|
"events_default": 0,
|
||||||
|
"invite": 50,
|
||||||
|
"kick": 50,
|
||||||
|
"notifications": {
|
||||||
|
"room": 20
|
||||||
|
},
|
||||||
|
"redact": 50,
|
||||||
|
"state_default": 50,
|
||||||
|
"users": {
|
||||||
|
"@example:localhost": 100
|
||||||
|
},
|
||||||
|
"users_default": 0
|
||||||
|
}
|
||||||
|
})
|
||||||
|
t.notDeepEqual(original, result)
|
||||||
|
})
|
||||||
|
|
8
package-lock.json
generated
8
package-lock.json
generated
|
@ -16,7 +16,7 @@
|
||||||
"js-yaml": "^4.1.0",
|
"js-yaml": "^4.1.0",
|
||||||
"matrix-appservice": "^2.0.0",
|
"matrix-appservice": "^2.0.0",
|
||||||
"matrix-js-sdk": "^24.1.0",
|
"matrix-js-sdk": "^24.1.0",
|
||||||
"mixin-deep": "^2.0.1",
|
"mixin-deep": "github:cloudrac3r/mixin-deep#v3.0.0",
|
||||||
"node-fetch": "^2.6.7",
|
"node-fetch": "^2.6.7",
|
||||||
"prettier-bytes": "^1.0.4",
|
"prettier-bytes": "^1.0.4",
|
||||||
"snowtransfer": "^0.8.0",
|
"snowtransfer": "^0.8.0",
|
||||||
|
@ -2111,9 +2111,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/mixin-deep": {
|
"node_modules/mixin-deep": {
|
||||||
"version": "2.0.1",
|
"version": "3.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-2.0.1.tgz",
|
"resolved": "git+ssh://git@github.com/cloudrac3r/mixin-deep.git#2dd70d6b8644263f7ed2c1620506c9eb3f11d32a",
|
||||||
"integrity": "sha512-imbHQNRglyaplMmjBLL3V5R6Bfq5oM+ivds3SKgc6oRtzErEnBUUc5No11Z2pilkUvl42gJvi285xTNswcKCMA==",
|
"license": "MIT",
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=6"
|
"node": ">=6"
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
"js-yaml": "^4.1.0",
|
"js-yaml": "^4.1.0",
|
||||||
"matrix-appservice": "^2.0.0",
|
"matrix-appservice": "^2.0.0",
|
||||||
"matrix-js-sdk": "^24.1.0",
|
"matrix-js-sdk": "^24.1.0",
|
||||||
"mixin-deep": "^2.0.1",
|
"mixin-deep": "github:cloudrac3r/mixin-deep#v3.0.0",
|
||||||
"node-fetch": "^2.6.7",
|
"node-fetch": "^2.6.7",
|
||||||
"prettier-bytes": "^1.0.4",
|
"prettier-bytes": "^1.0.4",
|
||||||
"snowtransfer": "^0.8.0",
|
"snowtransfer": "^0.8.0",
|
||||||
|
|
1
stdin.js
1
stdin.js
|
@ -14,6 +14,7 @@ const mreq = sync.require("./matrix/mreq")
|
||||||
const api = sync.require("./matrix/api")
|
const api = sync.require("./matrix/api")
|
||||||
const sendEvent = sync.require("./m2d/actions/send-event")
|
const sendEvent = sync.require("./m2d/actions/send-event")
|
||||||
const eventDispatcher = sync.require("./d2m/event-dispatcher")
|
const eventDispatcher = sync.require("./d2m/event-dispatcher")
|
||||||
|
const ks = sync.require("./matrix/kstate")
|
||||||
const guildID = "112760669178241024"
|
const guildID = "112760669178241024"
|
||||||
|
|
||||||
const extraContext = {}
|
const extraContext = {}
|
||||||
|
|
Loading…
Reference in a new issue