質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
シェルスクリプト

シェルスクリプトは、UNIX系のOSもしくはコマンドラインインタプリタ向けに記述されたスクリプト。bash/zshといったシェルによって実行されるため、このように呼ばれています。バッチ処理などに使用されており、テキストファイルに書かれた命令を順に実行します。

Raspberry Pi

Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。

Q&A

解決済

1回答

1153閲覧

Radiko録音スクリプトを正常に稼働させたい

hebo

総合スコア0

シェルスクリプト

シェルスクリプトは、UNIX系のOSもしくはコマンドラインインタプリタ向けに記述されたスクリプト。bash/zshといったシェルによって実行されるため、このように呼ばれています。バッチ処理などに使用されており、テキストファイルに書かれた命令を順に実行します。

Raspberry Pi

Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。

0グッド

1クリップ

投稿2020/11/09 16:31

前提・実現したいこと

下記で公開されているRadiko録音スクリプトについて、
RaspberryPiを再起動などする中でエラーが表示されるようになってしまいました。

簡易Radiko録音スクリプト
https://gist.github.com/moraine8/eb9b7131951a8ef5eeab6f4ff1577fea

エラーが表示されることなく、スクリプトを実行させたいです。

発生している問題・エラーメッセージ

failed auth1 process

該当のソースコード

#!/bin/bash LANG=ja_JP.utf8 pid=$$ date=`date '+%Y%m%d'` outdir="." if [ $# -le 1 ]; then echo "usage : $0 channel_name duration(minuites) [outputdir] [prefix]" exit 1 fi if [ $# -ge 2 ]; then channel=$1 DURATION=`expr $2 * 60` fi if [ $# -ge 3 ]; then outdir=$3 fi PREFIX=${channel} if [ $# -ge 4 ]; then PREFIX=$4 fi playerurl=http://radiko.jp/apps/js/flash/myplayer-release.swf playerfile="/tmp/${PREFIX}_player.swf" keyfile="/tmp/${PREFIX}_authkey.png" # # get player # if [ ! -f $playerfile ]; then wget -q -O $playerfile $playerurl if [ $? -ne 0 ]; then echo "failed get player" exit 1 fi fi # # get keydata (need swftool) # if [ ! -f $keyfile ]; then swfextract -b 12 $playerfile -o $keyfile if [ ! -f $keyfile ]; then echo "failed get keydata" exit 1 fi fi if [ -f auth1_fms_${pid} ]; then rm -f auth1_fms_${pid} fi # # access auth1_fms # wget -q \ --header="pragma: no-cache" \ --header="X-Radiko-App: pc_ts" \ --header="X-Radiko-App-Version: 4.0.0" \ --header="X-Radiko-User: test-stream" \ --header="X-Radiko-Device: pc" \ --post-data='\r\n' \ --no-check-certificate \ --save-headers \ -O auth1_fms_${pid} \ https://radiko.jp/v2/api/auth1_fms if [ $? -ne 0 ]; then echo "failed auth1 process" exit 1 fi # # get partial key # authtoken=`perl -ne 'print $1 if(/x-radiko-authtoken: ([\w-]+)/i)' auth1_fms_${pid}` offset=`perl -ne 'print $1 if(/x-radiko-keyoffset: (\d+)/i)' auth1_fms_${pid}` length=`perl -ne 'print $1 if(/x-radiko-keylength: (\d+)/i)' auth1_fms_${pid}` partialkey=`dd if=$keyfile bs=1 skip=${offset} count=${length} 2> /dev/null | base64` #echo "authtoken: ${authtoken} \noffset: ${offset} length: ${length} \npartialkey: $partialkey" rm -f auth1_fms_${pid} if [ -f auth2_fms_${pid} ]; then rm -f auth2_fms_${pid} fi # # access auth2_fms # wget -q \ --header="pragma: no-cache" \ --header="X-Radiko-App: pc_1" \ --header="X-Radiko-App-Version: 2.0.1" \ --header="X-Radiko-User: test-stream" \ --header="X-Radiko-Device: pc" \ --header="X-Radiko-Authtoken: ${authtoken}" \ --header="X-Radiko-Partialkey: ${partialkey}" \ --post-data='\r\n' \ --no-check-certificate \ -O auth2_fms_${pid} \ https://radiko.jp/v2/api/auth2_fms if [ $? -ne 0 -o ! -f auth2_fms_${pid} ]; then echo "failed auth2 process" exit 1 fi #echo "authentication success" areaid=`perl -ne 'print $1 if(/^([^,]+),/i)' auth2_fms_${pid}` #echo "areaid: $areaid" rm -f auth2_fms_${pid} # # get stream-url # if [ -f ${channel}.xml ]; then rm -f ${channel}.xml fi wget -q "http://radiko.jp/v2/station/stream/${channel}.xml" stream_url=`echo "cat /url/item[1]/text()" | xmllint --shell ${channel}.xml | tail -2 | head -1` declare -a url_parts=(`echo ${stream_url} | perl -pe 's!^(.*)://(.*?)/(.*)/(.*?)$/!$1://$2 $3 $4!'`) rm -f ${channel}.xml tmp="/tmp/${channel}_${PREFIX}_${date}" # # rtmpdump # #rtmpdump -q \ rtmpdump \ -r ${url_parts[0]} \ --app ${url_parts[1]} \ --playpath ${url_parts[2]} \ -W $playerurl \ -C S:"" -C S:"" -C S:"" -C S:$authtoken \ --live \ --stop ${DURATION} \ --flv $tmp avconv -loglevel quiet -y -i $tmp -acodec libmp3lame -ab 64k "${outdir}/${PREFIX}_${date}.mp3" if [ $? = 0 ]; then rm -f $tmp fi rm -f $playerfile rm -f $keyfile

試したこと

RaspberryPi本体を再起動した際に、tmp/のフォルダ内のファイルが削除されるようです。

再起動後に当スクリプトを実行すると0バイトのxxx_player.swfファイルが作成され
"failed get player"でエラー終了します。
0バイトのxxx_player.swfファイルがtmp/に存在する状態で当スクリプトを再実行すると
"failed get keydata"でエラー終了します。

上記の事象は正常なxxx_player.swfファイルを復元し、tmp/のフォルダに格納することで回避できましたが、
"failed auth1 process"でエラー終了してしまいます。

上記の事象と合わせて推察すると、スクリプトが正しくダウンロード等の通信を行うことができていないのでしょうか。
何らかRaspberryPiの本体設定が影響し、当スクリプトでエラーが発生している可能性があるのでしょうか。

補足情報(FW/ツールのバージョンなど)

使用マシン:Raspberry Pi 3 model B
当スクリプトはRaspberryPiで動作するように改変されているものですが、
大本のスクリプトは下記のようです。
https://gist.github.com/matchy2/3956266

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

自身のネットワーク環境不備によるものでした。

ネットワーク環境に不備があったため、
wgetが行えていないだけでした。

お騒がせし申し訳ございません。

投稿2020/11/10 14:18

hebo

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問