From: yuki Date: Mon, 30 Nov 2009 15:58:51 +0000 (+0000) Subject: ver.0.3.0変更分のマージ X-Git-Tag: rel20091201_ver0.3.1~3 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=0be8401dae3dbf821c90da41fd1299f2166ff2d9;p=coroid%2FNicoBrowser.git ver.0.3.0変更分のマージ git-svn-id: http://192.168.11.7/svn/repository/NicoBrowser/trunk@246 bdf3b611-c98c-6041-8292-703d9c9adbe7 --- diff --git a/NicoBrowser.bat b/NicoBrowser.bat new file mode 100644 index 0000000..ccd9c1b --- /dev/null +++ b/NicoBrowser.bat @@ -0,0 +1,9 @@ +SET LOGFILE=NicoBrowser.log + +ECHO: >> %LOGFILE% +ECHO ==== START ==== >> %LOGFILE% +DATE /T >> %LOGFILE% +TIME /T >> %LOGFILE% +ECHO: >> %LOGFILE% +java -jar NicoBrowser.jar 2>&1 >> %LOGFILE% +exit diff --git a/README.html b/README.html index 2e87de3..b520b95 100644 --- a/README.html +++ b/README.html @@ -1,3 +1,193 @@ - -README -

機能・特徴

使い方の一例

http://feather.cocolog-nifty.com/weblog/2008/03/post_7d4b.html


操作方法

コマンドラインで以下を実行。

java -jar NicoBrowser.jar

1回目の起動でコンフィグファイルがアプリケーションディレクトリに作成される。Windowsであれば、例えば以下のディレクトリ。

C:\Documents and Settings\user\.nicobrowser

nicobrowser.propertiesを開き、IDとパスワードを設定する。

設定後、再度実行すればダウンロード開始。

バージョンアップに関する注意事項

2009/05/24版以前を使用していた場合の注意事項

アップデート後(つまり今回のファイルで上書きした後)、1回目の起動前に以下のコマンドを実行する必要がある。実行しないとDB関連のエラーとなり処理が継続できない。

java -jar NicoBrowser.jar sync

(引数にsyncをつけて実行する)

2009/03/23版以前を使用していた場合の注意事項

nicobrowser.propertiesの互換性は無いため、一旦リネーム(or 削除)してから
実行する必要がある。こうすることで、新しいnicobrowser.propertiesが作成される。

path.dbの設定は、従来は"ファイル名"の指定だったが、現在は"ディレクトリ名"の指定に変わっていることに注意。

本体libディレクトリ以下について、構成が大きく変わっているため、libは上書きでなく置換することを推奨。

nicobrowser.propertiesの説明

path.db=
履歴管理DBを保存するディレクトリ。日本語名不可。

path.savefile=
ダウンロードしたflvファイルを保存するディレクトリ。日本語名不可。

encoding=
feedurl.txtの文字エンコーディング。

nicovideo.mail=
ニコニコ動画のメールアドレス(ID)。

nicovideo.password=
ニコニコ動画のパスワード。

download.retry=
指定した回数ダウンロード試行に失敗した場合、次回以降ダウンロード対象から除外する。

download.wait=
連続してダウンロードを行う際、ここで指定した秒数待ち合わせて次のファイルへ進む。

download.mylist=
指定した公開マイリストに登録されているコンテンツをダウンロード対象に含める。

例えば
http://www.nicovideo.jp/mylist/4573744
http://www.nicovideo.jp/mylist/739988/1395449
上記2個のマイリストを対象とする場合、
download.mylist=4573744,739988/1395449
と、URLの mylist/ 以下をカンマで区切って指定する。

feedurl.txtの説明

1行ごとに、対象とするRSSフィードのURLと抽出数をカンマ区切りで設定する。
書式についてはファイル内のコメント参照。

未解決の課題

webサイト参照。

更新履歴

200911/26 ver.0.2.0
download.waitプロパティを追加。

2009/11/13 ver.0.1.1
Log4Jのインストールバージョン誤りを修正。

2009/11/13 ver.0.1
永続化する情報に作者(投稿者)情報を追加。ipum用の対応。

2009/05/24
デイリーランキング以外のフィードへ対応。
一部のswfに対してアクセスできない問題の対応(新プレイヤ対応)。
ログ出力の見直し。

2009/03/23
動画ファイル取得時403をもらった場合、ファイルをダウンロードしないように対応。

2009/01/11
視聴権限が無い動画を取得しようとした場合にアプリケーションが終了してしまう問題を修正。

2008/08/03
ランキングのRSSをzioさん作ニコRSS
http://zio3.net/nicoRss/Handler.ashx
から本家
http://www.nicovideo.jp/ranking/mylist/daily/all?rss=atom
に変更した。

2008/04/09
前回ダウンロード要求から5秒待ってから次のダウンロード要求を行うようウェイト処理を追加した。
ターゲットをJDK6からJDK5に変更した。

2008/03/21
公開マイリストを指定したダウンロードを可能とした。

2008/03/15
ダウンロードする最低ランキングを指定可能とした。
ファイル名にドットが入っていた場合にもアンダーバーに
置換するよう置換規則を追加(Craving Explorerに合わせた)。

