upgrade test system

This commit is contained in:
derpystuff 2024-01-12 21:38:02 +01:00
parent 79afe37d42
commit 246a64bca4
9 changed files with 76 additions and 83 deletions

View file

@ -7,7 +7,6 @@ const { paginator } = require('../../../labscore/client');
const { editOrReply } = require('../../../labscore/utils/message'); const { editOrReply } = require('../../../labscore/utils/message');
const { Permissions } = require("detritus-client/lib/constants"); const { Permissions } = require("detritus-client/lib/constants");
const { canUseLimitedTestCommands } = require('../../../labscore/utils/testing');
function createHelpPage(context, title, contents, descriptions) { function createHelpPage(context, title, contents, descriptions) {
return page(createEmbed("default", context, { return page(createEmbed("default", context, {
@ -109,7 +108,7 @@ module.exports = {
}, },
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.READ_MESSAGE_HISTORY], permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.READ_MESSAGE_HISTORY],
run: async (context, args) => { run: async (context, args) => {
if (canUseLimitedTestCommands(context)) categories["limited"] = `${iconPill("stars", "Limited Test Commands")}`; if(await hasFeature(context, "core/help")) categories["limited"] = `${iconPill("stars", "Limited Test Commands")}`;
else if (categories["limited"]) delete categories["limited"] else if (categories["limited"]) delete categories["limited"]
if (args.command) { if (args.command) {

View file

@ -0,0 +1,21 @@
const { createEmbed } = require("../../../labscore/utils/embed");
const { editOrReply } = require("../../../labscore/utils/message");
const { getTestConfig } = require("../../../labscore/utils/testing");
module.exports = {
name: "refresh-configs",
metadata: {
description: 'Reload configs.',
description_short: 'Reload configs.',
examples: ['refresh-configs'],
category: 'dev',
usage: 'refresh-configs'
},
onBefore: context => context.user.isClientOwner,
onCancel: ()=>{},
run: async (context, args) => {
await context.triggerTyping();
let c = await getTestConfig();
return await editOrReply(context, createEmbed("success", context, "Refreshed configs (v"+c.revision+")."));
}
};

View file

@ -9,7 +9,7 @@ const { Permissions } = require("detritus-client/lib/constants");
const superagent = require('superagent'); const superagent = require('superagent');
const { STATIC_ICONS } = require("../../../labscore/utils/statics"); const { STATIC_ICONS } = require("../../../labscore/utils/statics");
const { stringwrap, iconPill, smallIconPill } = require("../../../labscore/utils/markdown"); const { stringwrap, iconPill, smallIconPill } = require("../../../labscore/utils/markdown");
const { canUseLimitedTestCommands } = require("../../../labscore/utils/testing"); const { hasFeature } = require("../../../labscore/utils/testing");
module.exports = { module.exports = {
name: 'gemini-vision', name: 'gemini-vision',
label: 'text', label: 'text',
@ -23,8 +23,7 @@ module.exports = {
}, },
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.ATTACH_FILES, Permissions.READ_MESSAGE_HISTORY], permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.ATTACH_FILES, Permissions.READ_MESSAGE_HISTORY],
run: async (context, args) => { run: async (context, args) => {
context.triggerTyping(); if(!await hasFeature(context, "ai/gemini/vision")) return;
if(!canUseLimitedTestCommands(context)) return;
context.triggerTyping(); context.triggerTyping();
// for the sake of privacy, make the context window one message // for the sake of privacy, make the context window one message

View file

@ -6,7 +6,7 @@ const { Permissions } = require("detritus-client/lib/constants");
const { STATIC_ICONS } = require("../../../labscore/utils/statics"); const { STATIC_ICONS } = require("../../../labscore/utils/statics");
const { stringwrap, iconPill, smallIconPill } = require("../../../labscore/utils/markdown"); const { stringwrap, iconPill, smallIconPill } = require("../../../labscore/utils/markdown");
const { canUseLimitedTestCommands } = require("../../../labscore/utils/testing"); const { hasFeature } = require("../../../labscore/utils/testing");
module.exports = { module.exports = {
name: 'gemini', name: 'gemini',
label: 'text', label: 'text',
@ -20,8 +20,7 @@ module.exports = {
}, },
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.ATTACH_FILES, Permissions.READ_MESSAGE_HISTORY], permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.ATTACH_FILES, Permissions.READ_MESSAGE_HISTORY],
run: async (context, args) => { run: async (context, args) => {
context.triggerTyping(); if(!await hasFeature(context, "ai/gemini/text")) return;
if(!canUseLimitedTestCommands(context)) return;
context.triggerTyping(); context.triggerTyping();
if(!args.text) return editOrReply(context, createEmbed("warning", context, `Missing Parameter (text).`)) if(!args.text) return editOrReply(context, createEmbed("warning", context, `Missing Parameter (text).`))

View file

@ -1,7 +1,6 @@
const { createEmbed } = require('../../../labscore/utils/embed') const { createEmbed } = require('../../../labscore/utils/embed')
const { editOrReply } = require('../../../labscore/utils/message') const { editOrReply } = require('../../../labscore/utils/message')
const { canUseLimitedTestCommands } = require('../../../labscore/utils/testing')
const { STATIC_ICONS } = require('../../../labscore/utils/statics'); const { STATIC_ICONS } = require('../../../labscore/utils/statics');
const superagent = require('superagent') const superagent = require('superagent')
@ -10,6 +9,7 @@ const { iconPill, stringwrap } = require('../../../labscore/utils/markdown')
const { Permissions, InteractionCallbackTypes } = require("detritus-client/lib/constants"); const { Permissions, InteractionCallbackTypes } = require("detritus-client/lib/constants");
const { Components } = require('detritus-client/lib/utils'); const { Components } = require('detritus-client/lib/utils');
const { bard } = require('../../../labscore/api/obelisk'); const { bard } = require('../../../labscore/api/obelisk');
const { hasFeature } = require('../../../labscore/utils/testing');
module.exports = { module.exports = {
name: 'bard', name: 'bard',
@ -24,7 +24,7 @@ module.exports = {
args: [], args: [],
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.ATTACH_FILES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.READ_MESSAGE_HISTORY], permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.ATTACH_FILES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.READ_MESSAGE_HISTORY],
run: async (context, args) => { run: async (context, args) => {
if(!canUseLimitedTestCommands(context)) return; if(!await hasFeature(context, "ai/bard")) return;
context.triggerTyping(); context.triggerTyping();
if(!args.text) return editOrReply(context, createEmbed("warning", context, `Missing Parameter (text).`)) if(!args.text) return editOrReply(context, createEmbed("warning", context, `Missing Parameter (text).`))

View file

@ -1,45 +0,0 @@
const { createEmbed } = require('../../../labscore/utils/embed')
const { editOrReply } = require('../../../labscore/utils/message')
const superagent = require('superagent')
const { codeblock, iconPill, smallIconPill } = require('../../../labscore/utils/markdown')
const { Permissions } = require("detritus-client/lib/constants");
const { canUseLimitedTestCommands } = require('../../../labscore/utils/testing')
const { STATICS } = require('../../../labscore/utils/statics');
const { chatgpt } = require('../../../labscore/api/obelisk');
module.exports = {
name: 'disstrack',
label: 'text',
metadata: {
description: `${iconPill("generative_ai", "LIMITED TESTING")}\n\nAI Generated Disstracks, powered by ChatGPT`,
description_short: 'AI generated disstracks.',
examples: ['disstrack'],
category: 'limited',
usage: 'disstrack <prompt>'
},
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.READ_MESSAGE_HISTORY],
run: async (context, args) => {
if(!canUseLimitedTestCommands(context)) return;
context.triggerTyping();
if(!args.text) return editOrReply(context, createEmbed("warning", context, `Missing Parameter (text).`))
try{
await editOrReply(context, createEmbed("ai", context, "Spitting bars..."))
let res = await chatgpt(context, "Write a disstrack about the subject the user supplies. The disstrack should have at least one verse and a chorus.", args.text);
res = res.response;
return editOrReply(context, createEmbed("default", context, {
description: smallIconPill("generative_ai", args.text) + '\n' + codeblock("ansi", [res.body.output.substr(0, 2020 - args.text.length)]),
footer: {
text: `Generative AI is experimental. • ${context.application.name}`,
iconUrl: STATICS.openai
}
}))
}catch(e){
console.log(e)
return editOrReply(context, createEmbed("error", context, `Unable to generate text.`))
}
}
};

View file

@ -1,7 +1,6 @@
const { createEmbed } = require('../../../labscore/utils/embed') const { createEmbed } = require('../../../labscore/utils/embed')
const { editOrReply } = require('../../../labscore/utils/message') const { editOrReply } = require('../../../labscore/utils/message')
const { canUseLimitedTestCommands, isLimitedTestUser } = require('../../../labscore/utils/testing')
const { STATIC_ICONS } = require('../../../labscore/utils/statics'); const { STATIC_ICONS } = require('../../../labscore/utils/statics');
const superagent = require('superagent') const superagent = require('superagent')
@ -9,6 +8,7 @@ const { iconPill, stringwrap, smallIconPill } = require('../../../labscore/utils
const { Permissions } = require("detritus-client/lib/constants"); const { Permissions } = require("detritus-client/lib/constants");
const { palm2 } = require('../../../labscore/api/obelisk'); const { palm2 } = require('../../../labscore/api/obelisk');
const { hasFeature } = require('../../../labscore/utils/testing');
module.exports = { module.exports = {
name: 'palm', name: 'palm',
@ -27,7 +27,7 @@ module.exports = {
], ],
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.ATTACH_FILES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.READ_MESSAGE_HISTORY], permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.ATTACH_FILES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.READ_MESSAGE_HISTORY],
run: async (context, args) => { run: async (context, args) => {
if(!canUseLimitedTestCommands(context)) return; if(!await hasFeature(context, "ai/palm")) return;
context.triggerTyping(); context.triggerTyping();
if(!args.text) return editOrReply(context, createEmbed("warning", context, `Missing Parameter (text).`)) if(!args.text) return editOrReply(context, createEmbed("warning", context, `Missing Parameter (text).`))

View file

@ -4,9 +4,9 @@ const { editOrReply } = require('../../../labscore/utils/message')
const { iconPill, smallIconPill } = require('../../../labscore/utils/markdown') const { iconPill, smallIconPill } = require('../../../labscore/utils/markdown')
const { Permissions } = require("detritus-client/lib/constants"); const { Permissions } = require("detritus-client/lib/constants");
const { canUseLimitedTestCommands } = require('../../../labscore/utils/testing')
const { STATIC_ICONS } = require('../../../labscore/utils/statics'); const { STATIC_ICONS } = require('../../../labscore/utils/statics');
const { summarizeWebpage } = require('../../../labscore/api/obelisk'); const { summarizeWebpage } = require('../../../labscore/api/obelisk');
const { hasFeature } = require('../../../labscore/utils/testing');
const URL_REGEX = /https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([^> \n]*)/ const URL_REGEX = /https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([^> \n]*)/
@ -23,7 +23,7 @@ module.exports = {
}, },
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.READ_MESSAGE_HISTORY], permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS, Permissions.READ_MESSAGE_HISTORY],
run: async (context, args) => { run: async (context, args) => {
if(!canUseLimitedTestCommands(context)) return; if(!await hasFeature(context, "flamingo/summary")) return;
context.triggerTyping(); context.triggerTyping();
let content = args.text; let content = args.text;

View file

@ -1,37 +1,57 @@
const superagent = require('superagent');
// Get Test Config let TESTING_REVISION = "-1";
let LIMITED_TEST_GUILDS;
if(process.env.TESTING_SERVER_IDS) LIMITED_TEST_GUILDS = process.env.TESTING_SERVER_IDS.split(';')
let LIMITED_TEST_CHANNELS;
if(process.env.TESTING_CHANNEL_IDS) LIMITED_TEST_CHANNELS = process.env.TESTING_CHANNEL_IDS.split(';')
let LIMITED_TEST_USERS;
if(process.env.TESTING_USER_IDS) LIMITED_TEST_USERS = process.env.TESTING_USER_IDS.split(';')
function isLimitedTestGuild(guild){ let TESTING_GROUPS = {}
if(LIMITED_TEST_GUILDS && LIMITED_TEST_GUILDS.includes(guild.id)) return true; let TESTING_ASSIGNMENTS = {}
function validateGroup(groups = [], featureId){
for(const g of groups){
if(TESTING_GROUPS[g] && TESTING_GROUPS[g].includes(featureId)) return true;
if(TESTING_GROUPS[g] && TESTING_GROUPS[g].includes("*")) return true;
}
return false; return false;
} }
function isLimitedTestChannel(channel){ // Fetches the testing configuration from the cdn
if(LIMITED_TEST_CHANNELS && LIMITED_TEST_CHANNELS.includes(channel.id)) return true; async function getTestConfig(){
return false; //if(!process.env.TESTING_CONFIG_URL) throw "Missing TESTING_CONFIG_URL in environment";
try{
let config = await superagent.get(process.env.TESTING_CONFIG_URL)
.query({
_t: Date.now()
});
TESTING_GROUPS = config.body.feature_groups
TESTING_ASSIGNMENTS = config.body.feature_assignments
TESTING_REVISION = config.body.revision
console.log('Loaded test configs (revision ' + TESTING_REVISION + ')')
return config.body;
}catch(e){
throw "Unable to retrieve test config."
}
} }
function isLimitedTestUser(user){ async function hasFeature(context, feature){
if(LIMITED_TEST_USERS && LIMITED_TEST_USERS.includes(user.id)) return true; // We need to load the test config first
return false; if(TESTING_REVISION == "-1") await getTestConfig();
}
// Server
if(context.guild && TESTING_ASSIGNMENTS.servers) if(validateGroup(TESTING_ASSIGNMENTS.servers[context.guild.id], feature)) return true;
// Channel
if(context.channel && TESTING_ASSIGNMENTS.channels) if(validateGroup(TESTING_ASSIGNMENTS.channels[context.channel.id], feature)) return true;
// Category
if(context.channel && context.channel.parent_id && TESTING_ASSIGNMENTS.categories) if(validateGroup(TESTING_ASSIGNMENTS.categories[context.channel.parent_id], feature)) return true;
// User
if(context.user && TESTING_ASSIGNMENTS.users) if(validateGroup(TESTING_ASSIGNMENTS.users[context.user.id], feature)) return true;
function canUseLimitedTestCommands(context){
if(isLimitedTestGuild(context.guild)) return true;
if(isLimitedTestChannel(context.channel)) return true;
if(isLimitedTestUser(context.user)) return true;
return false; return false;
} }
module.exports = { module.exports = {
canUseLimitedTestCommands, getTestConfig,
isLimitedTestGuild, hasFeature
isLimitedTestChannel,
isLimitedTestUser
} }