diff --git a/README.md b/README.md index 8e30b2e..e2241dd 100644 --- a/README.md +++ b/README.md @@ -3,21 +3,32 @@ Permet de poster sur mastodon selon le compte que l'on souhaite multi-account-post-schedule-mastodon et de réaliser des bots d'autopost de liens et d'images. -Pouvoir faire de la planification de posts de plusieurs comptes mastodon en créant une app pour chacun d'eux dans son compte masto, et en reportant les accès dans un fichier d'environnement de cette app nodejs. +Pouvoir faire de la planification de posts de plusieurs comptes mastodon en créant une app pour chacun d'eux dans son +compte masto, et en reportant les accès dans un fichier d'environnement de cette app nodejs. ![screenshot form](assets/screenshot_form.png) + # Getting started + ## Scripts d'autopost -Utiliser un cronjob pour lancer les scripts bash, qui s'occupent de faire fonctionner les scripts JS avec les bonnes variables d'environnement. + +Utiliser un cronjob pour lancer les scripts bash, qui s'occupent de faire fonctionner les scripts JS avec les bonnes +variables d'environnement. Voir le dossier [cron_scripts](cron_scripts) montrant un exemple de crontab. Modifiez votre crontab avec votre éditeur préféré en ligne de commande: + ```bash crontab -e ``` + ### Remplir les variables du fichier .env à créer + ```bash cp .env.example .env ``` -Et ajoutez les token de bot pour faire de l'autopost. Vous trouverez ces token dans vos comptes d'utilisateur Mastodon, partie "développement", créer un token pour chaque compte. + +Et ajoutez les token de bot pour faire de l'autopost. Vous trouverez ces token dans vos comptes d'utilisateur Mastodon, +partie "développement", créer un token pour chaque compte. + ```dotenv TOKEN_account_UTILISATEUR_MACHIN=MON_TOKEN_SDZERTYYRUTKIOUL46577OUKI?FXGDSGTGH_EXEMPLE ``` @@ -26,7 +37,9 @@ Installez les dépendances NPM avec Yarn. Récupérez les fichiers de blog wordpress via l'interface wp-json, mettez les json dans le dossier source. Modifiez les scripts dans le dossier helpers pour les faire convenir à votre présentation de Toot Mastodn. Exécutez les scripts node. + ## Interface Web multi compte + Requirements: avoir nodeJS sur sa machine et un navigateur. ```bash @@ -49,8 +62,10 @@ TOKEN_account_machin=ABCD TOKEN_account_bidule=ABCD ``` + Chaque info d'API doit correspondre à un compte pour lequel vous avez obtenu des jetons d'API. -Si vous sélectionnez un compte Toto, il faut que vous ayez dans le fichier .env un TOKEN_Toto=XXXXXYYYYZZZZZZZ, avec la bonne valeur donnée par votre instance mastodon. +Si vous sélectionnez un compte Toto, il faut que vous ayez dans le fichier .env un TOKEN_Toto=XXXXXYYYYZZZZZZZ, avec la +bonne valeur donnée par votre instance mastodon. lancer le serveur local avec un npm start aller sur localhost 8000 et zou, on peut créer la base de données, et commencer à sauver de nouveaux messages. @@ -59,9 +74,11 @@ http://localhost:8000 # Planifier ses posts ## yes we can + * on peut ajouter des posts avec un fichier attaché ## on ne peut pas encore: + * poster maintenant un nouveau post sans passer par la file d'attente * configurer les comptes à choisir dynamiquement * redistribuer les schedule des posts @@ -73,9 +90,11 @@ http://localhost:8000 * avoir en base l'information de quand est ce qu'un post a été envoyé à son instance par API. # Notes + ce site n'a pas besoin d'être hébergé sur le serveur de l'instance qu'il utilise Venez causer sur mastodon! -Ceci utilise un fichier sqlite comme base de données, vous pouvez faire des ajouts en base avec un bon IDE sans avoir à développer d'interface web. +Ceci utilise un fichier sqlite comme base de données, vous pouvez faire des ajouts en base avec un bon IDE sans avoir à +développer d'interface web. Les merge requests sont bienvenues. par tykayn: contact at cipherbliss.com, https://www.cipherbliss.com @@ -86,7 +105,7 @@ https://mastodon.cipherbliss.com ``` 12 12-14 * * * cd /home/tykayn/www/mastodon_multi_account && nvm use 16 && node helpers/tykayn_blog.mjs | tee -a /home/tykayn/log_autopost.txt 2>&1 -0 7 * * * cd /home/tykayn/www/mastodon_multi_account && nvm use 16 && node helpers/wiki_osm.mjs | tee -a /home/tykayn/log_autopost.txt 2>&1 +0 7 * * * cd /home/tykayn/www/mastodon_multi_account && nvm use 16 && node helpers/wiki_osm_random_from_elements.mjs | tee -a /home/tykayn/log_autopost.txt 2>&1 0 0 * * * cd /home/tykayn/www/mastodon_multi_account && nvm use 16 && node helpers/qzine_article.mjs | tee -a /home/tykayn/log_autopost.txt 2>&1 # version avec scripts bash 0 7 * * * su tykayn -c "bash /home/tykayn/wiki_osm.sh" @@ -95,4 +114,4 @@ https://mastodon.cipherbliss.com 14 12-14 * * * su tykayn -c "bash /home/tykayn/tkblog_post.sh" -``` \ No newline at end of file +``` diff --git a/helpers/wiki_osm.mjs b/helpers/wiki_osm_random_from_elements.mjs similarity index 100% rename from helpers/wiki_osm.mjs rename to helpers/wiki_osm_random_from_elements.mjs diff --git a/scrapper.mjs b/scrapper.mjs index c4d5a69..d4f5c39 100644 --- a/scrapper.mjs +++ b/scrapper.mjs @@ -1,6 +1,5 @@ - -import getElementCartographique from "./helpers/wiki_osm.mjs" +import getElementCartographique from './helpers/wiki_osm_random_from_elements.mjs' // const getRandomWikiOSMPage = require("./helpers/wiki_osm.mjs") console.log('Scrapper goes brr') getElementCartographique() - console.log('getRandomWikiOSMPage done') +console.log('getRandomWikiOSMPage done') diff --git a/views/index.jade b/views/index.jade index 1d8d044..ad8fe58 100644 --- a/views/index.jade +++ b/views/index.jade @@ -13,11 +13,12 @@ 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 + if accounts_to_select + 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 @@ -77,4 +78,4 @@ block content console.log('account changed', somePseudo) } - console.log('script loaded') \ No newline at end of file + console.log('script loaded')