001/*
002 * Copyright (c) 2009 The openGion Project.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *     http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
013 * either express or implied. See the License for the specific language
014 * governing permissions and limitations under the License.
015 */
016package org.opengion.hayabusa.report;
017
018import org.opengion.hayabusa.common.HybsSystem;
019import org.opengion.hayabusa.common.HybsSystemException;
020import org.opengion.fukurou.util.StringUtil;
021import org.opengion.fukurou.util.ApplicationInfo;
022import org.opengion.fukurou.db.DBUtil;
023
024import java.io.File;
025
026/**
027 * DBTableModelオブジェクトをレポート形式に返還するタグリブクラスです。
028 * このオブジェクトに、 データ(DBTableModel)と、コントローラ(DBTableReport クラス)を与えて、
029 * 外部からコントロールすることで、各種形式で データ(DBTableModel)を表示させることが
030 * 可能です。
031 *
032 * @og.group 帳票システム
033 *
034 * @version  4.0
035 * @author   Kazuhiko Hasegawa
036 * @since    JDK5.0,
037 */
038public class ReportProcessing {
039
040        private static final String FGRUN_1     = "1";  // HTMLのみ
041        private static final String FGRUN_2     = "2";  // 印刷のみ
042        private static final String FGRUN_3     = "3";  // 出力+印刷
043
044        // 3.8.0.0 (2005/06/07) 実行方法(FGRUN)に、EXCEL取込関連のフラグ値を追加。
045        private static final String FGRUN_5     = "5";  // 取込のみ
046        private static final String FGRUN_6     = "6";  // PG起動のみ
047        private static final String FGRUN_7     = "7";  // 取込+PG起動
048
049        private static final String FGRUN_A     = "A";  // RFID(通常印刷) 4.0.3.0 (2007/12/26)
050        private static final String FGRUN_B     = "B";  // RFID(全印刷) 4.0.3.0 (2007/12/26)
051        private static final String FGRUN_C     = "C";  // RFID(全消去) 4.0.3.0 (2007/12/26)
052        private static final String FGRUN_D     = "D";  // RFID(連続消去) 4.1.1.0 (2008/02/21)
053        
054        private static final String FGRUN_G     = "G";  // CSV(印刷) 5.9.0.0  (2015/09/04)
055        private static final String FGRUN_H     = "H";  // CSV(Excel) 5.9.0.0 (2015/09/04)
056        private static final String FGRUN_I     = "I";  // CSV(PDF) 5.9.0.0  (2015/09/04)
057        private static final String FGRUN_J     = "J";  // CSV(XLSX) 5.9.4.2 (2016/01/13)
058        
059
060        private static final String CR     = HybsSystem.CR ;
061
062        // 印刷時に使用するテンポラリフォルダ名
063        private final String REPORT_URL =
064                HybsSystem.url2dir( StringUtil.nval(
065                                                                HybsSystem.sys( "REPORT_FILE_URL" ) ,
066                                                                HybsSystem.sys( "FILE_URL"   ) + "REPORT/" ) ) ;
067
068        // 3.8.0.0 (2005/06/07) 追加
069        // EXCEL取込時に使用するテンポラリフォルダ名。ファイル名は、要求番号.xls
070        private final String EXCELIN_URL =
071                HybsSystem.url2dir( StringUtil.nval(
072                                                                HybsSystem.sys( "EXCEL_IN_FILE_URL" ) ,
073                                                                HybsSystem.sys( "FILE_URL"   ) + "EXCELIN/" ) ) ;
074
075        private StringBuilder errMsg = new StringBuilder();
076
077        // 各種DBを検索するときに、キー情報
078        private String          SYSTEM_ID       = null;
079        private String          YKNO            = null;
080        private String          GROUPID         = null;
081        private String          LISTID          = null;
082        private String          JOKEN           = null;
083        private String          OUT_DIR         = null;         // 5.1.0.0 (2009/11/04) OUTDIR ⇒ OUT_DIR
084        private String          OUT_FILE        = null;         // 5.1.0.0 (2009/11/04) OUTFILE ⇒ OUT_FILE
085        private String          outputFile      = null;
086        private boolean         isDebug         = false;        // 3.8.5.0 (2006/03/06) デバッグ用のフラグを追加
087
088        // GE53 検索結果
089        private String          FGRUN           = null;
090        private String          PRTID           = null;
091        private String          LANG            = "ja";
092        private String          PRGDIR          = null;
093        private String          PRGFILE         = null;
094        private String          DMN_GRP         = null;         // 3.8.0.5 (2005/08/26)
095        private String          programFile     = null;
096
097        // GE53 の帳票振分情報を取得するSQL文です。
098        // 3.8.0.5 (2005/08/26) デーモングループ追加
099        // 4.0.0 (2005/01/31) 共有 system_id を、考慮
100        private static final String GE53_SELECT =
101                "SELECT FGRUN,PRTID,LANG,PRGDIR,PRGFILE,SYSTEM_ID,DMN_GRP" +
102                " FROM GE53" +
103                " WHERE FGJ = '1'" +
104                " AND  SYSTEM_ID IN (?,'**')" +
105                " AND  JOKEN = ?" ;
106
107        private static final int GE53_FGRUN             = 0;
108        private static final int GE53_PRTID             = 1;
109        private static final int GE53_LANG              = 2;
110        private static final int GE53_PRGDIR    = 3;
111        private static final int GE53_PRGFILE   = 4;
112        private static final int GE53_SYSTEM_ID = 5;
113        private static final int GE53_DMN_GRP   = 6;
114
115        /** コネクションにアプリケーション情報を追記するかどうか指定 */
116        public static final boolean USE_DB_APPLICATION_INFO  = HybsSystem.sysBool( "USE_DB_APPLICATION_INFO" ) ;
117
118        // 3.8.7.0 (2006/12/15) アクセスログ取得の為,ApplicationInfoオブジェクトを設定
119        private ApplicationInfo appInfo;
120        private final String DBID = HybsSystem.sys( "RESOURCE_DBID" );          // 5.5.5.1 (2012/08/07) リソース系DBID 付け忘れ対応
121
122        /**
123         * 処理を実行します。
124         * このメソッドを実行すると、レポート変換、レポート出力を順次処理していきます。
125         *
126         * @og.rev 3.0.0.4 (2003/02/26) FGRUN が PRT のみのときは,MODELFILE のみセットして終了する。
127         * @og.rev 3.8.0.0 (2005/06/07) ReportConverter の initialDataSet() を呼び出して,MODELFILE をセットする。
128         * @og.rev 3.8.0.0 (2005/06/07) EXCEL 登録機能を追加します。
129         * @og.rev 3.8.0.0 (2005/06/07) 実行結果を boolean ではなく、文字列(FGKAN_XX)で返します。
130         * @og.rev 3.8.0.5 (2005/08/26) デーモングループ追加
131         * @og.rev 3.8.0.9 (2005/10/17) エラーメッセージ強化
132         * @og.rev 3.8.5.0 (2006/03/06) 標準画面出力メッセージの変更。日付、プリンタIDの表示
133         * @og.rev 3.8.7.0 (2006/12/15) アクセスログ取得の為,ApplicationInfoオブジェクトを設定
134         * @og.rev 4.0.3.0 (2007/12/26) RFID対応(実行方法='A','B','C'の処理追加)
135         * @og.rev 4.1.1.0 (2008/02/21) RFID対応(実行方法='D'の処理追加)
136         * @og.rev 4.3.3.0 (2008/10/01) 板金RFID対応(PRGDIR,PRGFILEの渡し等)
137         * @og.rev 5.4.3.9 (2012/01/25) RFIDの雛形ファイル名私は旧帳票は無視する
138         * @og.rev 5.9.0.0 (2015/09/04) CSV出力対応
139         * @og.rev 5.9.2.2 (2015/11/20) CSV出力にgrpid,dmngrpを追加
140         * @og.rev 5.9.4.2 (2016/01/13) FGRUN_J追加
141         *
142         * @return 結果 (FGKAN_XX エラー時は、null)
143         */
144        public String execute() {
145                System.out.println();
146                System.out.println( "Process Start:" + HybsSystem.getDate( "yyyy/MM/dd HH:mm:ss" ) );
147                System.out.println( "  SYSTEM_ID=[" + SYSTEM_ID + "] YKNO=[" + YKNO + "] GROUPID=[" + GROUPID + "]" );
148                System.out.println( "  PRTID=[" + PRTID + "] LISTID=[" + LISTID + "] JOKEN=[" + JOKEN + "]" );
149                String  fgkan = null;
150
151                // 3.8.7.0 (2006/12/15) アクセスログ取得の為,ApplicationInfoオブジェクトを設定
152                if( USE_DB_APPLICATION_INFO ) {
153                        appInfo = new ApplicationInfo();
154                        // ユーザーID,IPアドレス,ホスト名
155                        appInfo.setClientInfo( SYSTEM_ID,HybsSystem.HOST_ADRS,HybsSystem.HOST_NAME );
156                        // 画面ID,操作,プログラムID
157                        appInfo.setModuleInfo( "ReportProcessing",YKNO,LISTID );
158                }
159                else {
160                        appInfo = null;
161                }
162
163                boolean flag ;
164                try {
165                        flag = initialDataSet( appInfo );
166                        System.out.print( "INIT=" + flag + "," );
167                        String reportDir  = REPORT_URL + SYSTEM_ID + HybsSystem.FS + LISTID ;
168                        String modelFile = null;
169
170        // ================== FGRUN_1,2,3 は、帳票印刷処理 ===========================================
171                        // 3.8.0.0 (2005/06/07) 実行方法(FGRUN)に、EXCEL取込関連のフラグ値を追加。Stringからintに変更
172                        if( flag && ( FGRUN.equals( FGRUN_1 ) || FGRUN.equals( FGRUN_2 ) || FGRUN.equals( FGRUN_3 ) ) ) {
173                                System.out.println( "RUN_" + FGRUN );
174                                ReportConverter rc = new ReportConverter( SYSTEM_ID,YKNO,LISTID,reportDir,LANG,isDebug );
175
176                                // 3.8.0.0 (2005/06/07) MODELFILE のセットは、initialDataSet() で行う。
177                                flag = rc.initialDataSet();
178                                modelFile = rc.modelFile(); // 4.0.1.0 (2007/12/18)
179
180                                if( flag && ( FGRUN.equals( FGRUN_1 ) || FGRUN.equals( FGRUN_3 ) ) ) {
181                                        flag = rc.execute();
182                                }
183
184                                if( flag ) { fgkan = GE50Access.FG_OK; }
185                                errMsg.append( rc.getErrMsg() ).append( CR );
186                        }
187                        if( flag && ( FGRUN.equals( FGRUN_2 ) || FGRUN.equals( FGRUN_3 ) ) ) {
188                                System.out.println( "RUN_" + FGRUN );
189                                fgkan = null;
190                                // 3.8.0.5 (2005/08/26) デーモングループ追加
191                                ReportPrint rp = new ReportPrint( SYSTEM_ID,YKNO,PRTID,programFile,reportDir,modelFile,outputFile,DMN_GRP,isDebug );
192                                flag = rp.execute();
193                                if( flag ) { fgkan = GE50Access.FG_OK; }
194                                errMsg.append( rp.getErrMsg() ).append( CR );
195                        }
196
197        // ================== FGRUN_4,5,6 は、EXCEL取込処理 ===========================================
198                        // 3.8.0.0 (2005/06/07) EXCEL 登録機能を追加します。
199                        String excelinDir = EXCELIN_URL + SYSTEM_ID + HybsSystem.FS + LISTID;
200                        if( flag && ( FGRUN.equals( FGRUN_5 ) || FGRUN.equals( FGRUN_7 ) ) ) {
201                                System.out.println( "RUN_" + FGRUN );
202                                ExcelInsert ei = new ExcelInsert( SYSTEM_ID,YKNO,LISTID,excelinDir,isDebug );
203
204                                flag = ei.execute();
205                                if( flag ) { fgkan = GE50Access.FG_DBIN; }
206                                errMsg.append( ei.getErrMsg() ).append( CR );
207                        }
208                        if( flag && ( FGRUN.equals( FGRUN_6 ) || FGRUN.equals( FGRUN_7 ) ) ) {
209                                System.out.println( "RUN_" + FGRUN );
210                                fgkan = null;
211                                ProgramRun pr = new ProgramRun( SYSTEM_ID,YKNO,LISTID,isDebug );
212                                flag = pr.execute();
213                                if( flag ) { fgkan = GE50Access.FG_OK; }
214                                errMsg.append( pr.getErrMsg() ).append( CR );
215                        }
216
217        // ================== FGRUN_A,B,C,D は、RFID出力処理 ===========================================
218                        if( flag && ( FGRUN.equals( FGRUN_A ) || FGRUN.equals( FGRUN_B ) || FGRUN.equals( FGRUN_C ) || FGRUN.equals( FGRUN_D ) ) ) {
219                                System.out.println( "RUN_" + FGRUN );
220                                //RFIDPrintRequest rpr = new RFIDPrintRequest( SYSTEM_ID,YKNO,LISTID,LANG,FGRUN,PRTID,isDebug );
221                                // 4.3.3.0 (2008/10/01) RFIDPrintRequestのコンストラクタ引数追加
222                                // 5.4.3.9 (2012/01/25) 雛形ファイル名は新帳票のみ対応
223                                RFIDPrintRequest rpr = new RFIDPrintRequest( SYSTEM_ID,YKNO,LISTID,LANG,FGRUN,PRTID,PRGDIR,PRGFILE,OUT_DIR,null,isDebug );
224                                flag = rpr.initialDataSet();
225                                if( flag ) { flag = rpr.execute(); }
226                                //if( flag ) { fgkan = GE50Access.FG_RUN; }
227                                // 4.3.3.0 (2008/10/01) 完成フラグの取り方変更
228                                if( flag ) { fgkan = rpr.getFgkan(); }
229                                errMsg.append( rpr.getErrMsg() ).append( CR );
230                        }
231                        
232                        // 5.9.0.0 (2015/09/04)
233                        // 5.9.4.2 (2016/01/13) FGRUN_J追加
234                        // ================== FGRUN_G,H,I は、CSV出力処理 =========================================== 
235                        if( flag && ( FGRUN.equals( FGRUN_G ) || FGRUN.equals( FGRUN_H ) || FGRUN.equals( FGRUN_I ) || FGRUN.equals( FGRUN_J ) ) ) {
236                                System.out.println( "RUN_" + FGRUN );
237                                CSVPrintRequest rpr = new CSVPrintRequest( SYSTEM_ID,YKNO,LISTID,LANG,FGRUN,PRTID,PRGDIR,PRGFILE,OUT_DIR,null
238//                                              ,isDebug );
239                                                ,GROUPID,DMN_GRP,isDebug );  //5.9.2.2
240                                flag = rpr.initialDataSet();
241                                if( flag ) { flag = rpr.execute(); }
242                                if( flag ) { fgkan = rpr.getFgkan(); }
243                                errMsg.append( rpr.getErrMsg() ).append( CR );
244                        }
245                }
246                catch ( RuntimeException ex ) {
247                        errMsg.append( "ReportProcessing Execute Error! " ).append( CR ) ;
248                        errMsg.append( "==============================" ).append( CR );
249                        errMsg.append( StringUtil.stringStackTrace( ex ) ).append( CR ) ;
250                        flag = false;
251                }
252
253                return flag ? fgkan : null ;    // 正常なら、fgkan を、異常なら null を返します。
254        }
255
256        /**
257         * 内部変数をクリアします。
258         * このオブジェクトを再利用する場合は、必ずこのメソッドで内部変数の
259         * クリアが必要です。
260         * 注意:このクラス自身は、同期処理は入っていません
261         *
262         * @og.rev 3.8.0.5 (2005/08/26) デーモングループ追加
263         *
264         */
265        public void clear() {
266                SYSTEM_ID       = null;
267                YKNO            = null;
268                GROUPID         = null;
269                LISTID          = null;
270                JOKEN           = null;
271                OUT_DIR         = null;         // 5.1.0.0 (2009/11/04) OUTDIR ⇒ OUT_DIR
272                OUT_FILE        = null;         // 5.1.0.0 (2009/11/04) OUTFILE ⇒ OUT_FILE
273                outputFile      = null;
274                isDebug         = false;        // 3.8.5.0 (2006/03/06) デバッグ用のフラグを追加
275
276                FGRUN           = null;
277                PRTID           = null;
278                LANG            = null;
279                PRGDIR          = null;
280                PRGFILE         = null;
281                DMN_GRP         = null;         // 3.8.0.5 (2005/08/26)
282                programFile     = null;
283
284                errMsg          = new StringBuilder() ;
285        }
286
287        /**
288         * システムID(SYSTEM_ID)をセットします。
289         *
290         * @param val システムID
291         */
292        public void setSystemId( final String val ) { SYSTEM_ID = val; }
293
294        /**
295         * 要求番号(YKNO)をセットします。
296         *
297         * @param val 要求番号
298         */
299        public void setYkno( final String val ) { YKNO = val; }
300
301        /**
302         * グループID(GROUPID)をセットします。
303         *
304         * @param val グループID
305         */
306        public void setGroupId( final String val ) { GROUPID = val; }
307
308        /**
309         * 帳票ID(LISTID)をセットします。
310         *
311         * @param val 帳票ID
312         */
313        public void setListId( final String val ) { LISTID = val; }
314
315        /**
316         * 処理条件(JOKEN)をセットします。
317         *
318         * @param val 処理条件
319         */
320        public void setJoken( final String val ) { JOKEN = val; }
321
322        /**
323         * プリンターID(PRTID)をセットします。
324         *
325         * @og.rev 3.8.5.0 (2006/03/06) PRTID が指定されていれば、その値を使用する。なければ NULL
326         * @og.rev 4.3.4.4 (2009/01/01) メソッド名変更
327         *
328         * @param val プリンターID
329         */
330        public void setPrtId( final String val ) { PRTID = val; }
331
332        /**
333         * 出力先ディレクトリ(OUT_DIR)をセットします。
334         *
335         * @param val 出力先ディレクトリ
336         */
337        public void setOutDir( final String val ) { OUT_DIR = val; }
338
339        /**
340         * 出力先ファイル(OUT_FILE)をセットします。
341         *
342         * @param val 出力先ファイル
343         */
344        public void setOutFile( final String val ) { OUT_FILE = val; }
345
346        /**
347         * debugフラグをセットします。
348         *
349         * @og.rev 3.8.5.0 (2006/03/06) デバッグ用のフラグを追加します。
350         *
351         * @param       flag    デバッグフラグ[true:デバッグ/false:通常]
352         */
353        public void setDebug( final boolean flag ) { isDebug = flag; }
354
355        /**
356         * 初期データセットを行います。
357         * ここでは、GE53 テーブルより必要な情報を取得します。
358         *
359         * @og.rev 3.8.0.5 (2005/08/26) デーモングループ追加
360         * @og.rev 3.8.5.0 (2006/03/06) プリンタIDが引数から、渡される場合の対応
361         * @og.rev 3.8.6.0 (2006/09/29) 出力先フォルダの自動生成を行います。
362         * @og.rev 3.8.7.0 (2006/12/15) アクセスログ取得の為,ApplicationInfoオブジェクトを設定
363         * @og.rev 5.1.0.0 (2009/11/04) OUTDIR ⇒ OUT_DIR , OUTFILE ⇒ OUT_FILE カラム名変更
364         * @og.rev 5.5.5.1 (2012/08/07) リソース系DBID 付け忘れ対策
365         *
366         * @param       appInfo アプリ情報オブジェクト
367         *
368         * @return      結果[true:正常/false:異常]
369         */
370        private boolean initialDataSet( final ApplicationInfo appInfo ) {
371                String[] args = new String[] { SYSTEM_ID,JOKEN };
372                // fgrun,prtid,lang,prgdir,prgfile
373//              String[][] vals = DBUtil.dbExecute( GE53_SELECT,args,appInfo );                 // 3.8.7.0 (2006/12/15)
374                String[][] vals = DBUtil.dbExecute( GE53_SELECT,args,appInfo, DBID );   // 5.5.5.1 (2012/08/07)
375                if( vals == null || vals.length == 0 ) {
376                        errMsg.append( "Data does not exist in GE53 table." ).append( CR );
377                        errMsg.append( "==============================" ).append( CR );
378                        errMsg.append( "SYSTEM_ID=[" ).append( SYSTEM_ID ).append( "] , " );
379                        errMsg.append( "JOKEN=["     ).append( JOKEN     ).append( "]" );
380                        errMsg.append( CR );
381                        return false;
382                }
383
384                int row = 0;
385                // 検索結果が複数帰ったとき、SYSTEM_ID が 指定されている方のデータ(行)を採用する。
386                for( int i=0; i<vals.length; i++ ) {
387                        if( SYSTEM_ID.equalsIgnoreCase( vals[i][GE53_SYSTEM_ID] ) ) { row = i; break; }
388                }
389
390                // 3.8.5.0 (2006/03/06) プリンタIDが引数から、渡される場合の対応
391                if( PRTID == null ) {
392                        PRTID = StringUtil.nval( vals[row][GE53_PRTID],PRTID   );
393                }
394
395                FGRUN   = StringUtil.nval( vals[row][GE53_FGRUN],       FGRUN   );
396                LANG    = StringUtil.nval( vals[row][GE53_LANG],        LANG    );
397                PRGDIR  = StringUtil.nval( vals[row][GE53_PRGDIR],      PRGDIR  );
398                PRGFILE = StringUtil.nval( vals[row][GE53_PRGFILE],     PRGFILE );
399                DMN_GRP = StringUtil.nval( vals[row][GE53_DMN_GRP],     DMN_GRP );      // 3.8.0.5 (2005/08/26)
400                programFile = PRGDIR + HybsSystem.FS + PRGFILE ;
401
402                if( ( OUT_DIR != null  && OUT_DIR.length() > 0 ) &&
403                        ( OUT_FILE != null && OUT_FILE.length() > 0 ) ) {
404                                outputFile  = OUT_DIR + HybsSystem.FS + OUT_FILE ;
405                                // 3.8.6.0 (2006/09/29) 出力先フォルダの自動生成を行います。
406                                File dir = new File(OUT_DIR);
407                                if( ! dir.exists() && ! dir.mkdirs() ) {
408                                        String errMsg = "ディレクトリの作成に失敗しました。[" + OUT_DIR + "]";
409                                        throw new HybsSystemException( errMsg );
410                                }
411                }
412
413                return true;
414        }
415
416        /**
417         * エラーが存在した場合に、エラーメッセージを返します。
418         *
419         * @return エラーメッセージ String
420         */
421        public String getErrMsg() {
422                return errMsg.toString();
423        }
424}