From e07ff2a1928be00bb7f7eb7fc82c8447a581c58f Mon Sep 17 00:00:00 2001 From: EuAndreh Date: Sun, 27 Dec 2020 23:41:13 -0300 Subject: linter.rb: Add assert_media_metadata --- _plugins/generate-torrent.rb | 2 +- _plugins/linter.rb | 41 +++++++++++++++++++++++++++++++++++++++++ default.nix | 1 + 3 files changed, 43 insertions(+), 1 deletion(-) diff --git a/_plugins/generate-torrent.rb b/_plugins/generate-torrent.rb index 1c642f4..a2077bc 100644 --- a/_plugins/generate-torrent.rb +++ b/_plugins/generate-torrent.rb @@ -11,7 +11,7 @@ module Jekyll def generate(site) site.collections.each do |name, collection| - if ['podcasts', 'screencasts'].include? name + if ['podcasts', 'screencasts'].include? name then collection.docs.each do |document| date = document.data['date'].strftime('%Y-%m-%d') slug = document.data['slug'] diff --git a/_plugins/linter.rb b/_plugins/linter.rb index 5d78c17..aa55c8c 100644 --- a/_plugins/linter.rb +++ b/_plugins/linter.rb @@ -134,9 +134,50 @@ module Jekyll end end + def assert_media_metadata(site) + site.collections.each do |name, collection| + if ['podcasts', 'screencasts'].include? name then + collection.docs.each do |document| + date = document.data['date'].strftime('%Y-%m-%d') + slug = document.data['slug'] + file = "resources/#{name}/#{date}-#{slug}.flac" + if name == 'podcasts' + stdout = `metaflac --export-tags-to=- #{file}` + file_metadata = stdout.strip.split("\n") + expected = [ + "COMMENTS=#{site.config['url']}/#{file}", + 'ARTIST=EuAndreh', + "DATE=#{date}", + "TITLE=#{document.data['title']}", + "ALBUM=#{site.config['t']['podcasts']['feed']['title'][document.data['lang']]}" + ] + expected.each do |metadata| + unless file_metadata.include? metadata + tags = expected.join('\\n').gsub(/'/, "'\"'\"'") + add_metadata_cmd = "metaflac --remove-all #{file}\nprintf '#{tags}\\n' | metaflac --import-tags-from=- #{file}" + check_metadata_cmd = "metaflac --export-tags-to=- #{file}" + raise "Missing metadata entry '#{metadata}' in '#{file}'.\nAdd it with:\n\n#{add_metadata_cmd}\n\nCheck with:\n #{check_metadata_cmd}" + end + end + + check_cover_cmd = "metaflac #{file} --export-picture-to=- | diff - static/favicon.svg" + `#{check_cover_cmd}` + unless $?.success? then + add_cover_cmd = "metaflac #{file} --import-picture-from='3|image/svg+xml||420x420x24|static/favicon.svg'" + raise "Cover art from '#{file}' doesn't match 'static/favicon.svg'.\nFix it with:\n\n#{add_cover_cmd}\n\nCheck with:\n #{check_cover_cmd}" + end + elsif name == 'screencasts' then + p document + end + end + end + end + end + def generate(site) assert_unique_ids(site) assert_frontmatter(site) + assert_media_metadata(site) assert_git_annex(site) end diff --git a/default.nix b/default.nix index 067f0f1..fc84d6e 100644 --- a/default.nix +++ b/default.nix @@ -26,6 +26,7 @@ let pkgs-next.mdpo mktorrent-newer ffmpeg + flac perl graphviz -- cgit v1.2.3