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.plugin.column;
017    
018    import java.util.Calendar;
019    
020    import org.opengion.fukurou.util.ErrorMessage;
021    import org.opengion.fukurou.util.StringUtil;
022    import org.opengion.hayabusa.db.AbstractDBType;
023    import org.opengion.hayabusa.db.DBTypeCheckUtil;
024    import org.opengion.fukurou.util.HybsDateUtil;
025    
026    /**
027     * æ–?­—å?ã®æ™‚間属æ?(æ™?åˆ?ç§?ã®åŠè§’ã?時間を扱ã?‚ºã®ã€ã‚«ãƒ©ãƒ?±žæ?を定義ã—ã¾ã™ã?
028     *
029     * HHmmss ã«å¯¾å¿œã—ã¦ã?‚‹å¿?¦ãŒã‚りã¾ã™ã?
030     * (HHmmã®ãƒ??ã‚¿ã§ã‚‚利用å¯èƒ½ã§ã?
031     * ãŸã ã—ã?日付ã?æ•´åˆæ?ãƒã‚§ãƒ?‚¯ã¯è¡Œã„ã¾ã›ã‚“ãŒã?valueAdd( String value )ã§ã®
032     * 日付ã?åŠ?®—時ã«ã¯ã€æ­£å¼ãªæ—¥ä»˜ãƒ‡ãƒ¼ã‚¿ã«ã¦åŠ?®—ã—ã¾ã™ã?
033     *
034     * タイプãƒã‚§ãƒ?‚¯ã¨ã—ã¦ã€ä»¥ä¸‹ã?æ¡ä»¶ã‚’判定ã—ã¾ã™ã?
035     * ・æ–?­—å?é•·ã¯ã€ç›´æŽ¥è¨ˆç®—ã§æ–?­—æ•°ã¨ã®æ¯”è¼?
036     * ・日付使用æ–?­—ãƒã‚§ãƒ?‚¯ã€?'0' > c || '9' < c)以外ã?エラー
037     * ・æ–?­—パラメータ㮠正è¦è¡¨ç¾ãƒã‚§ãƒ?‚¯
038     *
039     * @og.group ãƒ??タ属æ?
040     * @og.rev 5.4.3.6 (2012/01/20)  タイプãƒã‚§ãƒ?‚¯ãŒæŠœã‘ã¦ã?‚‹ã®ã§è¿½åŠ?
041     *
042     * @version  4.0
043     * @author   Kazuhiko Hasegawa
044     * @since    JDK5.0,
045     */
046    public class DBType_HMS extends AbstractDBType {
047            //* ã“ã?プログラãƒ??VERSIONæ–?­—å?を設定ã—ã¾ã™ã?       {@value} */
048            private static final String VERSION = "5.6.1.0 (2013/02/01)" ;
049    
050            /**
051             * Stringå¼•æ•°ã®æ–?­—å?を+1ã—ãŸæ–‡å­—å?ã‚’è¿”ã—ã¾ã™ã?
052             * ã“れã¯ã€è‹±å­—ã?å ´å?A,B,C ãªã©)ã¯ã€B,C,D ã®ã‚ˆã†ã«,æœ?µ‚æ¡ã?æ–?­—コードを
053             * ?‹ï¼?ã—ã¾ã™ã?
054             * æ–?­—å?ãŒæ•°å­—タイプã?å ´åˆã?, æ•°å­—ã«å¤‰æ›ã—ã¦ã€?1 ã—ã¾ã™ã?(æ¡ä¸ŠãŒã‚Šã‚‚ã‚り)
055             * 混在タイプã?å ´åˆã?,æœ?¾Œã?æ¡ã ã‘を確èªã—㦠?‹ï¼‘ã—ã¾ã™ã?
056             * 引数ã?null ã®å ´åˆã¨ã€ã‚¼ãƒ­æ–?­—å?("")ã®å ´åˆã?,物ç?š„åˆæœŸè¨­å®šå?(String getDefault())
057             * ã®å€¤ã‚’è¿”ã—ã¾ã™ã?
058             * 
059             * @og.rev 5.8.6.1 (2015/04/17)
060             *
061             * @param       value   Stringå¼•æ•°ã®æ–?­—å?
062             *
063             * @return  Stringå¼•æ•°ã®æ–?­—å?を+1ã—ãŸæ–‡å­—å?
064             */
065            @Override
066            public String valueAdd( final String value ) {
067                    if( value == null || value.length() == 0 ) { return getDefault(); }
068    
069    //              int hour = Integer.parseInt( value.substring( 0,2 ) );
070    //
071    //              // å…ˆé?ã« 00 を付加ã™ã‚‹ç‚ºã«ã€æ•°å­—ã? 100 を加算ã—ã¦ã?‚‹ã€?
072    //              if( hour < 24 ) { hour = 101 + hour; }
073    //              else                    { hour = 100; }
074    //
075    //              String rtn = hour + value.substring( 2 );
076    //
077    //              return rtn.substring( 1 );
078                    
079                    // 5.8.6.1 (2015/04/10) ?”æ¡ã‚ˆã‚Šå°ã•ã?¨HHmmã€ãれ以外ã?ã€HHmmss
080                    final boolean isHM = value.length() <= 4 ;
081    
082                    //                        HHmm    HHmmss
083                    final int hms = ( isHM ? 10100 : 1010000 ) + Integer.parseInt( value );
084    
085                    // å…??å½¢å¼ã«æº–æ‹ ã—ã¦è¿”ã™ã€?
086                    return String.valueOf( hms ).substring( 1 );
087            }
088    
089            /**
090             * Stringå¼•æ•°ã®æ–?­—å?ã«ã€ç¬¬?’å¼•æ•°ã«æŒ?®šã?æ–?­—å?(æ•°å­—ã?日付ç­?を加算ã—ã¦è¿”ã—ã¾ã™ã?
091             *
092             * ã“ã“ã§ã¯ã€HHmmss å½¢å¼ã?ãƒ??ã‚¿ã«ã€æ™‚é–“ã‚’åŠ?®—ã—ã¾ã™ã?
093             *
094             * ã“ã? HMS ã¯ã€å¼•æ•°ã«ã€æ—¥ä»˜å˜ä½ã‚’æŒ?®šã§ãã¾ã™ã?å˜ä½ã?ã€HHmmss å½¢å¼ã?
095             * ?‘文字をæŒ?®šã—ã¾ã™ã?大æ–?­—ã?å°æ–‡å­—も識別ã—ã¾ã™ã?value="5H" ã¨ã™ã‚Œã°ã€?¼•時間ã?value="5m"
096             * ã¨ã™ã‚Œã°ã€?¼•å? 追åŠ?—ã¾ã™ã?
097             * æŒ?®šã—ãªã??åˆã?ã€æ™‚を加算ã—ã¾ã™ã?
098             *
099             * ã“ã“ã®ãƒ??ã‚¿ã¯ã€æ™‚é–“ãŒç¹°ã‚Šè¶Šã—ã¦ã‚‚ã?日付ã«å½±éŸ¿ã—ã¾ã›ã‚“ã€?
100             * ã¾ãŸã??’4時間をè¶?ˆãŸå?åˆã?ã€?0 æ™‚ã«æˆ»ã‚Šã¾ã™ã?
101             *
102             * @og.rev 5.6.0.3 (2012/01/24) ADD ã«ã€å¼•æ•°ã®å€¤ã‚’加算ã™ã‚‹æ©Ÿè?を追åŠ?—ã¾ã™ã?
103             * @og.rev 5.6.1.0 (2013/02/01) åŠ?®—ã™ã‚‹å¼•æ•°ã«ã€æ—¥ä»˜å˜ä½?'H','m','s')を指定å¯èƒ½ã«ã—ã¾ã™ã?
104             * @og.rev 5.8.6.1 (2015/04/17) æ¡æ•°å¯å¤‰å¯¾å¿?
105             *
106             * @param   value  String引数
107             * @param   add    åŠ?®—ã™ã‚‹æ™‚間文字å?(å˜ä½ä»˜ã:['H','m','s'])
108             *
109             * @return  å¼•æ•°ã®æ–?­—å?ã«æ™‚間を加算ã—ã¾ã™ã?
110             */
111            @Override
112            public String valueAdd( final String value,final String add ) {
113                    if( value == null || value.length() == 0 ) { return getDefault(); }
114    
115                    // 日付文字å?ã«ãƒ?ƒŸãƒ¼ã®å¹´æœˆæ—¥ã‚’追åŠ?—ã¦ãŠãã€?
116    //              return HybsDateUtil.getDatePlus( ("20100101" + value),add,Calendar.HOUR_OF_DAY,"HHmmss" );
117    
118    //              int addSu = 1;
119    //              if( add != null && !add.isEmpty() ) {
120    //                      addSu = Integer.parseInt( add );
121    //              }
122    
123    //              int hour = Integer.parseInt( value.substring( 0,2 ) ) + addSu;
124    
125                    // å…ˆé?ã« 00 を付加ã™ã‚‹ç‚ºã«ã€æ•°å­—ã? 100 を加算ã—ã¦ã?‚‹ã€‚ã¾ãŸã?24時間をè¶?ˆã‚‹å?åˆã?ã€?0 ã«æˆ»ã‚‹ã?
126    //              String rtn = ( 100 + ( hour % 24 ) ) + value.substring( 2 );            // 後ã‚ã¯ã€MMSSã®åˆ?
127                    //           ~~~~~~~~~~~~~~~~~~~~~~~   ~~~~~~~~~~~~~~~~~~~~
128                    //           数字部åˆ?                 MMSSã®æ–?­—å?部åˆ?
129    
130                    // å…ˆé?æ–?­—å?を削除ã™ã‚‹ã€?
131    //              return rtn.substring( 1 );
132                    
133                    // 5.8.6.1 (2015/04/10) ?”æ¡ã‚ˆã‚Šå°ã•ã?¨HHmmã€ãれ以外ã?ã€HHmmss
134                    final boolean isHM = value.length() <= 4 ;
135    
136                    // ※ yyyymmd + 1HHmmss ã§ã€æ—¥ä»˜ãƒ‡ãƒ¼ã‚¿ã®ãƒ?ƒŸãƒ¼ã®å¹´æœˆæ—¥ã‚’追åŠ?
137                    final int hms = 1000000 + Integer.parseInt( isHM ? value + "00" : value );
138    
139                    // å…??å½¢å¼ã«æº–æ‹ ã—ã¦è¿”ã™ã€?
140                    return HybsDateUtil.getDatePlus( ( "2010010" + hms ),add,Calendar.HOUR_OF_DAY, isHM ? "HHmm" : "HHmmss" );
141            }
142    
143            /**
144             * エãƒ?‚£ã‚¿ãƒ¼ã§ç·¨é›?•れãŸãƒ??タを登録ã™ã‚‹å ´åˆã«ã€ãƒ‡ãƒ¼ã‚¿ãã?ã‚‚ã?ã‚?
145             * 変æ›ã—ã¦ã€å®Ÿç™»éŒ²ãƒ??タを作æ?ã—ã¾ã™ã?
146             * 例ãˆã°,大æ–?­—ã?ã¿ã®ãƒ•ィールドãªã‚‰ã?大æ–?­—化ã—ã¾ã™ã?
147             * 実登録ãƒ??ã‚¿ã®ä½œæ?ã¯ã€DBType オブジェクトを利用ã—ã¾ã™ã?ã§,
148             * ã“れ㨠Editor ã¨ãŒã‚¢ãƒ³ãƒžãƒƒãƒã?å ´åˆã?ã€ã†ã¾ãデータ変æ›
149             * ã•れãªã?¯èƒ½æ€§ãŒã‚りã¾ã™ã?ã§ã€æ³¨æ„願ã„ã¾ã™ã?
150             * 
151             * 5.8.6.1 (2015/04/17) æ¡æ•°å¯å¤‰å¯¾å¿?
152             *
153             * @param       value   (ä¸?ˆ¬ã«ç·¨é›?ƒ‡ãƒ¼ã‚¿ã¨ã—ã¦ç™»éŒ²ã•れãŸãƒ‡ãƒ¼ã‚¿)
154             *
155             * @return  修正後ã?æ–?­—å?(ä¸?ˆ¬ã«ãƒ??タベã?スã«ç™»éŒ²ã™ã‚‹ãƒ??ã‚¿)
156             */
157            @Override
158            public String valueSet( final String value ) {
159                    if( value == null || value.length() == 0 ) { return ""; }
160    //              return StringUtil.lTrim0( StringUtil.deleteChar( value,':' ) );
161                    // 5.8.6. (2015/04/03) ?”æ¡ã‚ˆã‚Šå°ã•ã?¨HHmmã€ãれ以外ã?ã€HHmmss
162                    final String val = StringUtil.deleteChar( value,':' );
163                    final boolean isHM = val.length() <= 4 ;
164    
165                    // 5.8.6.1 (2015/04/17) try-catch
166                    try{
167                            //                        HHmm    HHmmss
168                            final int hms = ( isHM ? 10000 : 1000000 ) + Integer.parseInt( val );
169            
170                            // å…??å½¢å¼ã«æº–æ‹ ã—ã¦è¿”ã™ã€?
171                            return String.valueOf( hms ).substring( 1 );
172                    }
173                    catch( NumberFormatException ex ) {
174                            return val;             
175                    }
176            }
177    
178            /**
179             * ãƒ??ã‚¿ãŒç™»éŒ²å¯èƒ½ã‹ã©ã?‹ã‚’ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?
180             * ãƒ??ã‚¿ãŒã‚¨ãƒ©ãƒ¼ã®å ´åˆã?ã€ãã®ã‚¨ãƒ©ãƒ¼å†?®¹ã‚’è¿”ã—ã¾ã™ã?
181             *
182             * @og.rev 5.2.3.6 (2012/01/20) 数値ã®ã¿ã«é™å®šã™ã‚‹ãŸã‚ã«è¿½åŠ?
183             * @og.rev 5.6.0.3 (2012/01/24) ADD ã«ã€å¼•æ•°ã®å€¤ã‚’加算ã™ã‚‹æ©Ÿè?を追åŠ?—ã¾ã™ã?
184             *
185             * @param   key         キー
186             * @param   value       値
187             * @param   sizeX       整数部åˆ??æ–?­—å?ã®é•·ã?
188             * @param   sizeY       少数部åˆ??æ–?­—å?ã®é•·ã?
189             * @param   typeParam   dbType パラメータ
190             * @param   isStrict    厳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ã‹ã©ã?‹[true:ã™ã‚‹/false:標準的]
191             *
192             * @return  エラーå†?®¹
193             */
194            @Override
195            public ErrorMessage valueCheck( final String key ,final String value ,
196                                                                            final int sizeX ,final int sizeY ,final String typeParam ,final boolean isStrict) {
197                    String checkVal = valueSet(value); // ?šã?念ã®ãŸã‚外ã—ã¦ãŠã
198    
199                    ErrorMessage msg = new ErrorMessage();
200                    if( checkVal == null || checkVal.length() == 0 ) { return msg; }
201    
202                    int len = (sizeY == 0) ? sizeX : sizeX + sizeY + 1;
203                    if( isStrict ) {
204                            if( len != checkVal.length() ) {
205                                    // æ–?­—å?ã®é•·ã•ãŒæŒ?®šã?é•·ã•ã¨ç•°ãªã‚Šã¾ã™ã?
206                                    msg.addMessage( 0,ErrorMessage.NG,"ERR0011", key,value, String.valueOf( value.length() ), String.valueOf( len ) );
207                            }
208                    }
209                    else {
210                            if( len < checkVal.length() ) {
211                                    // æ–?­—å?ã®é•·ã•ãŒæŒ?®šã?é•·ã•よりも長ã?§ã™ã?
212                                    msg.addMessage( 0,ErrorMessage.NG,"ERR0006",key,value,
213                                                                                    String.valueOf( value.length() ),String.valueOf( len ) );
214                            }
215                    }
216    
217    //              StringBuilder val = new StringBuilder();
218    //              boolean isError = false;
219    //              for( int i=0; i<checkVal.length(); i++ ) {
220    //                      char ch = checkVal.charAt( i );
221    //                      if( ('0' > ch || '9' < ch) ) {
222    //                              val.append( "<span class=\"NG\">" ).append( ch ).append( "</span>" );
223    //                              isError = true;
224    //                      }
225    //                      else {
226    //                              val.append( ch );
227    //                      }
228    //              }
229    //              if( isError ) {
230    //                      // æŒ?®šã?æ–?­—以外ã?æ–?­—ãŒä½¿ã‚れã¦ã?¾ã™ã?
231    //                      msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,val.toString() );
232    //              }
233    
234                    // 5.6.0.3 (2012/01/24) æ–?­—ã?ç¯?›²ãƒã‚§ãƒ?‚¯
235                    String check = DBTypeCheckUtil.rangeCheck( checkVal, '0', '9' );
236                    if( check != null ) {
237                            // æŒ?®šã?æ–?­—以外ã?æ–?­—ãŒä½¿ã‚れã¦ã?¾ã™ã?
238                            msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check );
239                    }
240    
241                    // 5.6.0.3 (2012/01/24) 時å?ç§’ã?æ•´åˆæ?ãƒã‚§ãƒ?‚¯
242                    check = DBTypeCheckUtil.hmsFormatCheck( checkVal );
243                    if( check != null ) {
244                            // æŒ?®šã?æ–?­—以外ã?æ–?­—ãŒä½¿ã‚れã¦ã?¾ã™ã?
245                            msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check );
246                    }
247    
248                    // 3.6.0.0 (2004/09/22) dbType パラメータを使用ã—ãŸãƒžãƒƒãƒãƒã‚§ãƒ?‚¯
249                    check = DBTypeCheckUtil.matcheCheck( checkVal,typeParam );
250                    if( check != null ) {
251                            // æŒ?®šã?æ–?­—以外ã?æ–?­—ãŒä½¿ã‚れã¦ã?¾ã™ã?
252                            msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check );
253                    }
254    
255                    return msg;
256            }
257    }