mirror of
https://github.com/cooperhammond/irs.git
synced 2025-01-10 20:25:27 +00:00
Preliminary interception logging done!
This commit is contained in:
parent
76a624d32f
commit
80cb034ce1
|
@ -50,7 +50,7 @@ class CLI
|
||||||
end
|
end
|
||||||
|
|
||||||
def act_on_args
|
def act_on_args
|
||||||
if @args["help"]?
|
if @args["help"]? || @args.keys.size == 0
|
||||||
help
|
help
|
||||||
exit
|
exit
|
||||||
elsif @args["version"]?
|
elsif @args["version"]?
|
||||||
|
|
|
@ -33,6 +33,7 @@ class Song
|
||||||
end
|
end
|
||||||
|
|
||||||
if !@metadata
|
if !@metadata
|
||||||
|
puts "Searching for metadata ..."
|
||||||
@metadata = @spotify_searcher.find_item("track", {
|
@metadata = @spotify_searcher.find_item("track", {
|
||||||
"name" => @song_name,
|
"name" => @song_name,
|
||||||
"artist" => @artist_name
|
"artist" => @artist_name
|
||||||
|
@ -48,34 +49,35 @@ class Song
|
||||||
data = @metadata.as(JSON::Any)
|
data = @metadata.as(JSON::Any)
|
||||||
filename = data["track_number"].to_s + " - #{data["name"].to_s}.mp3"
|
filename = data["track_number"].to_s + " - #{data["name"].to_s}.mp3"
|
||||||
|
|
||||||
|
puts "Searching for url ..."
|
||||||
url = Youtube.find_url(@song_name, @artist_name, search_terms: "lyrics")
|
url = Youtube.find_url(@song_name, @artist_name, search_terms: "lyrics")
|
||||||
|
|
||||||
if !url
|
if !url
|
||||||
raise("There was no link found on youtube for\n" +
|
raise("There was no url found on youtube for\n" +
|
||||||
%("#{@song_name}" by "#{@artist_name}\n) +
|
%("#{@song_name}" by "#{@artist_name}\n) +
|
||||||
"Check your input and try again.")
|
"Check your input and try again.")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
puts "Downloading video ..."
|
||||||
Ripper.download_mp3(url.as(String), filename)
|
Ripper.download_mp3(url.as(String), filename)
|
||||||
|
|
||||||
temp_albumart_filename = ".tempalbumart.jpg"
|
# temp_albumart_filename = ".tempalbumart.jpg"
|
||||||
HTTP::Client.get(data["album"]["images"][0]["url"].to_s) do |response|
|
# HTTP::Client.get(data["album"]["images"][0]["url"].to_s) do |response|
|
||||||
File.write(temp_albumart_filename, response.body_io)
|
# File.write(temp_albumart_filename, response.body_io)
|
||||||
end
|
# end
|
||||||
|
|
||||||
tagger = Tags.new(filename)
|
# tagger = Tags.new(filename)
|
||||||
tagger.add_album_art(temp_albumart_filename)
|
# tagger.add_album_art(temp_albumart_filename)
|
||||||
tagger.add_text_tag("title", data["name"].to_s)
|
# tagger.add_text_tag("title", data["name"].to_s)
|
||||||
tagger.add_text_tag("artist", data["artists"][0]["name"].to_s)
|
# tagger.add_text_tag("artist", data["artists"][0]["name"].to_s)
|
||||||
tagger.add_text_tag("album", data["album"]["name"].to_s)
|
# tagger.add_text_tag("album", data["album"]["name"].to_s)
|
||||||
tagger.add_text_tag("genre",
|
# tagger.add_text_tag("genre",
|
||||||
@spotify_searcher.find_genre(data["artists"][0]["id"].to_s))
|
# @spotify_searcher.find_genre(data["artists"][0]["id"].to_s))
|
||||||
tagger.add_text_tag("track", data["track_number"].to_s)
|
# tagger.add_text_tag("track", data["track_number"].to_s)
|
||||||
tagger.add_text_tag("disc", data["disc_number"].to_s)
|
# tagger.add_text_tag("disc", data["disc_number"].to_s)
|
||||||
|
|
||||||
tagger.save()
|
# tagger.save()
|
||||||
File.delete(temp_albumart_filename)
|
# File.delete(temp_albumart_filename)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
85
src/interact/logger.cr
Normal file
85
src/interact/logger.cr
Normal file
|
@ -0,0 +1,85 @@
|
||||||
|
class Logger
|
||||||
|
|
||||||
|
@done_signal = "---DONE---"
|
||||||
|
|
||||||
|
@command : String
|
||||||
|
|
||||||
|
def initialize(command : String, @log_name : String, @sleept = 0.01)
|
||||||
|
# Have the command output its information to a log and after the command is
|
||||||
|
# finished, append an end signal to the document
|
||||||
|
@command = "#{command} > #{@log_name} " # standard output to log
|
||||||
|
@command += "2> #{@log_name} && " # errors to log
|
||||||
|
@command += "echo #{@done_signal} >> #{@log_name}" #
|
||||||
|
end
|
||||||
|
|
||||||
|
# Run @command in the background and pipe its output to the log file, with
|
||||||
|
# something constantly monitoring the log file and yielding each new line to
|
||||||
|
# the block call. Useful for changing the output of binaries you don't have
|
||||||
|
# much control over.
|
||||||
|
# Note that the created temp log will be deleted unless the command fails
|
||||||
|
# its exit or .start is called with delete_file: false
|
||||||
|
#
|
||||||
|
# ```
|
||||||
|
# l = Logger.new(".temp.log", %(echo "CIA spying" && sleep 2 && echo "new veggie tales season"))
|
||||||
|
# l.start do |output, index|
|
||||||
|
# case output
|
||||||
|
# when "CIA spying"
|
||||||
|
# puts "i sleep"
|
||||||
|
# when .includes?("veggie tales")
|
||||||
|
# puts "real shit"
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
# ```
|
||||||
|
def start(delete_file=true, &block) : Bool
|
||||||
|
# Delete the log if it already exists
|
||||||
|
File.delete(@log_name) if File.exists?(@log_name)
|
||||||
|
|
||||||
|
# Run the command in the background
|
||||||
|
called = future {
|
||||||
|
system(@command)
|
||||||
|
}
|
||||||
|
|
||||||
|
# Wait for the log file to be written to
|
||||||
|
while !File.exists?(@log_name)
|
||||||
|
sleep @sleept
|
||||||
|
end
|
||||||
|
|
||||||
|
log = File.open(@log_name)
|
||||||
|
log_content = read_file(log)
|
||||||
|
index = 0
|
||||||
|
|
||||||
|
while true
|
||||||
|
temp_content = read_file(log)
|
||||||
|
|
||||||
|
# make sure that there is new data
|
||||||
|
if temp_content.size > 0 && log_content != temp_content
|
||||||
|
log_content = temp_content
|
||||||
|
|
||||||
|
# break the loop if the command has completed
|
||||||
|
break if log_content[0] == @done_signal
|
||||||
|
|
||||||
|
# give the line and index to the block
|
||||||
|
yield log_content[0], index
|
||||||
|
index += 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
status = called.get()
|
||||||
|
if status == true && delete_file == true
|
||||||
|
log.delete()
|
||||||
|
end
|
||||||
|
|
||||||
|
return called.get()
|
||||||
|
end
|
||||||
|
|
||||||
|
# Reads each line of the file into an Array of Strings
|
||||||
|
private def read_file(file : IO) : Array(String)
|
||||||
|
content = [] of String
|
||||||
|
|
||||||
|
file.each_line do |line|
|
||||||
|
content.push(line)
|
||||||
|
end
|
||||||
|
|
||||||
|
return content
|
||||||
|
end
|
||||||
|
end
|
|
@ -1,3 +1,5 @@
|
||||||
|
require "./logger"
|
||||||
|
|
||||||
module Ripper
|
module Ripper
|
||||||
|
|
||||||
extend self
|
extend self
|
||||||
|
@ -11,7 +13,7 @@ module Ripper
|
||||||
# Ripper.download_mp3("https://youtube.com/watch?v=0xnciFWAqa0",
|
# Ripper.download_mp3("https://youtube.com/watch?v=0xnciFWAqa0",
|
||||||
# "Queen/A Night At The Opera/Bohemian Rhapsody.mp3")
|
# "Queen/A Night At The Opera/Bohemian Rhapsody.mp3")
|
||||||
# ```
|
# ```
|
||||||
def download_mp3(video_url : String, output_filename : String) : Bool
|
def download_mp3(video_url : String, output_filename : String)
|
||||||
ydl_loc = BIN_LOC.join("youtube-dl")
|
ydl_loc = BIN_LOC.join("youtube-dl")
|
||||||
|
|
||||||
# remove the extension that will be added on by ydl
|
# remove the extension that will be added on by ydl
|
||||||
|
@ -22,6 +24,7 @@ module Ripper
|
||||||
options = {
|
options = {
|
||||||
"--output" => %("#{output_filename}.%(ext)s"), # auto-add correct ext
|
"--output" => %("#{output_filename}.%(ext)s"), # auto-add correct ext
|
||||||
# "--quiet" => "",
|
# "--quiet" => "",
|
||||||
|
"--verbose" => "",
|
||||||
"--ffmpeg-location" => BIN_LOC,
|
"--ffmpeg-location" => BIN_LOC,
|
||||||
"--extract-audio" => "",
|
"--extract-audio" => "",
|
||||||
"--audio-format" => "mp3",
|
"--audio-format" => "mp3",
|
||||||
|
@ -33,11 +36,29 @@ module Ripper
|
||||||
command += " #{option} #{options[option]}"
|
command += " #{option} #{options[option]}"
|
||||||
end
|
end
|
||||||
|
|
||||||
if system(command)
|
|
||||||
return true
|
l = Logger.new(command, ".ripper.log")
|
||||||
else
|
o = RipperOutputCensor.new
|
||||||
return false
|
|
||||||
|
return l.start do |line, index|
|
||||||
|
o.censor_output(line, index)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
private class RipperOutputCensor
|
||||||
|
@dl_status_index = 0
|
||||||
|
|
||||||
|
def censor_output(line : String, index : Int32)
|
||||||
|
case line
|
||||||
|
when .includes? "[download]"
|
||||||
|
if @dl_status_index != 0
|
||||||
|
print "\e[1A"
|
||||||
|
print "\e[0K\r"
|
||||||
|
end
|
||||||
|
puts line
|
||||||
|
@dl_status_index += 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
Loading…
Reference in a new issue