\ No newline at end of file + + + + + README + + + +


+

+

機能・特徴

+ +


+

+

使い方の一例

+

http://feather.cocolog-nifty.com/weblog/2008/03/post_7d4b.html

+


+

+

操作方法

+

基本操作
+

+

コマンドラインで以下を実行。

+

java -jar +NicoBrowser.jar

+

1回目の起動では、このコマンドでコンフィグ設定画面が開く。ここでID、パスワードを入力し保存する。

+

設定後、再度実行すればダウンロードが開始される。

+

詳細なダウンロード設定については「設定ファイルに +ついて」の項を参照。
+

+

起動引数

+ + + + + + + + + + + + + + + +
-h
+
引数についてのヘルプを表示
+
-p
+
コンフィグ設定画面を起動
+
-v
+
バージョン情報を表示
+
+

例えば以下のように実行する:
+

+

java -jar +NicoBrowser.jar -p
+

+


+

+

設定ファイルについて
+

+コンフィグファイルはアプリケーションディレクトリに作成される。Windowsであれば、例えば以下のディレクトリ。 +

C:\Documents and Settings\user\.nicobrowser

+このディレクトリ以下のファイルを編集することで、好みのランキングやマイリストをダウンロード指定することが出来る。 +

nicobrowser.properties +の説明

+

path.db=
+履歴管理DBを保存するディレクトリ。

+

path.savefile=
+ダウンロードしたflvファイルを保存するディレクトリ。

+

encoding=
+feedurl.txtの文字エンコーディング。

+

nicovideo.mail=
+ニコニコ動画のメールアドレス(ID)。

+

nicovideo.password=
+ニコニコ動画のパスワード。

+

download.retry=
+指定した回数ダウンロード試行に失敗した場合、次回以降ダウンロード対象から除外する。

+

download.wait=
+連続してダウンロードを行う際、ここで指定した秒数待ち合わせて次のファイルへ進む。

+

download.mylist=
+指定した公開マイリストに登録されているコンテンツをダウンロード対象に含める。

+

例えば
+http://www.nicovideo.jp/mylist/4573744
+http://www.nicovideo.jp/mylist/739988/1395449
+上記2個のマイリストを対象とする場合、
+download.mylist=4573744,739988/1395449
+と、URLの mylist/ 以下をカンマで区切って指定する。

+

feedurl.txt +の説明

+

1行ごとに、対象とするRSSフィードのURLと抽出数をカンマ区切りで設定する。
+書式についてはファイル内のコメント参照。
+

+


+

+

バージョンアップに関する注意事項

+

2009/05/24版以前を使用していた場合 +の注意事項

+

アップデート後(つまり今回のファイルで上書きした後)、1回目の起動前に以下のコマンドを実行する必要がある。実行しないとDB関連 +のエラーとなり処理が継続できない。

+

java -jar +NicoBrowser.jar sync

+

(引数にsyncをつけて実行する)

+

2009/03/23版以前を使用していた場合 +の注意事項

+

nicobrowser.propertiesの互換性は無いため、一旦リネーム(or 削除)してから
+実行する必要がある。こうすることで、新しいnicobrowser.propertiesが作成される。

+

path.dbの設定は、従来は"ファイル名"の指定だったが、現在は"ディレクトリ名"の指定に変わっていることに注意。

+

本体libディレクトリ以下について、構成が大きく変わっているため、libは上書きでなく置換することを推奨。
+

+

未解決の課題

+

webサイト参照。

+

更新履歴

+

2009/11/30 ver.0.3.0
+コンフィグ設定画面を追加。

+

2009/11/26 ver.0.2.0
+download.waitプロパティを追加。

+

2009/11/13 ver.0.1.1
+Log4Jのインストールバージョン誤りを修正。

+

2009/11/13 ver.0.1
+永続化する情報に作者(投稿者)情報を追加。ipum用の対応。

+

2009/05/24
+デイリーランキング以外のフィードへ対応。
+一部のswfに対してアクセスできない問題の対応(新プレイヤ対応)。
+ログ出力の見直し。

+

2009/03/23
+動画ファイル取得時403をもらった場合、ファイルをダウンロードしないように対応。

+

2009/01/11
+視聴権限が無い動画を取得しようとした場合にアプリケーションが終了してしまう問題を修正。

+

2008/08/03
+ランキングのRSSをzioさん作ニコRSS
+http://zio3.net/nicoRss/Handler.ashx
+から本家
+http://www.nicovideo.jp/ranking/mylist/daily/all?rss=atom
+に変更した。

+

2008/04/09
+前回ダウンロード要求から5秒待ってから次のダウンロード要求を行うようウェイト処理を追加した。
+ターゲットをJDK6からJDK5に変更した。

+

2008/03/21
+公開マイリストを指定したダウンロードを可能とした。

+

2008/03/15
+ダウンロードする最低ランキングを指定可能とした。
+ファイル名にドットが入っていた場合にもアンダーバーに
+置換するよう置換規則を追加(Craving Explorerに合わせた)。

