post with picture up

This commit is contained in:
Tykayn 2022-12-14 17:31:03 +01:00 committed by tykayn
parent 0e17ab9c6f
commit af4ddd3c54
4 changed files with 51 additions and 20 deletions

File diff suppressed because one or more lines are too long

View File

@ -3,7 +3,7 @@ import path from 'path';
import sendPostMastodon, { import sendPostMastodon, {
randomIntFromInterval, randomIntFromInterval,
getRandomElementOfArray, getRandomElementOfArray,
findPictureAndSendPost findPictureAndSendPost, getRandomLinkGeneral
} from './utils.mjs' } from './utils.mjs'
const folderBlogPostsPreview = process.cwd() + '/assets/blog_posts_medias/' const folderBlogPostsPreview = process.cwd() + '/assets/blog_posts_medias/'
@ -22,8 +22,6 @@ const folderBlogPostsPreview = process.cwd() + '/assets/blog_posts_medias/'
const __dirname = path.resolve(); const __dirname = path.resolve();
const list_posts_json = JSON.parse(fs.readFileSync(__dirname + "/assets/documents/qzine_posts_all.json", 'utf-8')) const list_posts_json = JSON.parse(fs.readFileSync(__dirname + "/assets/documents/qzine_posts_all.json", 'utf-8'))
let reallySendPost = false;
// reallySendPost = true;
function getRandomLinkQzine() { function getRandomLinkQzine() {
@ -33,7 +31,16 @@ function getRandomLinkQzine() {
function postLink() { function postLink() {
let postObject = getRandomLinkQzine() let postObject = {};
let idOfPost = 1091;
// idOfPost = null;
if (idOfPost) {
postObject = list_posts_json.filter(elem => elem.id === idOfPost)[0]
console.log(postObject)
} else {
postObject = getRandomLinkGeneral(list_posts_json)
}
console.log("envoi de post par le compte Qzine - post n°" ,postObject.id) console.log("envoi de post par le compte Qzine - post n°" ,postObject.id)
let filteredExcerpt = postObject.excerpt.rendered.replace(/<[^>]+>/g, '') let filteredExcerpt = postObject.excerpt.rendered.replace(/<[^>]+>/g, '')
@ -57,7 +64,6 @@ function postLink() {
* ${postObject.link} * ${postObject.link}
${filteredExcerpt} ${filteredExcerpt}
* #qzine #qzineblog #blog #sexe #relations #éducation #plaisir #sociologie`, * #qzine #qzineblog #blog #sexe #relations #éducation #plaisir #sociologie`,
reallySendPost
} }
// console.log('postContent' , postContent) // console.log('postContent' , postContent)

View File

@ -2,7 +2,7 @@ import fs from "fs";
import path from 'path'; import path from 'path';
import { import {
randomIntFromInterval, randomIntFromInterval,
findPictureAndSendPost, getRandomLinkGeneral findPictureAndSendPost, getRandomLinkGeneral, hasCliArgument, slugify
} from './utils.mjs' } from './utils.mjs'
import Masto from "mastodon"; import Masto from "mastodon";
@ -11,14 +11,20 @@ const __dirname = path.resolve();
const folderBlogPostsPreview = process.cwd() + '/assets/blog_posts_medias/' const folderBlogPostsPreview = process.cwd() + '/assets/blog_posts_medias/'
const tkpostsjson = JSON.parse(fs.readFileSync(__dirname + "/assets/documents/tykayn_wptkblog_posts.json", 'utf-8')) const tkpostsjson = JSON.parse(fs.readFileSync(__dirname + "/assets/documents/tykayn_wptkblog_posts.json", 'utf-8'))
let reallySendPost = false;
// reallySendPost = true;
function postLink() { function postLink() {
let postObject = {};
let idOfPost = 1930;
idOfPost = null;
if (idOfPost) {
postObject = tkpostsjson.filter(elem => elem.ID === idOfPost)[0]
console.log(postObject)
} else {
let postObject = getRandomLinkGeneral(tkpostsjson) postObject = getRandomLinkGeneral(tkpostsjson)
}
console.log("envoi de post par tykayn") console.log("envoi de post par tykayn")
let filteredExcerpt = postObject.post_content.replace(/<[^>]+>/g, '') let filteredExcerpt = postObject.post_content.replace(/<[^>]+>/g, '')
@ -32,16 +38,16 @@ function postLink() {
let configPost = { let configPost = {
author: 'tykayn', author: 'tykayn',
website: 'tykayn_blog', website: 'tykayn_blog',
slug: postObject.guid, slug: slugify(postObject.post_title),
postObject, postObject,
folder_image: folderBlogPostsPreview, folder_image: folderBlogPostsPreview,
image: 'tk_blog_bannieres_oct2010-' + randomIntFromInterval(1, 10) + '.jpg', image: 'tk_blog_bannieres_oct2010-' + randomIntFromInterval(1, 9) + '.jpg',
message: `# [${postObject.post_title}](${postObject.guid}) message: `# [${postObject.post_title}](${postObject.guid})
* ${postObject.guid} * ${postObject.guid}
" ${filteredExcerpt} "
> "${filteredExcerpt}"
* #tykayn #tkblog #blog`, * #tykayn #tkblog #blog`,
reallySendPost
} }
// ajouter la première image du post de blog // ajouter la première image du post de blog
findPictureAndSendPost(postObject.post_content, configPost) findPictureAndSendPost(postObject.post_content, configPost)

View File

@ -6,6 +6,8 @@ import https from 'https';
let local_node_env_conf = dotenv.config() let local_node_env_conf = dotenv.config()
const myArgs = process.argv.slice(2);
let reallySendPost = hasCliArgument('--force');
export function randomIntFromInterval(min, max) { // min and max included export function randomIntFromInterval(min, max) { // min and max included
return Math.floor(Math.random() * (max - min + 1) + min) | 1 return Math.floor(Math.random() * (max - min + 1) + min) | 1
@ -23,7 +25,7 @@ export let defaultConfigMasto = {
visibility: 'public', visibility: 'public',
language: 'fr', language: 'fr',
sensitive: false, sensitive: false,
reallySendPost: false, reallySendPost,
image: '', image: '',
folder_image: process.cwd() + '/assets/blog_posts_medias/', folder_image: process.cwd() + '/assets/blog_posts_medias/',
message: "Hey coucou! on est le" + nowDate, message: "Hey coucou! on est le" + nowDate,
@ -36,7 +38,6 @@ export let defaultConfigMasto = {
export function tokenForAuthorIsPresentInDotEnv(author) { export function tokenForAuthorIsPresentInDotEnv(author) {
console.log(" process.env['TOKEN_' + author.toUpperCase()]", process.env['TOKEN_' + author.toUpperCase()])
return process.env['TOKEN_' + author.toUpperCase()]; return process.env['TOKEN_' + author.toUpperCase()];
} }
@ -47,6 +48,7 @@ export function tokenForAuthorIsPresentInDotEnv(author) {
*/ */
export default function sendPostMastodon(config) { export default function sendPostMastodon(config) {
console.log('send post', config.postObject.post_guid , config.postObject.guid )
// override defaults with input argument // override defaults with input argument
config = { config = {
...defaultConfigMasto, ...defaultConfigMasto,
@ -56,7 +58,7 @@ export default function sendPostMastodon(config) {
// console.log("sendPostMastodon config", config) // console.log("sendPostMastodon config", config)
if (!config.reallySendPost) { if (!config.reallySendPost) {
console.log(" =========== le message ne sera PAS réellement posté sur le compte @" + config.author + "@" + process.env.INSTANCE_MASTODON + " =========== ") console.log("\n =========== le message ne sera PAS réellement posté sur le compte @" + config.author + "@" + process.env.INSTANCE_MASTODON + " =========== \n")
} else { } else {
console.log(" ") console.log(" ")
@ -112,13 +114,14 @@ export default function sendPostMastodon(config) {
var id; var id;
console.log("envoi du média", config.image) console.log("envoi du média", config.image)
// upload new media // upload new media
return masto.post('media', {file: fs.createReadStream(config.folder_image + config.image)}) return masto.post('media', {file: fs.createReadStream(config.image)})
.then(resp => { .then(resp => {
id = resp.data.id; id = resp.data.id;
params.media_ids = [id] params.media_ids = [id]
console.log("\n ✅ image, id", id)
masto.post('statuses', params).then(rep => { masto.post('statuses', params).then(rep => {
// console.log('rep', rep) // console.log('rep', rep)
console.log("posté avec une nouvelle image, WOOT") console.log("\n ✅ posté avec une nouvelle image, WOOT")
}, err => { }, err => {
console.error(err) console.error(err)
@ -298,10 +301,14 @@ export function findPictureAndSendPost(postContent, configPost){
if (firstPictureSource) { if (firstPictureSource) {
console.log("firstPictureSource found", firstPictureSource) console.log("firstPictureSource found", firstPictureSource)
// check if picture already exist
console.log('on envoie le média et l image : ' , filePathImage)
downloadImage(firstPictureSource, filePathImage) downloadImage(firstPictureSource, filePathImage)
.then((res) => { .then((res) => {
// suite du poste avec upload d'image // suite du poste avec upload d'image
console.log('on envoie le media et l image' , filePathImage)
console.log('média téléchargé, on envoie le post')
configPost.image = filePathImage;
sendPostMastodon(configPost) sendPostMastodon(configPost)
@ -323,4 +330,17 @@ export function findPictureAndSendPost(postContent, configPost){
// on envoie avec l'image par défaut // on envoie avec l'image par défaut
sendPostMastodon(configPost) sendPostMastodon(configPost)
} }
}
/**
* find cli argument
* @param argument
* @returns {boolean}
*/
export function hasCliArgument(argument){
console.log('myArgs: ', myArgs);
return myArgs.indexOf(argument) !== -1
} }