multi-account-post-schedule.../helpers/wiki_osm_random_from_elements.mjs

325 lines
12 KiB
JavaScript
Raw Normal View History

2022-08-04 14:16:43 +02:00
// https://www.mediawiki.org/wiki/Manual:Random_page
2022-08-08 16:17:04 +02:00
/**
* Post de page aléatoire du wiki osm avec le compte curator
2025-01-12 12:28:59 +01:00
* utiliser l'argument --force pour réellement envoyer le post avec le compte Curator.
* nécessite d'avoir le fichier .env rempli.
2022-08-08 16:17:04 +02:00
*/
2022-08-04 14:16:43 +02:00
import fetch from "node-fetch"
import rp from "request-promise";
import $ from "cheerio";
2022-08-04 16:30:18 +02:00
import fs from "fs";
import path from 'path';
2024-09-03 10:32:31 +02:00
import sendPostMastodon, {downloadImage, randomIntFromInterval} from './libs/utils.mjs'
2022-12-14 18:18:34 +01:00
import {getSourceOfDescriptorPageContent} from "./osm_get_description_picture.mjs";
2022-08-04 16:30:18 +02:00
const __dirname = path.resolve();
2022-08-08 16:17:04 +02:00
// select one line of table to override description
2023-02-17 10:13:50 +01:00
// const selectionOverrideOfSectionTable = 19;
2022-08-08 16:30:55 +02:00
// const selectionOverrideOfLineTable = 7;
2022-08-08 15:25:09 +02:00
2022-08-08 16:17:04 +02:00
// select randomly a line
2022-08-08 16:30:55 +02:00
const selectionOverrideOfSectionTable = '';
const selectionOverrideOfLineTable = '';
2022-08-08 15:47:09 +02:00
2022-08-08 18:44:45 +02:00
let foundExistingWikiPageInFrench = false;
2022-08-04 23:07:59 +02:00
2022-08-04 16:30:18 +02:00
function getRandomWikiOSMPage() {
2022-08-04 14:16:43 +02:00
2025-01-12 12:28:59 +01:00
// get all FR tags
// const url = "https://wiki.openstreetmap.org/w/index.php?title=Special:Categories&offset=FR&limit=500"
const url = "https://wiki.openstreetmap.org/wiki/Special:AllPages?from=&to=&namespace=202&limit=500"
// get a random page wich is not a discussion
// const url = "https://wiki.openstreetmap.org/wiki/Special:Random?namespace=all-discussions%3B1%3B2%3B3%3B5%3B7%3B9%3B11%3B120%3B121%3B122%3B123%3B201%3B203&invert=1&limit=10&days=1&enhanced=1&namespace__202_color=c1&urlversion=2"
rp(url)
.then(function (html) {
//success!
const wikiUrls = [];
const filteredHtml = $('.mw-spcontent ul li a', html)
console.log("filteredHtml.length", filteredHtml.length)
// .filter(elem => {
// return (elem.attribs.title.indexOf('description for') === -1)
// })
for (let i = 0; i < filteredHtml.length; i++) {
// const contentCurated = filteredHtml[i]
const contentCurated = filteredHtml[i].attribs.href
wikiUrls.push(contentCurated);
}
console.log(wikiUrls);
return wikiUrls;
})
.catch(function (err) {
//handle error
console.error(err)
});
2022-08-04 14:16:43 +02:00
}
2022-08-04 16:30:18 +02:00
export default function getElementCartographique() {
2025-01-12 12:28:59 +01:00
if (foundExistingWikiPageInFrench) {
console.log("already found foundExistingWikiPageInFrench")
return;
}
2025-01-12 12:28:59 +01:00
const url = "https://wiki.openstreetmap.org/wiki/FR:%C3%89l%C3%A9ments_cartographiques"
const titleLink = "#toc a"
const listElementSelector = "#toc a"
// prendre un lien dans la table des matières de la page, extraire l'id du lien.
// prendre une ligne de tableau au hasard correspondant à l'ID de la section
const titleSelector = ""
2022-08-04 14:16:43 +02:00
2025-01-12 12:28:59 +01:00
return fs.readFile(__dirname + '/assets/documents/elements_cartographiques.html', 'utf8', function (err, html) {
if (err) {
return console.log(err);
}
// console.log(data);
2022-08-04 16:30:18 +02:00
2025-01-12 12:28:59 +01:00
//success!
const wikiUrls = [];
// const listOfLinks = $(titleLink, html)
// console.log("filteredHtml.length", listOfLinks.length)
// const selectedTocLink = getRandomElementOfArray(listOfLinks).attribs.href;
// console.log("selectedTocLink", selectedTocLink)
const listOfTableRows = $('.wikitable', html);
let keys = Object.keys(listOfTableRows);
let randNumber = 0;
if (selectionOverrideOfSectionTable) {
randNumber = selectionOverrideOfSectionTable
} else {
randNumber = randomIntFromInterval(0, keys.length)
}
2025-01-12 12:28:59 +01:00
console.log("rand", randNumber)
const foundLine = $(listOfTableRows[randNumber]).find('tr');
2025-01-12 12:28:59 +01:00
// console.log("randomTable",foundTable)
2025-01-12 12:28:59 +01:00
// on regarde les lignes du tableau
keys = Object.keys(foundLine);
if (selectionOverrideOfLineTable) {
randNumber = selectionOverrideOfLineTable
} else {
randNumber = randomIntFromInterval(0, keys.length)
}
2025-01-12 12:28:59 +01:00
console.log("lignes de tableau", keys.length)
console.log("ligne sélectionnée", randNumber)
let cells = $(foundLine[randNumber]).find('td')
2022-08-04 16:30:18 +02:00
2025-01-12 12:28:59 +01:00
keys = Object.keys(cells);
// console.log("cellules trouvées", keys.length)
2024-09-03 10:32:31 +02:00
2025-01-12 12:28:59 +01:00
console.log("\n")
let configPost = {
key: '',
value: '',
description: '',
long_desc: '',
}
cells.each((i, element) => {
// console.log("cell element", i, $(element).text().trim())
if (i === 0) {
configPost.key = $(element).text().trim();
}
if (i === 1) {
configPost.value = $(element).text().trim();
}
if (i === 3) {
configPost.description = $(element).text().replace(' ', '').replace(' ', '').trim();
}
})
if (!configPost.key) {
console.error("ERROR no key found", $(cells).html())
console.error('no key BOOOOOOOOOOH');
getElementCartographique();
return;
}
2022-08-08 15:47:09 +02:00
2022-08-05 21:30:04 +02:00
// aller chercher le lien
2025-01-12 12:28:59 +01:00
// si la clé est une description avec des espaces, faire un lien vers la Key
let pageLink = `FR:Tag:${configPost.key}=${configPost.value}`
2022-08-08 18:25:37 +02:00
2025-01-12 12:28:59 +01:00
if (configPost.value.indexOf(' ') !== -1) {
pageLink = `FR:Key:${configPost.key}`
2022-08-05 21:30:04 +02:00
}
2025-01-12 12:28:59 +01:00
configPost.link = `https://wiki.openstreetmap.org/wiki/${pageLink}`
const url = configPost.link
// get a random page wich is not a discussion
// certaines valeurs ont des espaces, donc pas utilisable en url
if (configPost.value.indexOf(' ') === -1 || configPost.value.indexOf('<') === -1 || configPost.value.indexOf('>') === -1) {
console.log("url", url)
rp(url).then(function (html) {
//success!
const descriptionStrophe = '';
const filteredHtml = $('.mw-parser-output', html).find('p')
// trouver l'image de description
configPost.download_description_src = getSourceOfDescriptorPageContent(html)
console.log("filteredHtml", filteredHtml.length)
configPost.long_desc = $(filteredHtml).text().substring(0, 250)
console.log("filteredHtml", configPost.long_desc)
// image de description:
// let imgSelector = ".description a.image img"
console.log("✅ cette page existe bien en Français sur le wiki OSM")
foundExistingWikiPageInFrench = true;
sendMessageWikiOSMOfTheDay(makePostMessageFromObj(configPost), configPost.download_description_src)
}, (err) => {
console.error(err.statusCode)
if (err.statusCode == 404) {
console.log("\n Cette page n'existe pas encore, c'est le moment de la créer.", `https://wiki.openstreetmap.org/w/index.php?title=FR:${configPost.key}=${configPost.value}`) //FR:Tag:boundary%3Dborder_zone&action=edit)
console.log("Essayez de voir si la version en Anglais existe.")
let englishPage = `https://wiki.openstreetmap.org/wiki/Tag:${configPost.key}=${configPost.value}`
let englishKey = `https://wiki.openstreetmap.org/wiki/Key:${configPost.key}`
console.log("-> ", englishPage)
checkExistenceOfWebPage(englishPage).catch(err => {
checkExistenceOfWebPage(englishKey)
});
console.log("bon spa tout ça on essaie une autre ligne")
getElementCartographique()
}
})
} else {
console.log("result", configPost)
rp(configPost.link).then((result) => {
console.log("oui cette page existe!", url)
sendMessageWikiOSMOfTheDay(makePostMessageFromObj(result))
}, (err) => {
console.log("hé non. WTF ?")
// getElementCartographique()
})
2024-09-03 10:32:31 +02:00
2025-01-12 12:28:59 +01:00
}
2024-09-03 10:32:31 +02:00
2022-08-04 23:07:59 +02:00
2025-01-12 12:28:59 +01:00
return configPost;
2022-08-04 16:30:18 +02:00
2025-01-12 12:28:59 +01:00
});
2022-08-04 14:16:43 +02:00
}
2022-08-08 15:47:09 +02:00
/**
* check if a page anwsers to a GET request
* @param url
* @returns {*}
*/
function checkExistenceOfWebPage(url) {
2025-01-12 12:28:59 +01:00
if (foundExistingWikiPageInFrench) {
console.log("already found foundExistingWikiPageInFrench, no need to check other page", url)
return;
}
return rp(url).then((html) => {
console.log("oui cette page existe!", url)
}, (err) => {
console.log("hé non. WTF ?")
})
2022-08-08 15:47:09 +02:00
}
2024-09-03 10:32:31 +02:00
function makePostMessageFromObj(post_obj) {
2025-01-12 12:28:59 +01:00
return `
2024-09-03 10:32:31 +02:00
# Le tag OSM du jour : ${post_obj.key}=${post_obj.value} 🗺🏷
${post_obj.link}
2023-02-17 10:13:50 +01:00
2024-09-03 10:32:31 +02:00
${post_obj.description ? post_obj.description.trim() : ''}
${post_obj.long_desc ? post_obj.long_desc.trim() : ''}
2022-08-05 15:19:45 +02:00
#osm #openstreetmap #wiki #rtfw
`
}
2022-08-04 14:16:43 +02:00
function getQuery() {
2025-01-12 12:28:59 +01:00
// var url = "https://wiki.openstreetmap.org/w/api.php";
var url = "https://fr.wikipedia.org/w/api.php";
var params = {
action: "query",
format: "json",
list: "random",
enhanced: "1",
hiderobot: "1",
urlversion: "2",
invert: "1",
rnnamespace: "all-discussions%3B1%3B2%3B3%3B5%3B7%3B9%3B11%3B120%3B121%3B122%3B123%3B201%3B203", // WIKI et FR:
lang: "FR",
rnlimit: "5"
};
url = url + "?&origin=*";
Object.keys(params).forEach(function (key) {
url += "&" + key + "=" + params[key];
});
return fetch(url)
.then(function (response) {
return response.json();
})
.then(function (response) {
const randoms = response.query.random;
for (let ii = 0; ii < randoms.length; ii++) {
// console.log(randoms[ii].title);
console.log("randoms[ii]", randoms[ii])
}
})
.catch(function (error) {
console.log(error);
});
2022-08-04 14:16:43 +02:00
2022-08-05 15:19:45 +02:00
}
2025-01-12 12:28:59 +01:00
export function sendMessageWikiOSMOfTheDay(message, download_description_src) {
2025-01-12 12:28:59 +01:00
let configPost = {
author: 'curator',
// document.querySelector('.d_image img').attributes['src']
// image: '/home/tykayn/www/multi-account-post-schedule-mastodon/assets/osm_post_' + randomIntFromInterval(1 , 5) + '.jpg',
image: `${process.cwd()}/assets/blog_posts_medias/assets/osm_post_${randomIntFromInterval(1, 5)}.jpg`,
message,
2022-08-08 15:25:09 +02:00
}
2025-01-12 12:28:59 +01:00
if (download_description_src) {
let filePathImage = `${process.cwd()}/assets/blog_posts_medias/osm_wiki_description_page.jpg`
if (download_description_src) {
console.log("firstPictureSource found", download_description_src)
// check if picture already exist
console.log('on récupère l image de description : ', filePathImage)
downloadImage(download_description_src, filePathImage)
.then((res) => {
// suite du poste avec upload d'image
console.log('média téléchargé, on envoie le post')
configPost.image = filePathImage;
sendPostMastodon(configPost)
},
(err) => {
console.log('pas dimage trouvée pour l URL ', download_description_src, err)
sendPostMastodon(configPost)
}
)
.catch((err) => {
console.log('erreur avec cette URL ', download_description_src, err)
sendPostMastodon(configPost)
})
}
2022-12-14 18:18:34 +01:00
2025-01-12 12:28:59 +01:00
} else {
console.log('no image description')
sendPostMastodon(configPost)
}
2023-01-23 09:11:37 +00:00
}