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     */
016    package org.opengion.hayabusa.taglib;
017    
018    import org.opengion.hayabusa.common.HybsSystem;
019    import org.opengion.hayabusa.db.DBColumn;
020    import org.opengion.hayabusa.db.DBTableModel;
021    import org.opengion.fukurou.util.Attributes;
022    import org.opengion.fukurou.util.ErrorMessage;
023    import org.opengion.fukurou.model.ArrayDataModel;
024    import org.opengion.fukurou.model.Formatter;
025    
026    import static org.opengion.fukurou.util.StringUtil.nval ;
027    
028    import java.util.List;
029    import java.util.ArrayList;
030    import java.util.Enumeration;
031    import java.util.Locale ;
032    
033    import java.io.ObjectOutputStream;
034    import java.io.ObjectInputStream;
035    import java.io.IOException;
036    
037    /**
038     * 検索結果の DBTableModelオブジェクトに値を設定するタグです?
039     *
040     * columnSet と共に使用する場合?、entryタグ の command属?と、columnSetタグ の command属??
041     * ??した場合?み、??れます?
042     * entryタグは、そのコマンドにより、DBTableModelオブジェクト?値を設定します?
043     * たとえ?、command="INSERT" なら??行?の??タを選択された行番号の次に挿入します?
044     * また?追??変更、削除された?DBTableModelオブジェク?でも??には????タ?
045     * 持って?ため、command="RESET" で??状態に戻すことが可能です?
046     *
047     * @og.formSample
048     * ●形式?
049     *       ・<og:entry command="…">
050     *             <og:columnSet command="…" />
051     *         </og:entry>
052     *       ・<og:entry command="…" />
053     *             ???columnSetを使わな??合でもresult.jspから次画面(insert,modify,copy.jsp?に
054     *                にDBTableModelをもって?場合には、??を書?ください?
055     *                (取消?とき?エンジン?DBTableModelを操作する?に使用する為)
056     * ●body?あ?EVAL_BODY_BUFFERED:BODYを評価し?{@XXXX} を解析しま?
057     *
058     * ●Tag定義??
059     *   <og:entry
060     *       command          ○?TAG】コマン?INSERT/COPY/MODIFY/DELETE/ENTRY/CHANGE/RESET/ALLRESET/ALLACTION/RESETDATA/INSERTONE/REALDELETE/REQENTRY)を設定しま???)
061     *       scope              【TAG】キャ?ュする場合?スコープ[request/page/session/applicaton]を指定しま?初期値:session)
062     *       repeatCount        【TAG】指定?回数?け?繰り返し処?行う回数を指定しま?初期値:1)
063     *       tableId            【TAG?通常使?せん)sessionから?す?DBTableModelオブジェクト? ID
064     *       useConsistency     【TAG】Consistency キー による整合?チェ?を行うかど?を指定しま?初期値:true)
065     *       selectedAll        【TAG】データを?件選択済みとして処?るかど?[true/false]を指定しま?初期値:false)
066     *       strictCheck        【TAG】カラ??の存在チェ?を行うかど?[true/false]を指定しま?初期値:true)
067     *       noTransition       【TAG?通常は使?せん)画面遷移を行わな?式?登録方法を使用するかを?しま?
068     *       debug              【TAG】デバッグ??を?力するかど?[true/false]を指定しま?初期値:false)
069     *   >   ... Body ...
070     *   </og:entry>
071     *
072     * ●使用?
073     *    <og:entry command="{@command}"  >
074     *        <og:columnSet command="{@command}" columnId="ECNO"   action="CLEAR" />
075     *        <og:columnSet command="{@command}" columnId="JYOKYO" action="SET" value="1" />
076     *    </og:entry>
077     *
078     *    <og:entry command="MODIFY" rows="1" >
079     *        <og:columnSet  command="MODIFY" columnId="key" action="TBLSET" value="[key][lang]"/>
080     *    </og:entry>
081     *
082     *    action="ADD" は、DBTypeに依存した方法で、既存?値を???します?
083     *    <og:entry command="{@command}" repeatCount="5" >
084     *        <og:columnSet  command="{@command}" columnId="YKNO" action="ADD" />
085     *    </og:entry>
086     *
087     *    action="ADD" は、DBTypeに依存した方法で、既存?値に、value の値を加算します?
088     *    <og:entry command="{@command}" repeatCount="5" >
089     *        <og:columnSet  command="{@command}" columnId="YKNO" action="ADD" value="5" />
090     *    </og:entry>
091     *
092     *    command属? は、columnSetタグのcommand属?と同??場合?み、??ます?
093     *    [command属?]
094     *      INSERT     新?
095     *      COPY       ??
096     *      MODIFY     変更
097     *      DELETE     削除
098     *      ENTRY      エントリー
099     *      CHANGE     チェンジ
100     *      RESET      リセ?
101     *      ALLRESET   全件リセ?
102     *      ALLACTION  オールアクション
103     *      RESETDATA  リセ???タ
104     *      INSERTONE  新?1行?み)
105     *      REALDELETE 物?除
106     *      REQENTRY   リクエスト変数設?
107     *
108     *    command属? は、columnSetタグで?します?
109     *    [action属?]
110     *      DEFAULT カラ?ソースで定義した初期値をセ?します?
111     *      CLEAR   値をクリア(ゼロストリング "" )します?
112     *      ADD     現在の値???します?  0 ?1 , A ?B , 9 ?10。value属?と併用すれば、指定?値を加算できます?
113     *      SET     value で設定した??新しい値として登録します?
114     *      NULLSET ??値?NULL の場合だけ?value で設定した新しい値を登録します?
115     *      LOWER   小文字に変換します?
116     *      UPPER   大?に変換します?
117     *      COPY    value にコピ???カラ?Dをセ?すれば、その値を代入します?
118     *      TBLSET  DBTableModel の?を取り込んで?? columnId カラ?設定します?[カラ?] で?できます?
119     *              また?これは??を解析して?value を作?します?で,??連結等に使用できます?
120     *      WRTCTRL writableControl を使用したカラ?ータの先?アン??バ?を削除します?
121     *      DBMENU  DBMENUでパラメータ設?コロン連結文?を使用したカラ?ータの先???タのみにします?
122     *      REQSET  valueで?したカラ??値をキーに、リクエスト変数から値を取出し?セ?します?
123     *      SEQSET  valueの初期値を利用して?レコードごとに?1した?をセ?します?
124     *      PREFIX  valueの値を後ろから検索し???カラ??の前半部?取得しま?記号は含みません)?
125     *      SUFIX   valueの値を後ろから検索し???カラ??の後半部?取得しま?記号は含みません)?
126     *      そ?? カラ??DBType の valueAction メソ?を呼び出します?自由に設定可能です?
127     *
128     *    [strictCheck属?]は、カラ??の存在チェ?を行うかど?を指定しま?初期値:true)
129     *      true    カラ??がDBTableModel に存在しな??合?、エラーになる?
130     *      false   カラ??がDBTableModel に存在しな??合?、無視する?
131     *
132     * @og.group 画面登録
133     *
134     * @version  4.0
135     * @author       Kazuhiko Hasegawa
136     * @since    JDK5.0,
137     */
138    public class EntryTag extends CommonTagSupport {
139            //* こ?プログラ??VERSION??を設定します?       {@value} */
140            private static final String VERSION = "5.6.6.1 (2013/07/12)" ;
141    
142            private static final long serialVersionUID = 566120130712L ;
143    
144            /** command 引数に渡す事?出来?コマン? 新?{@value} */
145            public static final String CMD_INSERT   = "INSERT" ;
146            /** command 引数に渡す事?出来?コマン? ?? {@value} */
147            public static final String CMD_COPY             = "COPY" ;
148            /** command 引数に渡す事?出来?コマン? 変更 {@value} */
149            public static final String CMD_MODIFY   = "MODIFY" ;
150            /** command 引数に渡す事?出来?コマン? 削除 {@value} */
151            public static final String CMD_DELETE   = "DELETE" ;
152            /** command 引数に渡す事?出来?コマン? エントリー {@value} */
153            public static final String CMD_ENTRY    = "ENTRY" ;
154            /** command 引数に渡す事?出来?コマン? チェンジ {@value} */
155            public static final String CMD_CHANGE   = "CHANGE" ;
156            /** command 引数に渡す事?出来?コマン? リセ? {@value} */
157            public static final String CMD_RESET    = "RESET" ;
158            /** command 引数に渡す事?出来?コマン? 全件リセ? {@value} */
159            public static final String CMD_ALLRESET         = "ALLRESET" ;  // 3.5.6.3 (2004/07/12)
160            /** command 引数に渡す事?出来?コマン? オールアクション{@value} */
161            public static final String CMD_ALLACTION        = "ALLACTION" ;
162            /** command 引数に渡す事?出来?コマン? リセ?(??タのみ){@value} */
163            public static final String CMD_RESETDATA        = "RESETDATA" ;         // 4.3.3.0 (2008/10/01)
164            /** command 引数に渡す事?出来?コマン? 追?1行?み){@value} */
165            public static final String CMD_INSERTONE        = "INSERTONE" ;         // 5.1.5.0 (2010/04/01)
166            /** command 引数に渡す事?出来?コマン? 物?除 {@value} */
167            public static final String CMD_REALDELETE       = "REALDELETE" ;                // 5.1.6.0 (2010/05/01)
168            /** command 引数に渡す事?出来?コマン? リクエスト変数設?{@value} */
169            public static final String CMD_REQENTRY         = "REQENTRY" ;                  // 5.6.1.2 (2013/02/22)
170    
171            // 3.5.6.3 (2004/07/12) CMD_ALLRESET    追?
172            // 4.3.3.0 (2008/10/01) CMD_RESETDATA   追?
173            // 5.1.5.0 (2010/04/01) CMD_INESRTONE   追?
174            // 5.1.6.0 (2010/05/01) CMD_REALDELETE  追?
175            private static final String[] COMMAND_LIST = new String[] {
176                    CMD_INSERT,CMD_COPY,CMD_MODIFY,CMD_DELETE,CMD_ENTRY,CMD_CHANGE,CMD_ALLACTION,CMD_RESET,CMD_ALLRESET,CMD_RESETDATA,CMD_INSERTONE,CMD_REALDELETE,CMD_REQENTRY };
177    
178            /** action 引数に渡す事?出来?アクションコマン? 初期値:{@value} */
179            public static final String ACT_DEFAULT  = "DEFAULT" ;
180            /** action 引数に渡す事?出来?アクションコマン? クリア {@value} */
181            public static final String ACT_CLEAR    = "CLEAR" ;
182            /** action 引数に渡す事?出来?アクションコマン? ??{@value} */
183            public static final String ACT_ADD      = "ADD" ;
184            /** action 引数に渡す事?出来?アクションコマン? 小文字化{@value} */
185            public static final String ACT_LOWER    = "LOWER" ;
186            /** action 引数に渡す事?出来?アクションコマン? 大?化{@value} */
187            public static final String ACT_UPPER    = "UPPER" ;
188            /** action 引数に渡す事?出来?アクションコマン? コピ? {@value} */
189            public static final String ACT_COPY     = "COPY" ;
190            /** action 引数に渡す事?出来?アクションコマン? セ? {@value} */
191            public static final String ACT_SET      = "SET" ;
192            // 3.4.0.3 (2003/09/10) NULLSET Action を追?ます?
193            /** action 引数に渡す事?出来?アクションコマン? NULLセ? {@value} */
194            public static final String ACT_NULLSET  = "NULLSET" ;
195            /** action 引数に渡す事?出来?アクションコマン? ??ブルセ? {@value} */
196            public static final String ACT_TBLSET   = "TBLSET" ;
197            /** action 引数に渡す事?出来?アクションコマン? ライトコントロール {@value} */
198            public static final String ACT_WRTCTRL  = "WRTCTRL" ;           // 3.8.1.5 (2006/03/30)
199            /** action 引数に渡す事?出来?アクションコマン? DBメニュー {@value} */
200            public static final String ACT_DBMENU  = "DBMENU" ;             // 3.8.5.3 (2006/08/07)
201            /** action 引数に渡す事?出来?アクションコマン? リクエスト?セ? {@value} */
202            public static final String ACT_REQSET  = "REQSET" ;             // 5.4.2.1 (2011/12/09)
203            /** action 引数に渡す事?出来?アクションコマン? 連番値セ? {@value} */
204            public static final String ACT_SEQSET  = "SEQSET" ;             // 5.6.5.2 (2013/06/21)
205            /** action 引数に渡す事?出来?アクションコマン? PREFIX値セ? {@value} */
206            public static final String ACT_PREFIX  = "PREFIX" ;             // 5.6.6.1 (2013/07/12)
207            /** action 引数に渡す事?出来?アクションコマン? SUFIX値セ? {@value} */
208            public static final String ACT_SUFIX   = "SUFIX" ;              // 5.6.6.1 (2013/07/12)
209    
210            // 3.5.6.0 (2004/06/18) すべて?protected から private に変更します?
211            private String                          tableId         = HybsSystem.TBL_MDL_KEY;
212            private transient DBTableModel  table   = null;
213            private String                          command         = null;
214            private int[]                           rowNo           = null;
215            private List<Attributes>  values          = null;
216    //      private transient Formatter     format          = null;
217    
218            // 3.5.4.2 (2003/12/15) ??回数繰り返す機?を追?ます?
219            private int                             repeatCount     = 1;
220    
221            // 3.5.5.7 (2004/05/10) Consistency キー による整合?チェ?を行うかど?を指定します?
222            private boolean                 useConsistency  = HybsSystem.sysBool( "USE_CONSISTENCY" );
223    
224            // 3.8.1.1 (2005/11/21) 全件選択されたこととして、??ます?
225            private boolean selectedAll = false;
226    
227            // 3.5.6.4 (2004/07/16) RESET コマンド??ォルト??に、ALLRESET ?
228            // 使用するかど?を指定しま?初期値:false(使用しな?)?
229            private final boolean RESET_ACTION_ALL_USE = HybsSystem.sysBool( "RESET_ACTION_ALL_USE" );
230    
231            // 4.0.0 (2006/09/31) カラ??の存在チェ?を行うかど?を指定します?
232            private boolean strictCheck = true;
233    
234            private boolean noTransition= false;    // 4.3.3.0 (2008/10/01) 追?
235    
236            // 5.6.5.2 (2013/06/21) SEQSET アクションのカウンター
237            private int seqsetCnt = 0;
238    
239            /**
240             * Taglibの開始タグが見つかったときに処??doStartTag() ?オーバ?ライドします?
241             *
242             * @og.rev 5.1.9.0 (2010/08/01) 戻り?を?EVAL_BODY_INCLUDE ?EVAL_BODY_BUFFERED に変更
243             *
244             * @return      後続????
245             */
246            @Override
247            public int doStartTag() {
248    //              int rtn = EVAL_BODY_INCLUDE;
249                    int rtn = EVAL_BODY_BUFFERED;           // 5.1.9.0 (2010/08/01) 変更
250    
251                    if( ! check( command, COMMAND_LIST ) ) {
252                            rtn = SKIP_BODY;
253                    }
254    
255                    return rtn;
256            }
257    
258            /**
259             * Taglibの終?グが見つかったときに処??doEndTag() ?オーバ?ライドします?
260             *
261             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応?release2() ?doEndTag()で呼ぶ?
262             * @og.rev 3.5.5.5 (2004/04/23) 登録時? 整合?パラメータチェ?を行います?
263             * @og.rev 3.5.5.6 (2004/04/27) JSP画面の作?不?合?ENTRY系で、command を投げた場合?、無視します?
264             * @og.rev 3.5.5.7 (2004/05/10) Consistency キー による整合?チェ?を行うかど?を指定します?
265             * @og.rev 3.5.5.8 (2004/05/20) Consistency キー による整合?チェ??checkConsistency() に??ます?
266             * @og.rev 3.6.0.8 (2004/11/19) DBTableModel をセーブする時に、トランザクションチェ?を行います?
267             * @og.rev 4.3.3.0 (2008/10/01) noTransition 属?を追?ます?
268             * @og.rev 4.3.8.0 (2009/08/01) noTransition値取得?メソ?名変更
269             * @og.rev 5.1.3.0 (2010/02/01) noTransitionのコントロールは、requestで行う?
270             *
271             * @return      後続????
272             */
273            @Override
274            public int doEndTag() {
275                    debugPrint();           // 4.0.0 (2005/02/28)
276                    // noTransition = isNoTransitionRequest() || noTransition; // 4.3.3.0 (2008/10/01) 追?
277    //              noTransition = isNoTransitionSession() || noTransition; // 4.3.8.0 (2009/08/01) メソ?名変更
278                    noTransition = isNoTransitionRequest(); // 5.1.3.0 (2010/02/01)
279                    startQueryTransaction( tableId );               // 3.6.0.8 (2004/11/19)
280                    table = (DBTableModel)getObject( tableId );
281    
282                    if( table != null && check( command, COMMAND_LIST ) ) {
283                            if( ! checkConsistency() ) { return(SKIP_PAGE); }
284                            if( rowNo == null ) { rowNo = getParameterRows(); }             // 4.0.0 (2005/01/31)
285    
286                            commandExec( command );
287    
288                            // 3.6.0.8 (2004/11/19) トランザクションチェ?を行います?
289                            if( ! commitTableObject( tableId, table ) ) {
290                                    jspPrint( "EntryTag Query処?割り込まれました?BTableModel は登録しません? );
291                                    return (SKIP_PAGE);
292                            }
293                    }
294    
295                    return(EVAL_PAGE);
296            }
297    
298            /**
299             * タグリブオブジェクトをリリースします?
300             *
301             * キャ?ュされて再利用される?で、フィールド?初期設定を行います?
302             *
303             * @og.rev 2.0.0.4 (2002/09/27) カスタ?グの release() メソ?を?追?
304             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応?release2() ?doEndTag()で呼ぶ?
305             * @og.rev 3.5.4.2 (2003/12/15) ??回数繰り返す機?を追?ます?
306             * @og.rev 3.5.5.7 (2004/05/10) Consistency キー による整合?チェ?を行うかど?を指定します?
307             * @og.rev 3.8.1.1 (2005/11/21) selectedAll 追??全件選択されたこととして、??ます?
308             * @og.rev 4.0.0.0 (2006/09/31) strictCheck 追??
309             * @og.rev 4.3.3.0 (2008/10/01) noTransition 属?を追?ます?
310             * @og.rev 5.6.5.2 (2013/06/21) seqsetCnt 属?を追?ます?
311             *
312             */
313            @Override
314            protected void release2() {
315                    super.release2();
316                    tableId         = HybsSystem.TBL_MDL_KEY;
317                    table           = null;
318                    command         = null;
319                    rowNo           = null;
320                    values          = null;
321    //              format          = null;
322                    repeatCount     = 1;                    // 3.5.4.2 (2003/12/15)
323                    useConsistency  = HybsSystem.sysBool( "USE_CONSISTENCY" );              // 3.5.5.7 (2004/05/10)
324                    selectedAll = false;            // 3.8.1.1 (2005/11/21)
325                    strictCheck = true;                     // 4.0.0 (2006/09/31)
326                    noTransition= false;            // 4.3.3.0 (2008/10/01) 追?
327                    seqsetCnt       = 0;                    // 5.6.5.2 (2013/06/21) SEQSET アクションのカウンター
328            }
329    
330            /**
331             * ?タグの ColumnSetTag より、???カラ??値を書き換える為の属?を指定します?
332             *
333             * ?の値を受け取って、後ほど、すべてのカラ?対して処?行います?
334             *
335             * @og.rev 3.1.0.0 (2003/03/20) Vector を使用して??で?同期でも構わな??を?ArrayList に置換え?
336             * @og.rev 3.1.2.0 (2003/04/07) taglib パッケージ?で使用して???protected 化する?
337             *
338             * @param   attri       属?リス?
339             */
340            protected void setAttributes( final Attributes attri ) {
341                    if( values == null ) { values = new ArrayList<Attributes>(); }
342                    if( command.equalsIgnoreCase( attri.get( "command" ) ) ) {
343                            values.add( attri );
344                    }
345            }
346    
347            /**
348             * 【TAG?通常は使?せん)結果のDBTableModelを?sessionに登録するとき?キーを指定しま?
349             *              (初期値:HybsSystem#TBL_MDL_KEY[={@og.value org.opengion.hayabusa.common.HybsSystem#TBL_MDL_KEY}])?
350             *
351             * @og.tag
352             * 検索結果より、DBTableModelオブジェクトを作?します?これを?下流?viewタグ等に
353             * 渡す?合に??常は、session を利用します?そ?場合?登録キーです?
354             * query タグを同時に実行して、結果を求める?合?同?モリに配置される為?
355             * こ? tableId 属?を利用して、メモリ空間を?ます?
356             *              (初期値:HybsSystem#TBL_MDL_KEY[={@og.value org.opengion.hayabusa.common.HybsSystem#TBL_MDL_KEY}])?
357             *
358             * @param       id sessionに登録する時? ID
359             */
360            public void setTableId( final String id ) {
361                    tableId   = nval( getRequestParameter( id ),tableId );  // 3.8.0.9 (2005/10/17)
362            }
363    
364            /**
365             * 【TAG】コマン?INSERT,COPY,MODIFY,DELETE,ENTRY,CHANGE,ALLACTION,RESET)をセ?します?
366             *
367             * @og.tag
368             * コマンド?,HTMLから(get/post)?されます?で,CMD_xxx で設定される
369             * フィールド定数値の?れかを??できます?
370             *
371             * @param       cmd コマン?public static final 宣?れて???)
372             * @see         <a href="{&#064;docRoot}/constant-values.html#org.opengion.hayabusa.taglib.EntryTag.CMD_INSERT">コマンド定数</a>
373             */
374            public void setCommand( final String cmd ) {
375                    String cmd2 = getRequestParameter( cmd );
376                    if( cmd2 != null && cmd2.length() > 0 ) { command = cmd2.toUpperCase(Locale.JAPAN); }
377            }
378    
379            /**
380             * コマンドを実行します?
381             *
382             * コマンド?,HTMLから(get/post)?されます?で,setCommand()メソ?で
383             * 登録します?
384             * コマンドを登録すると同時に,実行も行な?す?
385             *
386             * @og.rev 3.5.6.3 (2004/07/12) ALLRESET コマンドを追?る?
387             * @og.rev 4.3.3.0 (2008/10/01) RESETDATA コマンドを追?る?
388             * @og.rev 5.1.5.0 (2010/04/01) INSERTONE コマンドを追?る?
389             * @og.rev 5.1.6.0 (2010/05/01) REALDELETE コマンドを追?る?
390             * @og.rev 5.6.1.2 (2013/02/22) REQENTRY コマンドを追?る?
391             *
392             * @param   command コマン?public static final 宣?れて???)
393             */
394            private void commandExec( final String command ) {
395    
396                    table.setDefaultRowWritable( false );
397                    table.setDefaultRowChecked(  false );
398    
399                    if( CMD_INSERT.equals(      command ) ) { insert() ; }
400                    else if( CMD_COPY.equals(   command ) ) { copy()   ; }
401                    else if( CMD_MODIFY.equals( command ) ) { modify() ; }
402                    else if( CMD_CHANGE.equals( command ) ) { change() ; }
403                    else if( CMD_DELETE.equals( command ) ) { delete() ; }
404                    else if( CMD_ENTRY.equals(  command ) ) { entry()  ; }
405                    else if( CMD_RESET.equals(  command ) ) {
406                                    if( RESET_ACTION_ALL_USE )              { allReset() ; }        // 3.5.6.4 (2004/07/16)
407                                    else                                                    { reset()    ; }
408                    }
409                    else if( CMD_ALLRESET.equals(    command ) ) { allReset()  ; }  // 3.5.6.3 (2004/07/12)
410                    else if( CMD_ALLACTION.equals(   command ) ) { allAction() ; }
411                    else if( CMD_RESETDATA.equals(   command ) ) { resetData() ; }  // 4.3.3.0 (2008/10/01)
412                    else if( CMD_INSERTONE.equals(   command ) ) { insertOne() ; }  // 5.1.5.0 (2010/04/01)
413                    else if( CMD_REALDELETE.equals(  command ) ) { realDelete() ; } // 5.1.6.0 (2010/05/01)
414                    else if( CMD_REQENTRY.equals(    command ) ) { reqEntry()  ; }  // 5.6.1.2 (2013/02/22)
415            }
416    
417            /**
418             * DBTableModelに行を追?ます?
419             *
420             * 注意:writableカラ??暫定対応が入って?す?単純な空白??タ?
421             * インサートすると、カラ?ータ?null になる為? 制御がおかし?
422             * なります?
423             *
424             * @og.rev 3.5.4.2 (2003/12/15) repeatCount による繰り返し処?追?
425             * @og.rev 4.3.3.0 (2008/10/01) noTransition 属?対?
426             *
427             */
428            private void insert() {
429                    if( rowNo.length == 0 ) { rowNo = new int[] { -1 }; }
430    
431                    boolean rowWritableFlag = "WRITABLE".equalsIgnoreCase( table.getColumnName( 0 ) );      // writable 対?
432                    // src の作?は、各チェ?毎に行う??な????の??でよい?
433                    String[] src = new String[ table.getColumnCount() ];
434                    for( int j=0; j<src.length; j++ ) {
435                            DBColumn dbColumn = table.getDBColumn( j );
436                            src[j] = dbColumn.getDefault();
437                    }
438                    if( rowWritableFlag ) { src[0] = "true"; }      // writable 対?
439    
440                    int rowCount = table.getRowCount();
441    
442                    // ??にINSERTしな?、行番号がずれてしま??
443                    for( int i=rowNo.length-1; i>=0; i-- ) {
444                            int row = rowNo[i];
445                            for( int cnt=0; cnt<repeatCount; cnt++ ) {
446                                    if( cnt >= 1 ) {             // ?回目以?
447                                            src = table.getValues( row );
448                                    }
449    
450                                    String[] dst = new String[ table.getColumnCount() ];
451                                    System.arraycopy( src,0,dst,0,dst.length );
452                                    dst = setColumnValues( dst );
453    
454                                    // 4.3.3.0 (2008/10/01) noTransition属?対?
455                                    if( noTransition ) { row = rowCount; }
456                                    else { row ++; }                                        // ?行?下に追?る?
457                                    table.addValues( dst,row );
458                                    table.setRowWritable( row,true );
459                                    table.setRowChecked(  row,true );
460                            }
461                    }
462            }
463    
464            /**
465             * DBTableModelに行を追?、チェ?された行?値をセ?します?
466             *
467             * @og.rev 3.5.4.2 (2003/12/15) repeatCount による繰り返し処?追?
468             * @og.rev 4.3.3.0 (2008/10/01) noTransition 属?対?
469             *
470             */
471            private void copy() {
472                    if( rowNo.length == 0 ) { insert() ; return ;}
473    
474                    int rowCount = table.getRowCount();
475    
476                    // ??にCOPYしな?、行番号がずれてしま??
477                    for( int i=rowNo.length-1; i>=0; i-- ) {
478                            for( int cnt=0; cnt<repeatCount; cnt++ ) {
479                                    String[] src = table.getValues( rowNo[i]+cnt );
480                                    String[] dst = new String[ table.getColumnCount() ];
481                                    System.arraycopy( src,0,dst,0,dst.length );
482                                    dst = setColumnValues( dst );
483    
484                                    // 4.3.3.0 (2008/10/01) noTransition属?対?
485                                    int row = -1;
486                                    if( noTransition ) { row = rowCount; }
487                                    else { row = rowNo[i] + cnt + 1; }                      // ?行?下に追?る?
488    
489                                    table.addValues( dst,row );
490                                    table.setRowWritable( row,true );
491                                    table.setRowChecked(  row,true );
492                            }
493                    }
494            }
495    
496            /**
497             * DBTableModelの行を書込み可とます?
498             *
499             * @og.rev 4.3.4.6 (2009/01/15) 画面遷移なし登録で既に改廃Cがセ?されて?場合?、columnSetタグの処?行わな??
500             *
501             */
502            private void modify() {
503                    for( int i=0; i<rowNo.length; i++ ) {
504                            String[] src = table.getValues( rowNo[i] );
505                            String[] dst = new String[ table.getColumnCount() ];
506                            System.arraycopy( src,0,dst,0,dst.length );
507    
508                            // 4.3.4.6 (2009/01/15)
509                            // 画面遷移なし登録の場合?既に改廃Cが付いて?(編?れて?)場合??
510                            // columnSetによる値のセ?を行わな??
511                            // (同じコマンドで?のボタンを割り当てて?場合??回?変更・削除によって、?に登録され?
512                            // 値が削除されてしま?め?
513                            if( !( noTransition && table.getModifyType( rowNo[i] ) != null && table.getModifyType( rowNo[i] ).length() > 0 ) ){
514                                    dst = setColumnValues( dst );
515                            }
516    
517                            table.setValues( dst,rowNo[i] );
518                            table.setRowWritable( rowNo[i],true );
519                            table.setRowChecked(  rowNo[i],true );
520                    }
521            }
522    
523            /**
524             * DBTableModelの行を変更します?
525    
526             * @og.rev 4.3.4.6 (2009/01/15) 画面遷移なし登録で既に改廃Cがセ?されて?場合?、columnSetタグの処?行わな??
527             *
528             */
529            private void change() {
530                    for( int i=0; i<rowNo.length; i++ ) {
531                            String[] src = table.getValues( rowNo[i] );
532                            String[] dst = new String[ table.getColumnCount() ];
533                            System.arraycopy( src,0,dst,0,dst.length );
534    
535                            // 4.3.4.6 (2009/01/15)
536                            if( !( noTransition && table.getModifyType( rowNo[i] ) != null && table.getModifyType( rowNo[i] ).length() > 0 ) ){
537                                    dst = setColumnValues( dst );
538                            }
539    
540                            table.setValues( dst,rowNo[i] );
541                    }
542            }
543    
544            /**
545             * DBTableModelの行を削除します?
546             *
547             * @og.rev 3.5.4.2 (2003/12/15) DELETE時にも?の書き換えができるようにします?
548             * @og.rev 4.3.4.6 (2009/01/15) 画面遷移なし登録で既に改廃Cがセ?されて?場合?、columnSetタグの処?行わな??
549             *
550             */
551            private void delete() {
552                    for( int i=0; i<rowNo.length; i++ ) {
553                            // 3.5.4.2 (2003/12/15) 書き換え??追?
554                            String[] src = table.getValues( rowNo[i] );
555                            String[] dst = new String[ table.getColumnCount() ];
556                            System.arraycopy( src,0,dst,0,dst.length );
557    
558                            // 4.3.4.6 (2009/01/15)
559                            if( !( noTransition && table.getModifyType( rowNo[i] ) != null && table.getModifyType( rowNo[i] ).length() > 0 ) ){
560                                    dst = setColumnValues( dst );
561                            }
562    
563                            table.rowDelete( dst,rowNo[i] );
564                            table.setRowWritable( rowNo[i],true );
565                            table.setRowChecked( rowNo[i],true );
566                    }
567            }
568    
569            /**
570             * リクエスト情報から、セ?されたカラ?と値を取り?し?設定します?
571             *
572             * 設定?は、???キー??__" ??行番号 です?
573             * よって、?は,??設定されて?す?
574             *
575             * @og.rev 3.5.3.1 (2003/10/31) チェ?ボックスカラ??します?
576             * @og.rev 3.6.0.6 (2004/10/22) chboxNames 属?は?します?
577             * @og.rev 5.6.1.2 (2013/02/22) setRequestValuesメソ?の互換性の対応?
578             */
579            private void entry() {
580                    if( rowNo.length > 0 ) {
581    //                      setRequestValues();
582                            setRequestValues( false );              // 5.6.1.2 (2013/02/22) 互換性
583                            for( int i=0; i<rowNo.length; i++ ) {
584                                    String[] src = table.getValues( rowNo[i] );
585                                    String[] dst = new String[ table.getColumnCount() ];
586                                    System.arraycopy( src,0,dst,0,dst.length );
587                                    dst = setColumnValues( dst );
588    
589                                    table.setValues( dst,rowNo[i] );
590                                    table.setRowWritable( rowNo[i],true );
591                                    table.setRowChecked(  rowNo[i],true );
592                            }
593                    }
594            }
595    
596            /**
597             * リクエスト情報の??ブルモ???タを?リセ?します?
598             *
599             * @og.rev 5.6.5.2 (2013/06/21) 行ループを 0?最終行? 降?で廻します?
600             */
601            private void reset() {
602                    for( int i=rowNo.length-1; i>=0; i-- ) {
603    //              for( int i=0; i<rowNo.length; i++ ) {
604                            table.resetRow( rowNo[i] );
605                    }
606            }
607    
608            /**
609             * ??ブルモ???タを?全件リセ?します?
610             *
611             * @og.rev 3.5.6.3 (2004/07/12) 新規作?
612             * @og.rev 5.6.5.2 (2013/06/21) 行ループを 0?最終行? 降?で廻します?
613             */
614            private void allReset() {
615                    int rowCount = table.getRowCount();
616                    for( int row=0; row<rowCount; row++ ) {
617                            table.resetRow( row );
618                    }
619    
620    //              int rowMax = table.getRowCount()-1 ;
621    //              for( int i=rowMax; i>=0; i-- ) {
622    //                      table.resetRow( i );
623    //              }
624            }
625    
626            /**
627             * DBTableModelの全ての行に対して,値をセ?します?
628             *
629             * @og.rev 5.6.5.2 (2013/06/21) 行ループを 0?最終行? 降?で廻します?
630             */
631            private void allAction() {
632                    int rowCount = table.getRowCount();
633                    for( int row=0; row<rowCount; row++ ) {
634                            String[] src = table.getValues( row );
635                            String[] dst = new String[ table.getColumnCount() ];
636                            System.arraycopy( src,0,dst,0,dst.length );
637                            dst = setColumnValues( dst );
638    
639                            table.setValues( dst,row );
640                            table.setRowWritable( row,true );
641                            table.setRowChecked(  row,true );
642                    }
643    
644    //              int rowMax = table.getRowCount()-1 ;            // 3.5.6.3 (2004/07/12)
645    //              for( int i=rowMax; i>=0; i-- ) {
646    //                      String[] src = table.getValues( i );
647    //                      String[] dst = new String[ table.getColumnCount() ];
648    //                      System.arraycopy( src,0,dst,0,dst.length );
649    //                      dst = setColumnValues( dst );
650    //
651    //                      table.setValues( dst,i );
652    //                      table.setRowWritable( i,true );
653    //                      table.setRowChecked(  i,true );
654    //              }
655            }
656    
657            /**
658             * リクエスト情報の??ブルモ???タを?リセ?します?
659             * (?、リセ?された行?、チェ?された状態?ままになりま?
660             *
661             * @og.rev 4.3.3.0 (2008/10/01) 新規作?
662             * @og.rev 5.6.5.2 (2013/06/21) 行ループを 0?最終行? 降?で廻します?
663             */
664            private void resetData() {
665    //              for( int i=rowNo.length-1; i>=0; i-- ) {
666                    for( int i=0; i<rowNo.length; i++ ) {
667                            String cdkh = table.getModifyType( rowNo[i] );
668                            table.resetRow( rowNo[i] );
669                            // 更新又?、削除の時?み書き込み可能になる?
670                            if( DBTableModel.UPDATE_TYPE.equals( cdkh ) || DBTableModel.DELETE_TYPE.equals( cdkh ) ) {
671                                    table.setRowWritable( rowNo[i],true );
672                                    table.setRowChecked(  rowNo[i],true );
673                            }
674                    }
675            }
676    
677            /**
678             * DBTableModelに行を追?ます?(1行?み)
679             *
680             * 行が選択されて?かど?に関わらず?1行?みを追?ます?
681             * (動きとしては、行が選択されて??態でINSERTコマンドを発行した?合と同じで?
682             *
683             * @og.rev 5.1.5.0 (2010/04/01) 新規作?
684             *
685             */
686            private void insertOne() {
687                    rowNo = new int[0];
688                    insert();
689            }
690    
691            /**
692             * DBTableModelの行を物?除します?
693             *
694             * 通常の??タベ?ス等で削除する場合?、DELETE行も残しておかな?、どの行を削除する?
695             * 判らなくなります?また?アプリケーションによっては、削除ではなく?フラグ?を立て?
696             * ケースもあるため?現在の commend="DELETE" では、論理削除??の書き換えも可能になって?す?
697             * ここでの物?除は、WriteTable など、ファイル出力時には、その行そのも?をなくしておくほ?
698             * 良?ースがあるためです?
699             *
700             * @og.rev 5.1.6.0 (2010/05/01) REALDELETE コマンドを追?る?
701             */
702            private void realDelete() {
703                    // ??にしな?、行番号がずれてしま??
704                    for( int i=rowNo.length-1; i>=0; i-- ) {
705                            table.removeValue( rowNo[i] );
706                    }
707            }
708    
709            /**
710             * リクエスト情報から、セ?されたカラ?と値を取り?し?設定します?
711             *
712             * 設定?は、???キー??__" ??行番号 です?
713             * ENTRYコマンドとの違いは、h_rowSel と無関係に、リクエストされた変数すべて?
714             * 処?ます?
715             *
716             * @og.rev 5.6.1.2 (2013/02/22) 新規追?
717             */
718            private void reqEntry() {
719                    setRequestValues( true );       // リクエストされた変数すべてを??
720                    int rowCount = table.getRowCount();
721                    for( int row=0; row<rowCount; row++ ) {
722                            String[] src = table.getValues( row );
723                            String[] dst = new String[ table.getColumnCount() ];
724                            System.arraycopy( src,0,dst,0,dst.length );
725                            dst = setColumnValues( dst );
726    
727                            table.setValues( dst,row );
728                            table.setRowWritable( row,true );
729                            table.setRowChecked(  row,true );
730                    }
731            }
732    
733            /**
734             * リクエスト情報から、セ?されたカラ?と値を取り?し?設定します?
735             *
736             * 設定?は、???キー??__" ??行番号 です?
737             * よって、?は,??設定されて?す?
738             *
739             * @og.rev 3.1.0.0 (2003/03/20) 名前と行番号の区?記号?"^" から "__" に変更?
740             * @og.rev 3.5.5.0 (2004/03/12) 名前と行番号の区?記号("__")を?HybsSystem.JOINT_STRING  に変更?
741             * @og.rev 3.6.0.6 (2004/10/22) chboxNames 属?は?します?
742             * @og.rev 3.8.0.1 (2005/06/17) チェ?ボックス対応で、エラーチェ?をPL/SQLで行う場合?処??の追?
743             * @og.rev 3.8.0.2 (2005/07/11) チェ?ボックス対応で、判定を DBColumnのgetEditor()を使用しま?
744             * @og.rev 4.0.0.0 (2006/09/31) strictCheck 追??
745             * @og.rev 4.3.7.3 (2009/06/22) HSQLDB対応でリクエストが空??場合?null?に変換する
746             * @og.rev 5.0.0.2 (2009/09/15) XSS対?ALLはチェ?しな?
747             * @og.rev 5.6.1.2 (2013/02/22) isAllRow 引数追?
748             *
749             * @param isAllRows 選択行番号に関係なく?処?るかど?
750             */
751    //      private void setRequestValues() {
752            private void setRequestValues( final boolean isAllRows ) {
753                    Enumeration<?> enume = getParameterNames();               // 4.3.3.6 (2008/11/15) Generics警告対?
754    
755                    while( enume.hasMoreElements() ) {
756                            String key  = (String)(enume.nextElement());
757                            int    idx  = key.lastIndexOf(HybsSystem.JOINT_STRING);
758    
759                            if( idx > 0 ) {
760                                    String  column  = key.substring(0,idx);
761                                    int             clmNo   = table.getColumnNo( column,strictCheck );
762                                    if( clmNo < 0 ) { continue; }        // strictCheck 対?
763                                    DBColumn dbColumn = table.getDBColumn( clmNo );
764                                    int      row      = Integer.parseInt( key.substring(idx + 2) );
765                                    // 5.0.0.2 (2009/09/15) ?種別ALLはXSSチェ?しな?
766                                    // String   val      = dbColumn.valueSet( getRequestValue( key ) );
767                                    String   val = null;
768                                    if( "ALL".equals( dbColumn.getDbType() ) ){
769                                            val = dbColumn.valueSet( getRequestValue( key, false ) );
770                                    }
771                                    else{
772                                            val = dbColumn.valueSet( getRequestValue( key ) );
773                                    }
774    
775                                    // 3.6.0.6 (2004/10/22) チェ?ボックスはマルチで??タが来ます?
776                                    // 3.8.0.2 (2005/07/11) 判定を DBColumnのgetEditor()を使用
777                                    if( "0".equals(val) && "CHBOX".equals( dbColumn.getEditor() ) ) {
778                                            String[] vals = getRequestValues( key );
779                                            if( vals != null ) {
780                                                    for( int i=0; i<vals.length; i++ ) {
781                                                            if( "1".equals( vals[i] ) ) { val = "1"; break; }
782                                                    }
783                                            }
784                                    }
785    
786                                    // 5.6.1.2 (2013/02/22) リクエスト変数すべての??タを設?
787                                    if( isAllRows ) {
788                                            // 4.3.7.3 (2009/06/22) HSQLDB対?
789                                            if( val != null && val.length() == 0 ){
790                                                    val = null;
791                                            }
792                                            table.setValue(row, column, val );
793                                    }
794                                    // 従来のロジ?(チェ?を外してSUBMITするケースを想定して??
795                                    else {
796                                            // rowNo は、getParameterRows メソ?でソートされて?ので?
797                                            // java.util.Arrays#binarySearch(int[] a, int key) が使えるはず?
798                                            // 十?に?トして??め?今?変更しな??
799                                            for( int i=0; i<rowNo.length; i++ ) {
800                                                    if( rowNo[i] == row ) {
801                                                            // 4.3.7.3 (2009/06/22) HSQLDB対?
802                                                            if( val != null && val.length() == 0 ){
803                                                                    val = null;
804                                                            }
805                                                            table.setValue(row, column, val );
806                                                    }
807                                            }
808                                    }
809                            }
810                    }
811            }
812    
813            /**
814             * ColumnSetTag で?された条件を?に、その行?値を書き換えます?
815             *
816             * @og.rev 3.6.0.6 (2004/10/22) conditionKey と?conditionList 属?を追?
817             * @og.rev 3.8.1.5 (2006/03/30) writableControl を使用したカラ?ータの先?アン??バ?を削除します?
818             * @og.rev 4.0.0.0 (2006/09/31) strictCheck 追??
819             * @og.rev 4.3.7.3 (2009/06/22) HSQLDB対応で空??NULL
820             * @og.rev 5.6.5.2 (2013/06/21) valueの初期値を利用して?レコードごとに?1した?をセ?します?
821             *
822             * @param       val ?行データ配?
823             *
824             * @return      変更後??行データ配?
825             */
826            private String[] setColumnValues( final String[] val ) {
827                    if( values != null ) {
828                            int size = values.size();
829                            for( int i=0; i<size; i++ ) {
830                                    Attributes attri = values.get( i );
831                                    String columnId = attri.get( "columnId" );
832                                    int clmNo = table.getColumnNo( columnId,strictCheck );
833                                    if( clmNo < 0 ) { continue; }        // strictCheck 対?
834                                    String action = attri.get( "action" );
835                                    String newVal = attri.get( "value"  );
836                                    String oldVal = val[clmNo];
837    
838                                    // 3.6.0.6 (2004/10/22) 条件による処??実行可否判?
839                                    String conditionList = attri.get( "conditionList" );
840                                    if( conditionList != null ) {   // null の場合?、無条件実?
841                                            String conditionKey = attri.get( "conditionKey" );
842                                            int condClmNo = table.getColumnNo( conditionKey );
843                                            String condValue = "|" + val[condClmNo] + "|";
844                                            if( conditionList.indexOf( condValue ) < 0 ) {
845                                                    continue;
846                                            }
847                                    }
848    
849                                    if( ACT_COPY.equals( action ) ) {
850                                            int copyClmNo = table.getColumnNo( newVal );    // newVal はコピ??ラ?
851                                            val[clmNo] = val[copyClmNo];
852                                    }
853                                    else if( ACT_TBLSET.equals( action ) ) {
854    //                                      if( format == null ) {
855    //                                              format = new Formatter( model );
856    //                                      }
857                                            ArrayDataModel model = new ArrayDataModel( table.getNames() );
858                                            model.setValues( val,0 );
859                                            Formatter format = new Formatter( model );
860                                            format.setFormat( newVal );             // newValue はフォーマットされた??
861                                            val[clmNo] = format.getFormatString( 0 );
862                                    }
863                                    // 3.8.1.5 (2006/03/30) writableControl を使用したカラ?ータの先?アン??バ?を削除します?
864                                    else if( ACT_WRTCTRL.equals( action ) ) {
865                                            if( oldVal != null && oldVal.length() > 0 && oldVal.charAt(0) == '_' ) {
866                                                    val[clmNo] = oldVal.substring( 1 );
867                                            }
868                                    }
869                                    // 3.8.5.3 (2006/08/07) DBMENUでパラメータ設?コロン連結文?を使用したカラ?ータの先???タのみにします?
870                                    else if( ACT_DBMENU.equals( action ) ) {
871                                            if( oldVal != null && oldVal.length() > 0 ) {
872                                                    int adrs = oldVal.indexOf( ':' );
873                                                    if( adrs >= 0 ) {
874                                                            val[clmNo] = oldVal.substring( 0,adrs );
875                                                    }
876                                            }
877                                    }
878                                    // 5.4.2.1 (2011/12/09) valueで?したカラ??値をキーに、リクエスト変数から値を取出し?セ?します?
879                                    else if( ACT_REQSET.equals( action ) ) {
880                                            if( newVal != null && newVal.length() > 0 ) {
881                                                    int reqClmNo = table.getColumnNo( newVal );     // newVal はリクエスト取得?カラ?
882                                                    String reqClm = val[reqClmNo];                          // こ?時点では、コロン引数が付いて?可能性がある?
883    
884                                                    int adrs = reqClm.indexOf( ':' );                       // 先?がカラ?
885                                                    if( adrs >= 0 ) {
886                                                            reqClm = reqClm.substring( 0,adrs );    // コロンより前方の?け取り?す?
887                                                    }
888                                                    val[clmNo] = getRequestValue( reqClm );
889                                            }
890                                    }
891                                    // 5.6.5.2 (2013/06/21) valueの初期値を利用して?レコードごとに?1した?をセ?します?
892                                    else if( ACT_SEQSET.equals( action ) ) {
893                                            int intVal = seqsetCnt ;
894                                            if( newVal != null && newVal.length() > 0 ) {
895                                                    intVal += Integer.parseInt( newVal );           // value の設定?
896                                            }
897                                            val[clmNo] = String.valueOf( intVal );
898                                    }
899                                    else {
900                                            val[clmNo] = actionExec( action,columnId,oldVal,newVal );
901                                    }
902    
903                                    // 4.3.7.3 (2009/06/22) HSQLDB対?
904                                    if( val[clmNo] != null && val[clmNo].length() == 0){
905                                            val[clmNo] = null;
906                                    }
907                            }
908                    }
909                    seqsetCnt ++ ;          // // 5.6.5.2 (2013/06/21) SEQSET のカウンター?
910    
911                    return val;
912            }
913    
914            /**
915             * アクションを実行します?
916             *
917             * アクションは,??アクションコマンドに対応する??入力データに
918             * 対して行います?
919             *
920             * @og.rev 3.4.0.3 (2003/09/10) NULLSET Action を追?ます?
921             * @og.rev 5.6.0.3 (2012/01/24) ADD Action に、value引数の値を加算する機?を追?ます?
922             * @og.rev 5.6.6.1 (2013/07/12) action に、PREFIX,SUFIX を追?ます?
923             *
924             * @param   action アクションコマン?
925             * @param   clmId カラ??
926             * @param   oldValue 入力データ(旧??タ)
927             * @param   newValue 入力データ(新??タ)
928             *
929             * @return      実行後???タ
930             * @see         <a href="{&#064;docRoot}/constant-values.html#org.opengion.hayabusa.taglib.EntryTag.ACT_DEFAULT">アクション定数</a>
931             */
932            private String actionExec( final String action,final String clmId,
933                                                                    final String oldValue,final String newValue ) {
934                    String rtnVal = oldValue;
935    
936                    DBColumn dbColumn = getDBColumn( clmId );
937                    if( ACT_DEFAULT.equals(    action ) ) { rtnVal = dbColumn.getDefault(); }
938                    else if( ACT_CLEAR.equals( action ) ) { rtnVal = ""; }
939                    else if( ACT_SET.equals(   action ) ) { rtnVal = dbColumn.valueSet( newValue ); }
940    //              else if( ACT_ADD.equals(   action ) ) { rtnVal = dbColumn.valueAdd( oldValue ); }
941                    else if( ACT_ADD.equals(   action ) ) { rtnVal = dbColumn.valueAdd( oldValue,newValue ); }      // 5.6.0.3 (2012/01/24)
942                    else if( ACT_LOWER.equals( action ) ) {
943                            if( oldValue == null ) { rtnVal = dbColumn.getDefault();  }
944                            else                   { rtnVal = oldValue.toLowerCase(Locale.JAPAN); }
945                    }
946                    else if( ACT_UPPER.equals( action ) ) {
947                            if( oldValue == null ) { rtnVal = dbColumn.getDefault();  }
948                            else                   { rtnVal = oldValue.toUpperCase(Locale.JAPAN); }
949                    }
950                    // 3.4.0.3 (2003/09/10) NULLSET Action を追?ます?
951                    else if( ACT_NULLSET.equals( action ) ) {
952                            if( oldValue == null || oldValue.length() == 0 ) {
953                                    rtnVal = dbColumn.valueSet( newValue );
954                            }
955                    }
956                    // 5.6.6.1 (2013/07/12) PREFIX Action を追?ます?
957                    else if( ACT_PREFIX.equals( action ) ) {
958                            if( oldValue != null && oldValue.length() > 0 && newValue != null && newValue.length() > 0 ) {
959                                    int indx = oldValue.lastIndexOf( newValue );
960                                    if( indx >= 0 ) {
961                                            rtnVal = oldValue.substring( 0,indx );
962                                    }
963                            }
964                    }
965                    // 5.6.6.1 (2013/07/12) SUFIX Action を追?ます?
966                    else if( ACT_SUFIX.equals( action ) ) {
967                            if( oldValue != null && oldValue.length() > 0 && newValue != null && newValue.length() > 0 ) {
968                                    int indx = oldValue.lastIndexOf( newValue );
969                                    if( indx >= 0 ) {
970                                            rtnVal = oldValue.substring( indx+1 );          // ?記号は含まな??で?1する?
971                                    }
972                            }
973                    }
974                    else {
975                            rtnVal = dbColumn.valueAction( action,oldValue,newValue );
976                    }
977    
978                    if( rtnVal == null ) { rtnVal = dbColumn.getDefault(); }
979    
980                    return rtnVal;
981            }
982    
983            /**
984             * 【TAG】指定?回数?け?繰り返し処?行う回数を指定しま?初期値:1)?
985             *
986             * @og.tag
987             * 追???時に、指定?回数?け?処?繰り返して、新規に行を
988             * 作?します?
989             * 繰り返しは、指定?行に対して行われ?繰り返し毎に、直前に作?され?
990             * 行を?処?ます?これは、例えば、columnSet で、action="ADD"の場合に?
991             * 繰り返す毎に、ADD処?実行されることを意味します?
992             * 行が?されて???合?、?頭空行に追?ます?
993             * 初期値は?回です?
994             *
995             * @og.rev 3.5.4.2 (2003/12/15) 新規追?
996             *
997             * @param       rc      繰り返し処?行う回数を指?初期値:1)
998             */
999            public void setRepeatCount( final String rc ) {
1000                    repeatCount = nval( getRequestParameter( rc ),repeatCount );
1001            }
1002    
1003            /**
1004             * 【TAG】Consistency キー による整合?チェ?を行うかど?を指定しま?初期値:true)?
1005             *
1006             * @og.tag
1007             * 検索結果?DBTableModel にセ?する時に、整合?キーの Consistency キー?
1008             * 作?します?これを?Viewタグでhidden出力しておき、Entryタグで??タ書き換え時に
1009             * 整合?チェ?を行います?これは、IEの戻る?タンで戻った?合に、画面の
1010             * キーと検索結果の DBTableModel の?が??しな??合?エラーチェ?に
1011             * なります?
1012             * こ?属?は、何らか?ケースで、このエラーチェ?を行いたくな??合に?
1013             * false に設定することで、整合?チェ?を行いません?
1014             * 初期値は、true(整合?チェ?を行う)です?
1015             *
1016             * @og.rev 3.5.5.7 (2004/05/10) 新規登録
1017             *
1018             * @param       ck      Consistency Key の使用するかど?(初期値:true)
1019             */
1020            public void setUseConsistency( final String ck ) {
1021                    useConsistency = nval( getRequestParameter( ck ),useConsistency );
1022            }
1023    
1024            /**
1025             * DBTableModel の 整合?パラメータとリクエスト情報を比?ェ?します?
1026             * リクエスト情報は、その DBTableModel が?力された view で hidden 属?で
1027             * 設定されます?
1028             * 設定されるキーは、tableId が変更されて?ければ、HybsSystem.CONSISTENCY_KEY です?
1029             * 変更されて?ば、HybsSystem.CONSISTENCY_KEY + tableId です?
1030             *
1031             * @og.rev 3.5.5.8 (2004/05/20) Consistency キー による整合?チェ??checkConsistency() に??ます?
1032             *
1033             * @return チェ?結果  true:正常/false:異常
1034             * @see org.opengion.hayabusa.common.HybsSystem#CONSISTENCY_KEY
1035             */
1036            private boolean checkConsistency() {
1037                    boolean rtn = true;
1038                    String key = HybsSystem.CONSISTENCY_KEY ;
1039    
1040                    String consisKey = getRequestValue( key );
1041                    if( consisKey != null && consisKey.length() > 0 ) {
1042                            if( useConsistency && ! consisKey.equals( table.getConsistencyKey() ) ) {
1043    
1044                                    ErrorMessage errMsgObj = new ErrorMessage( "Consistency Key Check Error!" );
1045                                    errMsgObj.addMessage( 0,ErrorMessage.NG,"ERR0033.1" );
1046                                    errMsgObj.addMessage( 0,ErrorMessage.NG,"ERR0033.2" );
1047                                    errMsgObj.addMessage( 0,ErrorMessage.NG,"ERR0033.3" );
1048                                    jspPrint( TaglibUtil.makeHTMLErrorTable( errMsgObj,getResource() ) );
1049                                    rtn = false;
1050                            }
1051                    }
1052                    else {
1053                            System.out.println( "EntryTag:Consistency Key is null" );
1054                    }
1055                    return rtn ;
1056            }
1057    
1058            /**
1059             * 表示??タの HybsSystem.ROW_SEL_KEY を?に?ばれた 行を処??対象とします?
1060             *
1061             * <del>rowNo[] ?null の場合?み、取込を行います?</del>
1062             *
1063             * @og.rev 3.8.1.1 (2005/11/21) selectedAll 追??全件選択されたこととして、??ます?
1064             * @og.rev 4.0.0.0 (2005/01/31) getParameterRows() を使用するように変更
1065             *
1066             * @return      選択行?配?
1067             */
1068            @Override
1069            protected int[] getParameterRows() {
1070                    final int[] rowNo ;
1071                    if( selectedAll ) {
1072                            int rowCnt = table.getRowCount();               // 3.5.5.7 (2004/05/10)
1073                            rowNo = new int[ rowCnt ];
1074                            for( int i=0; i<rowCnt; i++ ) {
1075                                    rowNo[i] = i;
1076                            }
1077                    } else {
1078                            rowNo = super.getParameterRows();               // 4.0.0 (2005/01/31)
1079                    }
1080                    return rowNo ;
1081            }
1082    
1083            /**
1084             * 【TAG】データを?件選択済みとして処?るかど?[true/false]を指定しま?初期値:false)?
1085             *
1086             * @og.tag
1087             * 全ての??タを選択済み??タとして扱って処?ます?
1088             * 全件処?る?合に?true/false)を指定します?
1089             * 初期値は false です?
1090             *
1091             * @param  all ??タを?件選択済み [true:全件選択済み/false:通常]
1092             */
1093            public void setSelectedAll( final String all ) {
1094                    selectedAll = nval( getRequestParameter( all ),selectedAll );
1095            }
1096    
1097            /**
1098             * 【TAG】カラ??の存在チェ?を行うかど?[true/false]を指定しま?初期値:true)?
1099             *
1100             * @og.tag
1101             * true の場合?カラ??がDBTableModel に存在しな??合?、エラーになります?
1102             * false の場合?カラ??がDBTableModel に存在しな??合?、無視します?
1103             * これは、検索条件によって、設定されるカラ?異なる?合でも?entryタグ?
1104             * 正常に動作させた??合に、使用します?
1105             * 初期値は true (チェ?を行う) です?
1106             *
1107             * @param  check 存在チェ?を行うかど? [true:行う/false:行わない]
1108             */
1109            public void setStrictCheck( final String check ) {
1110                    strictCheck = nval( getRequestParameter( check ),strictCheck );
1111            }
1112    
1113            /**
1114             * 【TAG?通常は使?せん)画面遷移を行わな?式?登録方法を使用するかを?します?
1115             *
1116             * @og.tag
1117             * 画面遷移なし?登録を行うかど?を指定します?
1118             * trueが指定された場合?entryタグでは、行?追????時にDBTableModel上??行に??タ?
1119             * 追?ます?
1120             * 画面遷移なしモード?場合?途中行に挿入された?合?既にクライアントに出力されて?
1121             * チェ?ボックスの行番号?入力フィールド?変数名との整合?を合わせるためには?
1122             * 編?以降??数値を?て再計算する?があります?
1123             * こ?処??、レスポンス悪化に繋がるため?DBTableModel上?、中間に行?挿入を行いません?
1124             * ?画面表示上???常通り選択行?直下に行が挿入されるため?DBTableModelの?と標準??
1125             * 異なります?(エンジン側では、各チェ?ボックスの値で行を識別して?ため、問題?発生しません)
1126             *
1127             * こ?値は、og:headタグで設定?、また?前画面からの値を継承するため??常、この属?ではセ?しません?
1128             *
1129             * @og.rev 4.3.3.0 (2008/10/01) 新規追?
1130             * @og.rev 5.1.3.0 (2010/02/01) noTransition、ajaxSubmitのコントロールは、requestで行う?
1131             *
1132             * @param   noTrnstn 画面遷移を行わな?式?登録方法を使用する?
1133             */
1134            public void setNoTransition( final String noTrnstn ) {
1135                    setNoTransitionRequest( nval( getRequestParameter( noTrnstn ), isNoTransitionRequest() ) );
1136    //              noTransition = nval( getRequestParameter( noTrnstn ), noTransition );
1137            }
1138    
1139            /**
1140             * シリアライズ用のカスタ?リアライズ書き込みメソ?
1141             *
1142             * @og.rev 4.0.0.0 (2006/09/31) 新規追?
1143             * @serialData
1144             *
1145             * @param       strm    ObjectOutputStreamオブジェク?
1146             */
1147            private void writeObject( final ObjectOutputStream strm ) throws IOException {
1148                    strm.defaultWriteObject();
1149            }
1150    
1151            /**
1152             * シリアライズ用のカスタ?リアライズ読み込みメソ?
1153             *
1154             * ここでは、transient 宣?れた?変数の??初期化が?なフィールド?み設定します?
1155             *
1156             * @og.rev 4.0.0.0 (2006/09/31) 新規追?
1157             * @serialData
1158             *
1159             * @param       strm    ObjectInputStreamオブジェク?
1160             * @see #release2()
1161             */
1162            private void readObject( final ObjectInputStream strm ) throws IOException , ClassNotFoundException {
1163                    strm.defaultReadObject();
1164            }
1165    
1166            /**
1167             * こ?オブジェクト???表現を返します?
1168             * 基本???目?使用します?
1169             *
1170             * @return こ?クラスの??表現
1171             */
1172            @Override
1173            public String toString() {
1174                    return org.opengion.fukurou.util.ToString.title( this.getClass().getName() )
1175                                    .println( "VERSION"                                     ,VERSION                                )
1176                                    .println( "tableId"                                     ,tableId                                )
1177                                    .println( "command"                                     ,command                                )
1178                                    .println( "rowNo"                               ,rowNo                          )
1179                                    .println( "repeatCount"                         ,repeatCount                    )
1180                                    .println( "useConsistency"                      ,useConsistency                 )
1181                                    .println( "selectedAll"                         ,selectedAll                    )
1182                                    .println( "strictCheck"                         ,strictCheck                    )
1183                                    .println( "noTransition"                        ,noTransition                   )
1184                                    .println( "RESET_ACTION_ALL_USE"        ,RESET_ACTION_ALL_USE   )
1185                                    .println( "Other..."                            ,getAttributes().getAttribute() )
1186                                    .fixForm().toString() ;
1187            }
1188    }