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
* /
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 17:35:20 +02:00
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
2024-09-03 10:32:31 +02: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 ( ) {
2024-09-03 10:32:31 +02:00
if ( foundExistingWikiPageInFrench ) {
console . log ( "already found foundExistingWikiPageInFrench" )
return ;
}
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 = ""
return fs . readFile ( _ _dirname + '/assets/documents/elements_cartographiques.html' , 'utf8' , function ( err , html ) {
if ( err ) {
return console . log ( err ) ;
2022-08-08 18:34:56 +02:00
}
2024-09-03 10:32:31 +02:00
// console.log(data);
2022-08-04 14:16:43 +02:00
2024-09-03 10:32:31 +02:00
//success!
const wikiUrls = [ ] ;
// const listOfLinks = $(titleLink, html)
// console.log("filteredHtml.length", listOfLinks.length)
// const selectedTocLink = getRandomElementOfArray(listOfLinks).attribs.href;
// console.log("selectedTocLink", selectedTocLink)
2022-08-04 16:30:18 +02:00
2024-09-03 10:32:31 +02:00
const listOfTableRows = $ ( '.wikitable' , html ) ;
let keys = Object . keys ( listOfTableRows ) ;
2022-08-04 16:30:18 +02:00
2024-09-03 10:32:31 +02:00
let randNumber = 0 ;
if ( selectionOverrideOfSectionTable ) {
randNumber = selectionOverrideOfSectionTable
} else {
randNumber = randomIntFromInterval ( 0 , keys . length )
}
2022-08-08 14:47:40 +02:00
2024-09-03 10:32:31 +02:00
console . log ( "rand" , randNumber )
const foundLine = $ ( listOfTableRows [ randNumber ] ) . find ( 'tr' ) ;
2022-08-04 17:35:20 +02:00
2024-09-03 10:32:31 +02:00
// console.log("randomTable",foundTable)
2022-08-04 17:35:20 +02:00
2024-09-03 10:32:31 +02:00
// on regarde les lignes du tableau
keys = Object . keys ( foundLine ) ;
if ( selectionOverrideOfLineTable ) {
randNumber = selectionOverrideOfLineTable
} else {
randNumber = randomIntFromInterval ( 0 , keys . length )
}
2022-08-04 17:35:20 +02:00
2024-09-03 10:32:31 +02:00
console . log ( "lignes de tableau" , keys . length )
console . log ( "ligne sélectionnée" , randNumber )
let cells = $ ( foundLine [ randNumber ] ) . find ( 'td' )
2022-08-04 17:35:20 +02:00
2024-09-03 10:32:31 +02:00
keys = Object . keys ( cells ) ;
// console.log("cellules trouvées", keys.length)
2022-08-04 16:30:18 +02:00
2024-09-03 10:32:31 +02: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
2024-09-03 10:32:31 +02: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-05 21:30:04 +02:00
2024-09-03 10:32:31 +02:00
if ( configPost . value . indexOf ( ' ' ) !== - 1 ) {
pageLink = ` FR:Key: ${ configPost . key } `
}
configPost . link = ` https://wiki.openstreetmap.org/wiki/ ${ pageLink } `
2022-08-08 18:25:37 +02:00
2024-09-03 10:32:31 +02:00
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 ;
sendMessageWikiTagOfTheDay ( 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 ( )
2022-08-08 18:25:37 +02:00
2022-08-05 21:30:04 +02:00
}
2022-08-04 17:35:20 +02:00
2024-09-03 10:32:31 +02:00
} )
} else {
console . log ( "result" , configPost )
rp ( configPost . link ) . then ( ( result ) => {
console . log ( "oui cette page existe!" , url )
sendMessageWikiTagOfTheDay ( makePostMessageFromObj ( result ) )
} , ( err ) => {
console . log ( "hé non. WTF ?" )
// getElementCartographique()
} )
}
2022-08-04 23:07:59 +02:00
2024-09-03 10:32:31 +02:00
return configPost ;
2022-08-04 16:30:18 +02:00
2024-09-03 10:32:31 +02: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 ) {
2024-09-03 10:32:31 +02: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 ) {
return `
# 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 ( ) {
2024-09-03 10:32:31 +02: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
}
// run
const res = getElementCartographique ( )
2024-09-03 10:32:31 +02:00
2022-08-08 15:47:09 +02:00
// console.log("res", res)
2022-08-08 15:25:09 +02:00
2022-12-14 18:18:34 +01:00
function sendMessageWikiTagOfTheDay ( message , download _description _src ) {
2022-08-08 18:34:56 +02:00
2024-09-03 10:32:31 +02: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 ,
}
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-08-08 15:25:09 +02:00
}
2022-12-14 18:18:34 +01:00
2024-09-03 10:32:31 +02:00
} else {
console . log ( 'no image description' )
sendPostMastodon ( configPost )
}
2023-01-23 10:11:37 +01:00
}