+ + diff --git a/nbproject/project.properties b/nbproject/project.properties index e5493b7..1c1324e 100644 --- a/nbproject/project.properties +++ b/nbproject/project.properties @@ -1,5 +1,5 @@ application.homepage=http://feather.cocolog-nifty.com/ -application.title=DEMO:\u30cb\u30b3\u30cb\u30b3\u52d5\u753b\u30b3\u30f3\u30c6\u30f3\u30c4\u60c5\u5831\u30d6\u30e9\u30a6\u30b6 +application.title=NicoBrowser - \u30e9\u30f3\u30ad\u30f3\u30b0\u3001\u516c\u958b\u30de\u30a4\u30ea\u30b9\u30c8\u304b\u3089\u306e\u30cb\u30b3\u30cb\u30b3\u52d5\u753b\u81ea\u52d5\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9 application.vendor=yukihane build.classes.dir=${build.dir}/classes build.classes.excludes= @@ -19,8 +19,8 @@ debug.test.classpath=\ dist.dir=dist dist.jar=${dist.dir}/NicoBrowser.jar dist.javadoc.dir=${dist.dir}/javadoc +endorsed.classpath= excludes= -file.reference.commons-io-1.4.jar=F:\\data\\java\\commons\\commons-io-1.4\\commons-io-1.4.jar file.reference.liquibase-1.9.5.jar=F:\\data\\java\\liquibase-1.9.5\\liquibase-1.9.5.jar includes=** jar.compress=false @@ -32,9 +32,14 @@ javac.classpath=\ ${libs.Log4J.classpath}:\ ${libs.HttpClient4.0.classpath}:\ ${libs.NekoHtml.classpath}:\ - ${file.reference.commons-io-1.4.jar}:\ ${libs.groovy-all.classpath}:\ - ${file.reference.liquibase-1.9.5.jar} + ${libs.Commons-IO.classpath}:\ + ${libs.Commons-CLI.classpath}:\ + ${file.reference.liquibase-1.9.5.jar}:\ + ${libs.swing-layout.classpath}:\ + ${libs.Commons-Lang.classpath}:\ + ${libs.Commons-Configuration.classpath}:\ + ${libs.Commons-Collections.classpath} # Space-separated list of extra javac options javac.compilerargs= javac.deprecation=false @@ -52,7 +57,6 @@ javadoc.noindex=false javadoc.nonavbar=false javadoc.notree=false javadoc.private=false -javadoc.reference.commons-io-1.4.jar=F:\\data\\java\\commons\\commons-io-1.4\\docs javadoc.splitindex=true javadoc.use=true javadoc.version=false @@ -90,7 +94,6 @@ run.test.classpath=\ ${javac.test.classpath}:\ ${build.test.classes.dir} source.encoding=UTF-8 -source.reference.commons-io-1.4.jar=F:\\data\\java\\commons\\commons-io-1.4\\commons-io-1.4-sources.jar src.dir=src test.src.dir=test compile.on.save.unsupported.groovy=true diff --git a/src/nicobrowser/Config.java b/src/nicobrowser/Config.java index 61aea9f..544a046 100644 --- a/src/nicobrowser/Config.java +++ b/src/nicobrowser/Config.java @@ -3,13 +3,15 @@ package nicobrowser; import java.io.BufferedReader; import java.io.File; -import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.util.ArrayList; +import java.util.Arrays; import java.util.List; -import java.util.Properties; +import org.apache.commons.configuration.Configuration; +import org.apache.commons.configuration.ConfigurationException; +import org.apache.commons.configuration.PropertiesConfiguration; import org.apache.commons.io.FileUtils; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; @@ -46,22 +48,23 @@ public final class Config { } private static Log log = LogFactory.getLog(Config.class); private static Config instance; - private final Properties properties; + private final PropertiesConfiguration properties; private static final String APPLICATION_NAME = "nicobrowser"; private static final String CONFIG_NAME = APPLICATION_NAME + ".properties"; private static final String FEEDURL_NAME = "feedurl.txt"; private static final File APP_HOME = new File(System.getProperty("user.home", "."), "." + APPLICATION_NAME); private static final File CONFIG_FILE = new File(APP_HOME, CONFIG_NAME); private static final File FEEDURL_FILE = new File(APP_HOME, FEEDURL_NAME); - private static final String P_PATH_DB = "path.db"; - private static final String P_PATH_SAVEFILE = "path.savefile"; - private static final String P_FILE_ENCODING = "encoding"; - private static final String P_NICOVIDEO_MAIL = "nicovideo.mail"; - private static final String P_NICOVIDEO_PASSWORD = "nicovideo.password"; - private static final String P_DOWNLOAD_RETRY = "download.retry"; - private static final String P_DOWNLOAD_WAIT = "download.wait"; + public static final String P_PATH_DB = "path.db"; + public static final String P_PATH_SAVEFILE = "path.savefile"; + public static final String P_FILE_ENCODING = "encoding"; + public static final String P_NICOVIDEO_MAIL = "nicovideo.mail"; + public static final String P_NICOVIDEO_PASSWORD = "nicovideo.password"; + public static final String P_DOWNLOAD_RETRY = "download.retry"; + public static final String P_DOWNLOAD_WAIT = "download.wait"; + public static final String P_DOWNLOAD_MYLIST = "download.mylist"; + private static final int DEFAULT_MAX_RETRY = 3; private static final int DEFAULT_WAIT_TIME = 15; - private static final String P_DOWNLOAD_MYLIST = "download.mylist"; /** * プログラム実行に必要なコンフィグファイルを作成する. @@ -91,6 +94,41 @@ public final class Config { return result; } + /** + * 新しいプロパティを設定する. 新しいプロパティに値がない場合, 現在のままとなる. + * @param p 新規プロパティ. + * @throws IOException + */ + public void updateConfigFile(Configuration p) throws IOException { + updatePropertyValue(p, P_NICOVIDEO_MAIL); + updatePropertyValue(p, P_NICOVIDEO_PASSWORD); + updatePropertyValue(p, P_FILE_ENCODING); + + updatePropertyValue(p, P_PATH_DB); + updatePropertyValue(p, P_PATH_SAVEFILE); + + updatePropertyValue(p, P_DOWNLOAD_RETRY); + updatePropertyValue(p, P_DOWNLOAD_WAIT); + + updatePropertyValue(p, P_DOWNLOAD_MYLIST); + + try { + properties.save(); + } catch (ConfigurationException ex) { + throw new IOException(ex); + } + } + + /** + * 新しいプロパティを設定する. 新しいプロパティに値がない場合, 現在のままとなる. + * @param newProp 新規プロパティ. + * @param key 設定するプロパティキー. + */ + private void updatePropertyValue(Configuration newProp, String key) { + String value = newProp.getString(key, properties.getString(key)); + properties.setProperty(key, value); + } + private static void createNewConfigFile(File file) throws IOException { ArrayList props = new ArrayList(); @@ -109,9 +147,9 @@ public final class Config { props.add(P_FILE_ENCODING + "=" + System.getProperty("file.encoding")); - props.add(P_NICOVIDEO_MAIL + "=set.your@mail.address"); - props.add(P_NICOVIDEO_PASSWORD + "=set_your_password"); - props.add(P_DOWNLOAD_RETRY + "=3"); + props.add(P_NICOVIDEO_MAIL + "="); + props.add(P_NICOVIDEO_PASSWORD + "=s"); + props.add(P_DOWNLOAD_RETRY + "=" + DEFAULT_MAX_RETRY); props.add(P_DOWNLOAD_WAIT + "=" + DEFAULT_WAIT_TIME); props.add(P_DOWNLOAD_MYLIST + "="); @@ -132,22 +170,11 @@ public final class Config { } private Config() { - properties = new Properties(); - FileInputStream fis = null; try { - fis = new FileInputStream(CONFIG_FILE); - properties.load(fis); - } catch (IOException ex) { + properties = new PropertiesConfiguration(CONFIG_FILE); + } catch (Exception ex) { log.fatal("コンフィグの読み込みに失敗: " + CONFIG_FILE); throw new RuntimeException(ex); - } finally { - if (fis != null) { - try { - fis.close(); - } catch (IOException ex) { - log.warn("", ex); - } - } } try { @@ -169,29 +196,29 @@ public final class Config { * @return ニコニコ動画ログインID. */ public String getNicoMail() { - return properties.getProperty(P_NICOVIDEO_MAIL); + return properties.getString(P_NICOVIDEO_MAIL); } /** * @return ニコニコ動画ログインパスワード. */ public String getNicoPassword() { - return properties.getProperty(P_NICOVIDEO_PASSWORD); + return properties.getString(P_NICOVIDEO_PASSWORD); } - /** @return DBパス */ + /** @return DBパス. コンフィグで設定した値(保存ディレクトリ)でなく, DBファイルのパスが変えることに注意. */ public String getDbFile() { - return new File(properties.getProperty(P_PATH_DB), "nicodb").getAbsolutePath(); + return new File(properties.getString(P_PATH_DB), "nicodb").getAbsolutePath(); } /** @return 保存先の指定. */ public String getSrcSaveDir() { - return properties.getProperty(P_PATH_SAVEFILE); + return properties.getString(P_PATH_SAVEFILE); } /** @return feedurl.txtの文字エンコーディング. */ public String getEncoding() { - String res = properties.getProperty(P_FILE_ENCODING, System.getProperty("file.encoding")); + String res = properties.getString(P_FILE_ENCODING, System.getProperty("file.encoding")); return res; } @@ -200,8 +227,7 @@ public final class Config { * @return リトライ回数. */ public int getMaxRetry() { - String res = properties.getProperty(P_DOWNLOAD_RETRY); - return Integer.parseInt(res); + return properties.getInt(P_DOWNLOAD_RETRY, DEFAULT_MAX_RETRY); } /** @@ -209,25 +235,12 @@ public final class Config { * @return 待ち時間(秒). */ public int getWaitTime() { - int res = DEFAULT_WAIT_TIME; - try { - res = Integer.parseInt(properties.getProperty(P_DOWNLOAD_WAIT)); - } catch (NumberFormatException e) { - } - return res; + return properties.getInt(P_DOWNLOAD_WAIT, DEFAULT_WAIT_TIME); } public List getDownLoadMyList() { - List list = new ArrayList(); - String res = properties.getProperty(P_DOWNLOAD_MYLIST); - String[] nums = res.split(","); - for (int i = 0; i < nums.length; i++) { - String text = nums[i].trim(); - if (!text.isEmpty()) { - list.add(text); - } - } - return list; + String[] res = properties.getStringArray(P_DOWNLOAD_MYLIST); + return Arrays.asList(res); } public List getNicoFeeds() { @@ -250,4 +263,12 @@ public final class Config { } return list; } + + public static File getConfigfile() { + return CONFIG_FILE; + } + + public static File getFeedUrlFile() { + return FEEDURL_FILE; + } } diff --git a/src/nicobrowser/gui/config/ConfigFrame.form b/src/nicobrowser/gui/config/ConfigFrame.form new file mode 100644 index 0000000..a92a3fc --- /dev/null +++ b/src/nicobrowser/gui/config/ConfigFrame.form @@ -0,0 +1,366 @@ + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
diff --git a/src/nicobrowser/gui/config/ConfigFrame.java b/src/nicobrowser/gui/config/ConfigFrame.java new file mode 100644 index 0000000..d36891d --- /dev/null +++ b/src/nicobrowser/gui/config/ConfigFrame.java @@ -0,0 +1,385 @@ +/* $Id$ */ + +/* + * ConfigFrame.java + * + * Created on 2009/11/30, 16:35:22 + */ +package nicobrowser.gui.config; + +import java.io.IOException; +import java.util.logging.Level; +import java.util.logging.Logger; +import javax.swing.JFileChooser; +import javax.swing.JOptionPane; +import javax.swing.JTextField; +import javax.swing.UIManager; +import nicobrowser.Config; +import org.apache.commons.configuration.PropertiesConfiguration; +import org.apache.commons.io.FilenameUtils; + +/** + * + * @author yuki + */ +public class ConfigFrame extends javax.swing.JFrame { + + private final Config config; + + /** Creates new form ConfigFrame */ + public ConfigFrame() { + initComponents(); + configFileField.setText(Config.getConfigfile().getAbsolutePath()); + feedFileField.setText(Config.getFeedUrlFile().getAbsolutePath()); + config = Config.getInstance(); + + // ニコニコ動画アカウント + idField.setText(config.getNicoMail()); + passField.setText(config.getNicoPassword()); + + // 保存先 + String dbPath = FilenameUtils.getFullPathNoEndSeparator(config.getDbFile()); + dbPathField.setText(dbPath); + flvPathField.setText(config.getSrcSaveDir()); + + // 動作 + waitSpinner.setValue(config.getWaitTime()); + retrySpinner.setValue(config.getMaxRetry()); + } + + /** This method is called from within the constructor to + * initialize the form. + * WARNING: Do NOT modify this code. The content of this method is + * always regenerated by the Form Editor. + */ + @SuppressWarnings("unchecked") + // //GEN-BEGIN:initComponents + private void initComponents() { + + jPanel1 = new javax.swing.JPanel(); + configFileField = new javax.swing.JTextField(); + feedFileField = new javax.swing.JTextField(); + configFileLabel = new javax.swing.JLabel(); + feedFileLabel = new javax.swing.JLabel(); + jLabel5 = new javax.swing.JLabel(); + jPanel2 = new javax.swing.JPanel(); + idLabel = new javax.swing.JLabel(); + passLabel = new javax.swing.JLabel(); + idField = new javax.swing.JTextField(); + passField = new javax.swing.JPasswordField(); + jPanel4 = new javax.swing.JPanel(); + jLabel3 = new javax.swing.JLabel(); + jLabel4 = new javax.swing.JLabel(); + dbPathField = new javax.swing.JTextField(); + flvPathField = new javax.swing.JTextField(); + dbPathButton = new javax.swing.JButton(); + flvPathButton = new javax.swing.JButton(); + jPanel3 = new javax.swing.JPanel(); + jLabel1 = new javax.swing.JLabel(); + jLabel2 = new javax.swing.JLabel(); + waitSpinner = new javax.swing.JSpinner(); + retrySpinner = new javax.swing.JSpinner(); + jPanel5 = new javax.swing.JPanel(); + savaButton = new javax.swing.JButton(); + + setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE); + setTitle("NicoBrowser - コンフィグ設定"); + setResizable(false); + + jPanel1.setBorder(javax.swing.BorderFactory.createTitledBorder("情報")); + + configFileField.setEditable(false); + + feedFileField.setEditable(false); + + configFileLabel.setText("コンフィグ,マイリスト"); + + feedFileLabel.setText("フィード(RSS)"); + + jLabel5.setText("マイリスト、フィードの設定は上記のファイルを直接エディタで開いて編集してください"); + + org.jdesktop.layout.GroupLayout jPanel1Layout = new org.jdesktop.layout.GroupLayout(jPanel1); + jPanel1.setLayout(jPanel1Layout); + jPanel1Layout.setHorizontalGroup( + jPanel1Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(jPanel1Layout.createSequentialGroup() + .add(jPanel1Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(configFileLabel) + .add(feedFileLabel)) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel1Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(feedFileField, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, 301, Short.MAX_VALUE) + .add(configFileField, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, 301, Short.MAX_VALUE))) + .add(jPanel1Layout.createSequentialGroup() + .add(jLabel5) + .addContainerGap()) + ); + jPanel1Layout.setVerticalGroup( + jPanel1Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(jPanel1Layout.createSequentialGroup() + .add(jPanel1Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.BASELINE) + .add(configFileField, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE) + .add(configFileLabel)) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel1Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.BASELINE) + .add(feedFileField, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE) + .add(feedFileLabel)) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jLabel5) + .addContainerGap(org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)) + ); + + jPanel2.setBorder(javax.swing.BorderFactory.createTitledBorder("ニコニコ動画アカウント")); + + idLabel.setText("ID(メールアドレス)"); + + passLabel.setText("パスワード"); + + org.jdesktop.layout.GroupLayout jPanel2Layout = new org.jdesktop.layout.GroupLayout(jPanel2); + jPanel2.setLayout(jPanel2Layout); + jPanel2Layout.setHorizontalGroup( + jPanel2Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(jPanel2Layout.createSequentialGroup() + .add(jPanel2Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(idLabel) + .add(passLabel)) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel2Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(passField, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, 302, Short.MAX_VALUE) + .add(idField, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, 302, Short.MAX_VALUE))) + ); + jPanel2Layout.setVerticalGroup( + jPanel2Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(jPanel2Layout.createSequentialGroup() + .add(jPanel2Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.BASELINE) + .add(idLabel) + .add(idField, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel2Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.BASELINE) + .add(passLabel) + .add(passField, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE))) + ); + + jPanel4.setBorder(javax.swing.BorderFactory.createTitledBorder("保存先")); + + jLabel3.setText("履歴DB"); + + jLabel4.setText("動画ファイル"); + + dbPathButton.setText("..."); + dbPathButton.addActionListener(new java.awt.event.ActionListener() { + public void actionPerformed(java.awt.event.ActionEvent evt) { + dbPathButtonActionPerformed(evt); + } + }); + + flvPathButton.setText("..."); + flvPathButton.addActionListener(new java.awt.event.ActionListener() { + public void actionPerformed(java.awt.event.ActionEvent evt) { + flvPathButtonActionPerformed(evt); + } + }); + + org.jdesktop.layout.GroupLayout jPanel4Layout = new org.jdesktop.layout.GroupLayout(jPanel4); + jPanel4.setLayout(jPanel4Layout); + jPanel4Layout.setHorizontalGroup( + jPanel4Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(jPanel4Layout.createSequentialGroup() + .add(jPanel4Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(jLabel4) + .add(jLabel3)) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel4Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(org.jdesktop.layout.GroupLayout.TRAILING, dbPathField, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, 281, Short.MAX_VALUE) + .add(org.jdesktop.layout.GroupLayout.TRAILING, flvPathField, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, 281, Short.MAX_VALUE)) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel4Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(org.jdesktop.layout.GroupLayout.TRAILING, flvPathButton) + .add(org.jdesktop.layout.GroupLayout.TRAILING, dbPathButton))) + ); + jPanel4Layout.setVerticalGroup( + jPanel4Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(jPanel4Layout.createSequentialGroup() + .add(jPanel4Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.BASELINE) + .add(jLabel3) + .add(dbPathButton) + .add(dbPathField, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel4Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.BASELINE) + .add(jLabel4) + .add(flvPathButton) + .add(flvPathField, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE))) + ); + + jPanel3.setBorder(javax.swing.BorderFactory.createTitledBorder("動作")); + + jLabel1.setText("ダウンロード間隔(秒)"); + + jLabel2.setText("失敗時リトライ回数"); + + org.jdesktop.layout.GroupLayout jPanel3Layout = new org.jdesktop.layout.GroupLayout(jPanel3); + jPanel3.setLayout(jPanel3Layout); + jPanel3Layout.setHorizontalGroup( + jPanel3Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(jPanel3Layout.createSequentialGroup() + .add(jPanel3Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING, false) + .add(jPanel3Layout.createSequentialGroup() + .add(jLabel1) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(waitSpinner, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, 46, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE)) + .add(jPanel3Layout.createSequentialGroup() + .add(jLabel2) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.UNRELATED) + .add(retrySpinner))) + .addContainerGap(240, Short.MAX_VALUE)) + ); + jPanel3Layout.setVerticalGroup( + jPanel3Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(jPanel3Layout.createSequentialGroup() + .add(jPanel3Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.BASELINE) + .add(jLabel1) + .add(waitSpinner, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel3Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.BASELINE) + .add(jLabel2) + .add(retrySpinner, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE))) + ); + + jPanel5.setBorder(javax.swing.BorderFactory.createTitledBorder("")); + + savaButton.setText("保存"); + savaButton.addActionListener(new java.awt.event.ActionListener() { + public void actionPerformed(java.awt.event.ActionEvent evt) { + savaButtonActionPerformed(evt); + } + }); + + org.jdesktop.layout.GroupLayout jPanel5Layout = new org.jdesktop.layout.GroupLayout(jPanel5); + jPanel5.setLayout(jPanel5Layout); + jPanel5Layout.setHorizontalGroup( + jPanel5Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(org.jdesktop.layout.GroupLayout.TRAILING, jPanel5Layout.createSequentialGroup() + .addContainerGap(332, Short.MAX_VALUE) + .add(savaButton)) + ); + jPanel5Layout.setVerticalGroup( + jPanel5Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(savaButton) + ); + + org.jdesktop.layout.GroupLayout layout = new org.jdesktop.layout.GroupLayout(getContentPane()); + getContentPane().setLayout(layout); + layout.setHorizontalGroup( + layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(jPanel1, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) + .add(jPanel2, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) + .add(jPanel4, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) + .add(jPanel3, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) + .add(jPanel5, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) + ); + layout.setVerticalGroup( + layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING) + .add(layout.createSequentialGroup() + .add(jPanel1, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, 90, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel2, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel4, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel3, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE) + .addPreferredGap(org.jdesktop.layout.LayoutStyle.RELATED) + .add(jPanel5, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE, org.jdesktop.layout.GroupLayout.DEFAULT_SIZE, org.jdesktop.layout.GroupLayout.PREFERRED_SIZE) + .addContainerGap()) + ); + + pack(); + }// //GEN-END:initComponents + + private void dbPathButtonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_dbPathButtonActionPerformed + setPathField(dbPathField); + }//GEN-LAST:event_dbPathButtonActionPerformed + + private void flvPathButtonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_flvPathButtonActionPerformed + setPathField(flvPathField); + }//GEN-LAST:event_flvPathButtonActionPerformed + + private void savaButtonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_savaButtonActionPerformed + PropertiesConfiguration p = new PropertiesConfiguration(); + + p.setProperty(Config.P_NICOVIDEO_MAIL, idField.getText()); + p.setProperty(Config.P_NICOVIDEO_PASSWORD, String.valueOf(passField.getPassword())); + + p.setProperty(Config.P_PATH_DB, dbPathField.getText()); + p.setProperty(Config.P_PATH_SAVEFILE, flvPathField.getText()); + + p.setProperty(Config.P_DOWNLOAD_WAIT, waitSpinner.getValue().toString()); + p.setProperty(Config.P_DOWNLOAD_RETRY, retrySpinner.getValue().toString()); + try { + config.updateConfigFile(p); + JOptionPane.showMessageDialog(this, Config.getConfigfile().getAbsolutePath() + "\nを更新しました"); + } catch (IOException ex) { + Logger.getLogger(ConfigFrame.class.getName()).log(Level.SEVERE, null, ex); + JOptionPane.showMessageDialog(this, "保存に失敗しました", "エラー", JOptionPane.ERROR_MESSAGE); + } + }//GEN-LAST:event_savaButtonActionPerformed + + private void setPathField(JTextField field) { + String current = field.getText(); + JFileChooser fc = new JFileChooser(current); + fc.setFileSelectionMode(JFileChooser.DIRECTORIES_ONLY); + int ret = fc.showDialog(this, "選択"); + if (ret == JFileChooser.APPROVE_OPTION) { + String selectPath = fc.getSelectedFile().getAbsolutePath(); + field.setText(selectPath); + } + } + + /** + * @param args the command line arguments + */ + public static void main(String args[]) { + setLookAndFeel(); + java.awt.EventQueue.invokeLater(new Runnable() { + + public void run() { + new ConfigFrame().setVisible(true); + } + }); + } + + public static void setLookAndFeel() { + UIManager.LookAndFeelInfo[] lafs = UIManager.getInstalledLookAndFeels(); + String lafClassName = UIManager.getSystemLookAndFeelClassName(); + try { + UIManager.setLookAndFeel(lafClassName); + } catch (Exception ex) { + } + } + // Variables declaration - do not modify//GEN-BEGIN:variables + private javax.swing.JTextField configFileField; + private javax.swing.JLabel configFileLabel; + private javax.swing.JButton dbPathButton; + private javax.swing.JTextField dbPathField; + private javax.swing.JTextField feedFileField; + private javax.swing.JLabel feedFileLabel; + private javax.swing.JButton flvPathButton; + private javax.swing.JTextField flvPathField; + private javax.swing.JTextField idField; + private javax.swing.JLabel idLabel; + private javax.swing.JLabel jLabel1; + private javax.swing.JLabel jLabel2; + private javax.swing.JLabel jLabel3; + private javax.swing.JLabel jLabel4; + private javax.swing.JLabel jLabel5; + private javax.swing.JPanel jPanel1; + private javax.swing.JPanel jPanel2; + private javax.swing.JPanel jPanel3; + private javax.swing.JPanel jPanel4; + private javax.swing.JPanel jPanel5; + private javax.swing.JPasswordField passField; + private javax.swing.JLabel passLabel; + private javax.swing.JSpinner retrySpinner; + private javax.swing.JButton savaButton; + private javax.swing.JSpinner waitSpinner; + // End of variables declaration//GEN-END:variables +} diff --git a/src/nicobrowser/main/Main.java b/src/nicobrowser/main/Main.java index 9468374..aaca44b 100644 --- a/src/nicobrowser/main/Main.java +++ b/src/nicobrowser/main/Main.java @@ -1,7 +1,6 @@ /*$Id$*/ package nicobrowser.main; -import nicobrowser.update.DBUpdater; import java.io.File; import java.io.IOException; import java.util.ArrayList; @@ -14,23 +13,58 @@ import javax.persistence.EntityManagerFactory; import javax.persistence.EntityTransaction; import javax.persistence.Persistence; import javax.persistence.Query; +import javax.swing.JFrame; +import javax.swing.SwingUtilities; import nicobrowser.Config; import nicobrowser.GetFlvResult; import nicobrowser.Config.NicoFeed; import nicobrowser.NicoHttpClient; import nicobrowser.entity.NicoContent; import nicobrowser.entity.NicoContent.Status; +import nicobrowser.gui.config.ConfigFrame; +import nicobrowser.update.DBUpdater; +import org.apache.commons.cli.CommandLine; +import org.apache.commons.cli.CommandLineParser; +import org.apache.commons.cli.HelpFormatter; +import org.apache.commons.cli.Options; +import org.apache.commons.cli.ParseException; +import org.apache.commons.cli.PosixParser; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; public class Main { + public static final String VERSION = "version 0.3.0"; private static Log log = LogFactory.getLog(Main.class); public static void main(String[] args) throws IOException { - boolean res = Config.createNewConfigFiles(); + final boolean res = Config.createNewConfigFiles(); + + CommandLineParser parser = new PosixParser(); + Options options = createOptions(); + + try { + // parse the command line arguments + CommandLine line = parser.parse(options, args); + + if (line.hasOption("help")) { + new HelpFormatter().printHelp("java -jar NicoBrowser.jar [option]", options); + return; + } else if (line.hasOption("version")) { + System.out.println(VERSION); + return; + } else if (line.hasOption("property")) { + propertyOpen(); + return; + } + } catch (ParseException exp) { + HelpFormatter formatter = new HelpFormatter(); + formatter.printHelp("java -jar NicoBrowser.jar [option]", options); + return; + } + if (res) { - System.out.println("コンフィグファイルを作成しました. 編集後, 再実行してください."); + propertyOpen(); return; } @@ -44,6 +78,26 @@ public class Main { new Main().start(); } + private static Options createOptions() throws IllegalArgumentException { + Options options = new Options(); + options.addOption("h", "help", false, "このメッセージを表示します"); + options.addOption("p", "property", false, "コンフィグ設定画面を起動します"); + options.addOption("v", "version", false, "バージョン情報を表示します"); + return options; + } + + private static void propertyOpen() { + SwingUtilities.invokeLater(new Runnable() { + + public void run() { + ConfigFrame.setLookAndFeel(); + JFrame frame = new ConfigFrame(); + frame.setLocationByPlatform(true); + frame.setVisible(true); + } + }); + } + public void start() { log.info("program start"); diff --git a/src/resources/feedurl.txt b/src/resources/feedurl.txt index 70c38b9..71ceca5 100644 --- a/src/resources/feedurl.txt +++ b/src/resources/feedurl.txt @@ -1,4 +1,5 @@ -http://www.nicovideo.jp/ranking/mylist/daily/all?rss=atom, 20 +# カテゴリ合算 の マイリスト ランキング(デイリー)の上位20件 +http://www.nicovideo.jp/ranking/mylist/daily/all?rss=2.0, 20 # URL, 抽出数 @@ -7,18 +8,12 @@ http://www.nicovideo.jp/ranking/mylist/daily/all?rss=atom, 20 # 抽出数は100以内. # 行頭が#の行はコメント扱い. - ### 記述例 ### -### フィードのURLについては http://nicowiki.com/?RSSフィード一覧 などを参照のこと. - -# 新着投稿動画 -# http://www.nicovideo.jp/newarrival?rss=2.0, 100 - -# 新着動画(カテゴリ:科学) -# http://www.nicovideo.jp/tag/科学?sort=f&rss=2.0, 3 +### 記述するURLは +### http://yukihane.dip.jp/dist/NicoBrowser/feedurllist.html +### http://nicowiki.com/RSS%E3%83%95%E3%82%A3%E3%83%BC%E3%83%89%E4%B8%80%E8%A6%A7.html +### などを参考のこと -# 新着コメント動画 -# http://www.nicovideo.jp/recent?rss=2.0,10 -# 自然のマイリストランキング(月間) -# http://www.nicovideo.jp/ranking/mylist/monthly/nature?rss=2.0,10 +# 新着投稿動画 15件 +# http://www.nicovideo.jp/newarrival?rss=2.0, 15 diff --git a/test/nicobrowser/ConfigTest.java b/test/nicobrowser/ConfigTest.java index dafe6a5..50af87d 100644 --- a/test/nicobrowser/ConfigTest.java +++ b/test/nicobrowser/ConfigTest.java @@ -254,7 +254,7 @@ public class ConfigTest { Config config = Config.getInstance(); int res = config.getWaitTime(); - assertEquals(10, res); + assertEquals(15, res); } @Test