start curator recommendations

This commit is contained in:
Tykayn 2023-12-06 12:08:36 +01:00 committed by tykayn
parent 7fa3b34b08
commit ac38059f80
5 changed files with 4551 additions and 2883 deletions

1
.idea/vcs.xml generated
View File

@ -2,6 +2,5 @@
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="$PROJECT_DIR$" vcs="Git" />
<mapping directory="$PROJECT_DIR$/mastodon_multi_account" vcs="Git" />
</component>
</project>

View File

@ -0,0 +1,131 @@
// import sendPostMastodon from "./libs/utils.mjs";
import axios from "axios"
import sharp from "sharp"
import path from "path"
import fs from "fs"
import os from "os"
import https from "https"
const downloadImage = async (url, name) => {
const outputPath = path.join(__dirname, 'images', name);
try {
const stats = await fs.promises.stat(outputPath);
if (stats.isFile()) {
console.log(`${name} already downloaded`);
return;
}
} catch (error) {
if (error.code == 'ENOENT') {
throw error;
}
}
const response = await axios.get(url, { responseType: 'arraybuffer' });
const buffer = Buffer.from(response.data, 'binary');
await fs.promises.writeFile(outputPath, buffer);
console.log(`Downloaded ${name} and saved to ${outputPath}`);
};
async function makePicture(){
// URL des images à combiner
const urls = [
'https://mastodon.cipherbliss.com/system/cache/accounts/avatars/111/167/114/936/998/027/original/a80c6e973a5ebfa4.jpg',
'https://mastodon.cipherbliss.com/system/cache/accounts/avatars/111/322/992/248/243/542/original/23520c84291a6c41.png',
'https://mastodon.cipherbliss.com/system/cache/accounts/avatars/111/472/478/271/279/314/original/938c74ffb49473d1.jpg'
];
// Noms des images à combiner
const names = ['Image 1', 'Image 2', 'Image 3'];
// Largeur totale de l'image combinée
const totalWidth = 800;
// Hauteur totale de l'image combinée
const totalHeight = 600;
// Créer un dossier temporaire pour stocker les images téléchargées
const TEMP_DIR_NAME ='my-temp-dir';
const tempDir = fs.mkdtempSync(path.join(os.tmpdir(), TEMP_DIR_NAME));
console.log('tempDir:',tempDir)
Promise.all(urls.map((url, index) => {
// Télécharger l'image
return downloadImage(url)
}))
.then((filePaths) => {
// Combiner les images en une seule image
return sharp(filePaths[0])
.resize(totalWidth / 3, totalHeight)
.append([
sharp(filePaths[1]).resize(totalWidth / 3, totalHeight),
sharp(filePaths[2]).resize(totalWidth / 3, totalHeight)
])
.toBuffer();
})
.then((buffer) => {
// Enregistrer l'image combinée
const outputFilePath = path.join(tempDir, 'combined.jpg');
return new Promise((resolve, reject) => {
fs.writeFile(outputFilePath, buffer, (error) => {
if (error) {
reject(error);
} else {
resolve(outputFilePath);
}
});
});
})
.then((outputFilePath) => {
// Afficher l'image combinée
console.log(`Combined image saved to ${outputFilePath}`);
})
.catch((error) => {
console.error(error);
});
}
async function getFollowers(username, instance) {
const url = `https://${instance}/api/v1/accounts/${username}/following`;
try {
const response = await axios.get(url);
return response.data;
} catch (error) {
console.error(error);
}
}
async function main() {
const username = '1';
const instance ='mastodon.cipherbliss.com';
const followers = await getFollowers(username, instance);
console.log('followers', followers.length)
const randomFollowers = followers.sort(() => Math.random() - 0.5)
const selection = randomFollowers.slice(0, 3)
console.log('Random followers:', randomFollowers.length);
selection.forEach(elem=>{
console.log('selection', elem.username , elem.avatar_static)
})
}
// main();
makePicture();

View File

@ -26,12 +26,14 @@
"webpage": "^0.3.0"
},
"devDependencies": {
"axios": "^1.6.2",
"cheerio": "^1.0.0-rc.12",
"fs": "^0.0.1-security",
"https": "^1.0.0",
"node-fetch": "^3.2.10",
"nodemon": "^2.0.22",
"path": "^0.12.7",
"request-promise": "^4.2.6",
"sharp": "^0.31.2"
"sharp": "^0.32.6"
}
}

View File

@ -13,11 +13,11 @@ block content
br
div.images
each val, index in accounts_to_select
div.clickable(onclick=`selectAccount('${val.value}')`)
img.account__avatar-overlay(src=`${val.src}`)
br
span=val.label
each val, index in accounts_to_select
div.clickable(onclick=`selectAccount('${val.value}')`)
img.account__avatar-overlay(src=`${val.src}`)
br
span=val.label
br
select(method="post", name="author", value=bodyReq ? bodyReq.author : "", id="author_select")
each val, index in accounts_to_select

7288
yarn.lock

File diff suppressed because it is too large Load Diff