Perun: Difference between revisions
(→/home/user/osm_update.py: rename) |
(→/home/user/youtube_downloader.py: rename to yt. and add complete description because it is the full update script) |
||
Line 13: | Line 13: | ||
Fetches the newest <code>.osc.gz</code> daily changefiles from [https://planet.openstreetmap.org/ openstreetmap] for osm container into <code>/mnt/maps/tmp/</code>, to be processed by [[Osm#Data_updates]]. The latest already imported changefile is identified by its sequence number, and that written to <code>/mnt/maps/state.txt</code>. The state number therefore refers to which changefiles have already been downloaded. Whether they are in the database is indicated if they are removed from <code>/mnt/maps/tmp</code> or not. Because this file presence/absence shows whether a changefile was successfully or not imported to database, the <code>maps</code> dataset is a subdataset of <code>dbp</code> which hosts the entire database: a recursive snapshot always contains a self-consistent state of the data. See [[Osm#Filesystem]] for details. | Fetches the newest <code>.osc.gz</code> daily changefiles from [https://planet.openstreetmap.org/ openstreetmap] for osm container into <code>/mnt/maps/tmp/</code>, to be processed by [[Osm#Data_updates]]. The latest already imported changefile is identified by its sequence number, and that written to <code>/mnt/maps/state.txt</code>. The state number therefore refers to which changefiles have already been downloaded. Whether they are in the database is indicated if they are removed from <code>/mnt/maps/tmp</code> or not. Because this file presence/absence shows whether a changefile was successfully or not imported to database, the <code>maps</code> dataset is a subdataset of <code>dbp</code> which hosts the entire database: a recursive snapshot always contains a self-consistent state of the data. See [[Osm#Filesystem]] for details. | ||
== /home/user/ | == /home/user/yt.py == | ||
For regularly downloading youtube videos to be displayed in [[Lada#Youtube]]. | For regularly downloading youtube videos to be displayed in [[Lada#Youtube]]. Because Perun container has network passwordless access to the Lada database, this script is entirely self-contained for adding or refreshing information on youtube videos, channels or playlists. Uses the python module <code>yt_dlp</code> and <code>ffmpeg</code> as main dependencies. The regularly scheduled task is as follows: | ||
# Download newly uploaded videos to <code>/mnt/youtube/{channel_id}/{video_id}.mkv</code>. | |||
# Move thumbnails to <code>/mnt/icache/youtube/{channel_id}/{video_id}.{img_fmt}</code>. | |||
# Clean up temporary download files like <code>.part</code> and pre-transcoded files like <code>.webm</code>. Those were kept by <code>yt-dlp</code> to allow for resuming downloads instead of restarting them when the internet is very slow or unreliable. By this point, they will not be useful anymore. | |||
# Trigger a database rescan : | |||
## Look at all video files in <code>/mnt/youtube</code> that are not in the database yet. | |||
## Add them by reading from the deduced <code>.info.json</code>, and deduce thumbnail by corresponding <code>.{img_fmt}</code>. | |||
## Generate same-size and same-aspect-ratio (640x360p) thumbnails to <code>/mnt/icache/youtube/{channel_id}/{video_id}.360p.{img_fmt}</code>, with <code>ffmpeg</code>. | |||
## For any special video files like <code>.1080p.mkv</code>, add them to their parent video as <code>altvideos</code>. | |||
# Check if 1080p versions are missing: download to <code>/mnt/youtube/{channel_id}/{video_id}.1080p.mkv</code> if the video necessitates a smaller 1080p version (if it is natively >1080p). | |||
# Rescan database to add those <code>.1080p</code> videos. | |||
# Again like step 3 remove .part and similar temporary files. | |||
This main script also allows for maintenance tasks to be run, like: | |||
* re-downloading all <code>.info.json</code> files of any video present in the database and updating that info. | |||
* downloading playlists of channels and adding those to the database. | |||
== /home/user/audio_podcasts_fetch2db.py == | == /home/user/audio_podcasts_fetch2db.py == |
Revision as of 12:36, 7 January 2023
LXC container, connected to the internet and used for downloading everything. It has readwrite access to relevant mountpoints and has wget
, youtube-dlp
, rsync
and lftp
as download software installed.
/video/lectures/updatefeeds.sh
Completely automatic ETHZ-video lecture recording downloader. It reads dir;url
lines from urls.csv
where dir
is a directory under /video/lectures
and link
is a RSS feed of an ETHZ video lecture series. It fetches the RSS feed through the feed2exec
python module, that converts every item to a csv line. Those are internally interpreted to extract the published date in %Y-%m-%d
format and the video url is then downloaded to {dir}/%Y-%m-%d.mp4
. It prints a last line reporting the work done: amount of feeds fetched, files detected (which are mentioned in the feeds but also already downloaded) and new files downloaded.
/software/git_clone.sh
Fetches archived git repositories, ran automatically.
/software/syncrepo-template.sh
Fetches, through rsync
, archlinux and artixlinux (depending on $1
) entire package repositories. Also fetches database files allowing completely functional package mirror operations, see Lada#Arch and artix package mirror.
/home/user/osmdl.py
Fetches the newest .osc.gz
daily changefiles from openstreetmap for osm container into /mnt/maps/tmp/
, to be processed by Osm#Data_updates. The latest already imported changefile is identified by its sequence number, and that written to /mnt/maps/state.txt
. The state number therefore refers to which changefiles have already been downloaded. Whether they are in the database is indicated if they are removed from /mnt/maps/tmp
or not. Because this file presence/absence shows whether a changefile was successfully or not imported to database, the maps
dataset is a subdataset of dbp
which hosts the entire database: a recursive snapshot always contains a self-consistent state of the data. See Osm#Filesystem for details.
/home/user/yt.py
For regularly downloading youtube videos to be displayed in Lada#Youtube. Because Perun container has network passwordless access to the Lada database, this script is entirely self-contained for adding or refreshing information on youtube videos, channels or playlists. Uses the python module yt_dlp
and ffmpeg
as main dependencies. The regularly scheduled task is as follows:
- Download newly uploaded videos to
/mnt/youtube/{channel_id}/{video_id}.mkv
. - Move thumbnails to
/mnt/icache/youtube/{channel_id}/{video_id}.{img_fmt}
. - Clean up temporary download files like
.part
and pre-transcoded files like.webm
. Those were kept byyt-dlp
to allow for resuming downloads instead of restarting them when the internet is very slow or unreliable. By this point, they will not be useful anymore. - Trigger a database rescan :
- Look at all video files in
/mnt/youtube
that are not in the database yet. - Add them by reading from the deduced
.info.json
, and deduce thumbnail by corresponding.{img_fmt}
. - Generate same-size and same-aspect-ratio (640x360p) thumbnails to
/mnt/icache/youtube/{channel_id}/{video_id}.360p.{img_fmt}
, withffmpeg
. - For any special video files like
.1080p.mkv
, add them to their parent video asaltvideos
.
- Look at all video files in
- Check if 1080p versions are missing: download to
/mnt/youtube/{channel_id}/{video_id}.1080p.mkv
if the video necessitates a smaller 1080p version (if it is natively >1080p). - Rescan database to add those
.1080p
videos. - Again like step 3 remove .part and similar temporary files.
This main script also allows for maintenance tasks to be run, like:
- re-downloading all
.info.json
files of any video present in the database and updating that info. - downloading playlists of channels and adding those to the database.
/home/user/audio_podcasts_fetch2db.py
Multistep process to update a podcast. Has database acces on lada to dbname=audio. Can either:
- Fetch a podcast
url={dbname=audio:podcasts:url}
to a specified output file (then the XML should be manually edited and converted to json) - Import a given
.json
file as the next episode for a podcast (then only the file needs to be downloaded to the correct location) - Fully-automated
url={dbname=audio:podcasts:url}
fetch, XML parse of the latest item, import to database and download to the correct location. This also requires the given podcast to be specified in/home/user/audio_podcasts_parse.py
for how which XML keys should be translated or converted into data for the database. Also checks database contstraints like length in advance. If the database import succeeded, run awget
subprocess to download the file.
For the third option, /home/user/sanitize_eschtml.py
can parse HTML and remove attributes of some tags and remove some tags (while preserving children of those tags). It can be used to compress the description
s as it removes cluttering attributes and <span>
tags that have no attributes left. This script takes escaped HTML as both input and output.