mirror of
https://gitlab.com/bignutty/labscore.git
synced 2025-06-08 14:13:02 -04:00
reverse image search ctx
This commit is contained in:
parent
e007a1b97c
commit
054a6c9513
1 changed files with 79 additions and 0 deletions
79
commands/interaction/context/reverse-image.js
Normal file
79
commands/interaction/context/reverse-image.js
Normal file
|
@ -0,0 +1,79 @@
|
||||||
|
const { createEmbed, formatPaginationEmbeds, page } = require('../../../labscore/utils/embed')
|
||||||
|
const { editOrReply } = require('../../../labscore/utils/message')
|
||||||
|
const { STATICS } = require('../../../labscore/utils/statics')
|
||||||
|
|
||||||
|
const { paginator } = require('../../../labscore/client');
|
||||||
|
const { reverseImageSearch } = require('../../../labscore/api');
|
||||||
|
|
||||||
|
const { InteractionCallbackTypes, ApplicationCommandTypes } = require("detritus-client/lib/constants");
|
||||||
|
const { getMessageAttachment, validateAttachment } = require('../../../labscore/utils/attachment');
|
||||||
|
|
||||||
|
function createReverseImageSearchResultPage(context, result, source) {
|
||||||
|
let res = page(
|
||||||
|
createEmbed("default", context, {
|
||||||
|
author: {
|
||||||
|
iconUrl: `https://www.google.com/s2/favicons?domain=${encodeURIComponent(result.url)}&sz=256`,
|
||||||
|
name: result.name,
|
||||||
|
url: result.url
|
||||||
|
},
|
||||||
|
image: {
|
||||||
|
url: result.image
|
||||||
|
},
|
||||||
|
thumbnail: {
|
||||||
|
url: source
|
||||||
|
},
|
||||||
|
footer: {
|
||||||
|
iconUrl: STATICS.google,
|
||||||
|
text: `Google Cloud Vision • ${context.application.name}`
|
||||||
|
}
|
||||||
|
}))
|
||||||
|
if (result.thumbnail) res.embeds[0].thumbnail = { url: result.thumbnail };
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
name: 'Reverse Image Search',
|
||||||
|
type: ApplicationCommandTypes.MESSAGE,
|
||||||
|
contexts: [
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
integrationTypes: [
|
||||||
|
1
|
||||||
|
],
|
||||||
|
run: async (context, args) => {
|
||||||
|
try{
|
||||||
|
await context.respond({data: {}, type: InteractionCallbackTypes.DEFERRED_CHANNEL_MESSAGE_WITH_SOURCE})
|
||||||
|
|
||||||
|
const { message } = args;
|
||||||
|
|
||||||
|
let attachment = getMessageAttachment(message)
|
||||||
|
if(attachment && validateAttachment(attachment, "image")){
|
||||||
|
attachment = attachment.url
|
||||||
|
} else {
|
||||||
|
delete attachment;
|
||||||
|
}
|
||||||
|
if(!attachment) return context.editOrRespond({ embeds: [createEmbed("warning", context, "No images found.")] })
|
||||||
|
|
||||||
|
|
||||||
|
let search = await reverseImageSearch(context, attachment)
|
||||||
|
search = search.response
|
||||||
|
|
||||||
|
if (search.body.status == 2) return editOrReply(context, createEmbed("error", context, search.body.message))
|
||||||
|
|
||||||
|
let pages = []
|
||||||
|
for (const res of search.body.results) {
|
||||||
|
pages.push(createReverseImageSearchResultPage(context, res, attachment))
|
||||||
|
}
|
||||||
|
|
||||||
|
await paginator.createPaginator({
|
||||||
|
context,
|
||||||
|
pages: formatPaginationEmbeds(pages)
|
||||||
|
});
|
||||||
|
} catch (e) {
|
||||||
|
console.log(e)
|
||||||
|
return editOrReply(context, createEmbed("error", context, `Unable to perform reverse image search.`))
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
Loading…
Add table
Add a link
Reference in a new issue