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.text.DateFormat;
019    // import java.text.SimpleDateFormat;
020    // import java.util.Calendar;
021    // import java.util.Locale;
022    
023    import org.opengion.fukurou.model.NativeType;
024    import org.opengion.fukurou.util.ErrorMessage;
025    import org.opengion.fukurou.util.StringUtil;
026    import org.opengion.fukurou.util.HybsDateUtil;
027    import org.opengion.hayabusa.common.HybsSystemException;
028    import org.opengion.hayabusa.db.AbstractDBType;
029    import org.opengion.hayabusa.db.DBTypeCheckUtil;
030    
031    /**
032     * æ–?­—å?ã®é–‹å§‹æ—¥ä»˜å±žæ?ã‚’è¦å®šã™ã‚‹åŠè§’文字å?を扱ã?‚ºã®ã€ã‚«ãƒ©ãƒ?±žæ?を定義ã—ã¾ã™ã?
033     * 登録時ã«0000XXXXã¯00000101ã€?999XXXXã¯99991231ã€ãれ以外ã?YYYYMM01ã¨å¤‰æ›ã—ã¾ã™ã?
034     *
035     * YYYYMM01 ã¾ãŸã?ã€?0000XXXX , 9999XXXX を許å¯ã—ã¾ã™ã?
036     * ã¾ãŸã?入力データã¨ã—ã¦, YYYYMM å½¢å¼?ã¯ã€è¨±å¯ã—ã¾ã›ã‚“。ã‚らã‹ã˜ã‚,
037     * valueSet( String ) ã§ãƒ??タを変æ›ã—ã¦ãŠãå¿?¦ãŒã‚りã¾ã™ã?
038     * ãŸã ã—ã?日付ã¨ã—ã¦ã®æ•´åˆæ?ãƒã‚§ãƒ?‚¯ã¯è¡Œã„ã¾ã›ã‚“ã€?
039     *
040     * タイプãƒã‚§ãƒ?‚¯ã¨ã—ã¦ã€ä»¥ä¸‹ã?æ¡ä»¶ã‚’判定ã—ã¾ã™ã?
041     * ・æ–?­—å?é•·ã¯ã€ç›´æŽ¥è¨ˆç®—ã§æ–?­—æ•°ã¨ã®æ¯”è¼?
042     * ・日付使用æ–?­—ãƒã‚§ãƒ?‚¯ã€?'0' > c || '9' < c)以外ã?エラー
043     * ・æ–?­—パラメータ㮠正è¦è¡¨ç¾ãƒã‚§ãƒ?‚¯
044     *
045     * @og.rev 5.4.3.6 (2012/01/19) コメント修正
046     * @og.group ãƒ??タ属æ?
047     *
048     * @version  4.0
049     * @author   Kazuhiko Hasegawa
050     * @since    JDK5.0,
051     */
052    public class DBType_YM01 extends AbstractDBType {
053            //* ã“ã?プログラãƒ??VERSIONæ–?­—å?を設定ã—ã¾ã™ã?       {@value} */
054            private static final String VERSION = "5.6.6.0 (2013/07/05)" ;
055    
056            private static final String DEF_VALUE = "00000000" ;    // ãƒ??ã‚¿ã®ãƒ?ƒ•ォルトå?
057    
058            /**
059             * ãƒ?ƒ•ォルトコンストラクター
060             *
061             * @og.rev 4.0.0.0 (2005/01/31) type å»?­¢
062             */
063            public DBType_YM01() {
064                    super( DEF_VALUE );
065            }
066    
067            /**
068             * NATIVEã®åž‹ã?識別コードを返ã—ã¾ã™ã?
069             *
070             * @og.rev 3.8.5.3 (2006/08/07) æ–°è¦ä½œæ?
071             * @og.rev 4.1.1.2 (2008/02/28) Enumåž?fukurou.model.NativeType)ã«å¤‰æ›´
072             *
073             * @return  NATIVEã®åž‹ã?識別コーãƒ?DBType ã§è¦å®?
074             * @see org.opengion.fukurou.model.NativeType
075             */
076            @Override
077            public NativeType getNativeType() {
078                    return NativeType.CALENDAR;
079            }
080    
081            /**
082             * åŠè§’スペã?スã§å›ºå®šé•·(åŠè§’æ›ç®—ã?æ•°)ã«å¤‰æ›ã—ãŸæ–?­—å?ã‚’è¿”ã—ã¾ã™ã?
083             * ãªãŠã?エラーãƒã‚§ãƒ?‚¯ã¯è¡Œã‚れã¾ã›ã‚“ã€?
084             * 実行å‰ã«ã€å¿?š valueCheck( String value ,int len ) ãŒè¡Œã‚れるå¿?¦ãŒã‚りã¾ã™ã?
085             *
086             * @og.rev 3.5.4.5 (2004/01/23) エンコード指定ã«å¤‰æ›´ã—ã¾ã™ã?
087             *
088             * @param   value    ?¦?©?¬?¬åŸ‹ã‚ã™ã‚‹æ–?­—å?
089             * @param   sizeX    整数部åˆ??æ–?­—å?ã®é•·ã?
090             * @param   sizeY    少数部åˆ??æ–?­—å?ã®é•·ã?
091             * @param   encode   固定長ã§å¤‰æ›ã™ã‚‹æ–?­—エンコーãƒ?
092             *
093             * @return  ?¦?©?¬?¬åŸ‹ã‚ã—ãŸæ–°ã—ã„æ–?­—å?
094             */
095            @Override
096            public String valueFill( final String value ,final int sizeX ,final int sizeY,final String encode ) {
097                    if( value != null && value.length() >= sizeX ) {
098                            return value.substring( 0, sizeX );
099                    }
100    
101                    String errMsg = "æŒ?®šæ–‡å­—ãŒä¸æ­£ã§ã™ã?value=[" + value + "] length=[" + sizeX + "]";
102                    throw new HybsSystemException( errMsg );
103            }
104    
105            /**
106             * Stringå¼•æ•°ã®æ–?­—å?を+1ã—ãŸæ–‡å­—å?ã‚’è¿”ã—ã¾ã™ã?
107             * ã“ã“ã§ã¯ã€YYYYMM å½¢å¼ã?ãƒ??ã‚¿ã«ã€?¼‹ï¼?ã™ã‚‹ã®ã§ã€æœˆã‚’+1ã—ã¾ã™ã?
108             * 
109             * 0000XX ã¨ã€?999XX ã¯ã€å¼•æ•°ã®å€¤ãã?ã¾ã¾ã‚’è¿”ã—ã¾ã™ã?
110             * 引数ã?null ã®å ´åˆã¨ã€ã‚¼ãƒ­æ–?­—å?("")ã®å ´åˆã?,物ç?š„åˆæœŸè¨­å®šå?(String getDefault())
111             * ã®å€¤ã‚’è¿”ã—ã¾ã™ã?
112             * ãれ以外ã?å ´åˆã?ã€æ—¥ä»˜è¨ˆç®—を行ã„ã€æœˆã‚’加算ã—ã¾ã™ã?よã£ã¦ã€å¹´æœˆãƒ•ォーマットã«
113             * åˆã‚ãªã?ƒ‡ãƒ¼ã‚¿ã‚’指定ã—ãŸå?åˆã?ã€ã‚¨ãƒ©ãƒ¼ã«ãªã‚Šã¾ã™ã?ã§ã€ã”注æ„ãã?•ã??
114             *
115             * @og.rev 3.6.0.0 (2004/09/17) 月ã?åŠ?®—ロジãƒ?‚¯ã®èª¤ã‚Šä¿®æ­£ã€?roll â‡?add)
116             * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用ã™ã‚‹ã‚ˆã†ã«ä¿®æ­£ã—ã¾ã™ã?
117             *
118             * @param       value   Stringå¼•æ•°ã®æ–?­—å?
119             *
120             * @return  Stringå¼•æ•°ã®æ–?­—å?を+1ã—ãŸæ–‡å­—å?
121             */
122            @Override
123            public String valueAdd( final String value ) {
124                    if( value == null || value.length() == 0 ) { return getDefault(); }
125                    if( value.startsWith( "0000" ) || value.startsWith( "9999" ) ) { return value; }
126    
127                    return HybsDateUtil.getMonthPlus( value , 1 ) + "01";           // 5.5.7.2 (2012/10/09) HybsDateUtil を利用
128    
129    //              Calendar cal = Calendar.getInstance();
130    // 
131    //              int year  = Integer.parseInt( value.substring( 0,4 ) );
132    //              int month = Integer.parseInt( value.substring( 4,6 ) ) - 1;
133    //              int date  = Integer.parseInt( value.substring( 6,8 ) );
134    // 
135    //              cal.set( year,month,date );
136    //              cal.add( Calendar.MONTH, 1 );           // 月を?‘ヶ月加算ã—ã¾ã™ã?
137    // 
138    //              DateFormat formatter = new SimpleDateFormat( "yyyyMMdd",Locale.JAPAN );
139    //              return formatter.format( cal.getTime() );
140            }
141    
142            /**
143             * å…¥åŠ›ãƒ‡ãƒ¼ã‚¿ã®æ•´åˆæ?ã‚’åˆã‚ã›ãŸçµæžœã‚’è¿”ã—ã¾ã™ã?
144             * ã“ã“ã§ã¯ã€æ—¥ä»˜ãƒ‡ãƒ¼ã‚¿ã«å«ã¾ã‚Œã‚‹ãƒ•ォーマット文字å?を削除ã—ã?æ•°å­—ã ã‘ã?
145             * æ–?­—å?を作æ?ã—ã?YYYYMM å½¢å¼ã?å…ˆé??–æ–‡å­???"01" ã®ãƒ??タを作æ?ã—ã¾ã™ã?
146             * ã“ã?メソãƒ?ƒ‰ã§ã¯ã€æ—¥ä»˜æ¬??ã€å¿?š "01" ã«ãªã‚Šã¾ã™ã?
147             * 実登録ãƒ??ã‚¿ã®ä½œæ?ã¯ã€DBType オブジェクトを利用ã—ã¾ã™ã?ã§,
148             * ã“れ㨠Editor ã¨ãŒã‚¢ãƒ³ãƒžãƒƒãƒã?å ´åˆã?ã€ã†ã¾ãデータ変æ›
149             * ã•れãªã?¯èƒ½æ€§ãŒã‚りã¾ã™ã?ã§ã€æ³¨æ„願ã„ã¾ã™ã?
150             *
151             * @og.rev 3.3.3.0 (2003/07/09) å‰å¾Œã?スペã?スをå–り除ã?¦ãŠãã€?
152             * @og.rev 4.3.3.4 (2008/12/01) 0000 or 9999 時ã?ãƒã‚°ä¿®æ­£
153             * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用ã™ã‚‹ã‚ˆã†ã«ä¿®æ­£ã—ã¾ã™ã?
154             * @og.rev 5.6.6.0 (2013/07/05) parseDate を改é€?—ã€æ—¥ä»˜ã?æ¡æ•°æŒ?®šã‚’厳å¯?«åˆ¤å®šã—ã¾ã™ã?
155             *
156             * @param       value   (ä¸?ˆ¬ã«ç·¨é›?ƒ‡ãƒ¼ã‚¿ã¨ã—ã¦ç™»éŒ²ã•れãŸãƒ‡ãƒ¼ã‚¿)
157             *
158             * @return  修正後ã?æ–?­—å?(ä¸?ˆ¬ã«ãƒ??タベã?スã«ç™»éŒ²ã™ã‚‹ãƒ??ã‚¿)
159             */
160            @Override
161            public String valueSet( final String value ) {
162                    if( value == null || value.length() == 0 ) { return getDefault(); }
163    
164                    return HybsDateUtil.parseDate( value , 6 ) + "01";              // ä¸è¦ãªè¨˜å·ç­‰ã‚’削除ã—ã?æ¡æ•°ã‚’ãã‚ãˆã‚‹ã?
165    
166    //              if( value == null ) { return null; }
167    //              String rtn = StringUtil.rTrim( value );                 // 3.3.3.1 (2003/07/18)
168    //              if( rtn.length() >= 6 ) {
169    //                      rtn = rtn.substring( 0,6 );
170    // //                   if(      rtn.startsWith( "0000" ) ) { rtn = "000001"; }
171    // //                   else if( rtn.startsWith( "9999" ) ) { rtn = "999912"; }
172    //                      if(      rtn.startsWith( "0000" ) ) { rtn = "00000101"; }
173    //                      else if( rtn.startsWith( "9999" ) ) { rtn = "99991231"; }
174    //                      else                                { rtn += "01"; }
175    //              }
176    //              return rtn;
177            }
178    
179            /**
180             * ãƒ??ã‚¿ãŒç™»éŒ²å¯èƒ½ã‹ã©ã?‹ã‚’ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?
181             * ãƒ??ã‚¿ãŒã‚¨ãƒ©ãƒ¼ã®å ´åˆã?ã€ãã®ã‚¨ãƒ©ãƒ¼å†?®¹ã‚’è¿”ã—ã¾ã™ã?
182             * valueSet( String ) ã™ã‚‹ä»¥å‰ã?æ–?­—ã«ã¤ã?¦ã¯,æ•´åˆæ?ã¯ä¿è¨¼ã—ã¦ã?¾ã›ã‚“ã€?
183             *
184             * @og.rev 3.6.0.0 (2004/09/22) dbType パラメータを引数ã«è¿½åŠ?
185             * @og.rev 5.2.2.0 (2010/11/01) 厳å¯?«ãƒã‚§ãƒ?‚¯(isStrict=true)ã™ã‚‹ãƒ•ラグを追åŠ?
186             * @og.rev 5.6.0.3 (2012/01/24) 日付ãƒã‚§ãƒ?‚¯ã®æ•´åˆæ?ã¾ã§å«ã‚ãŸãƒã‚§ãƒ?‚¯ã‚’å?れるã€?
187             *
188             * @param   key         ã‚¿ã‚°ã®ã‚­ãƒ¼(カラãƒ?D)
189             * @param   value       ãƒã‚§ãƒ?‚¯ã™ã‚‹å€¤
190             * @param   sizeX       整数部åˆ??æ–?­—å?ã®é•·ã?
191             * @param   sizeY       少数部åˆ??æ–?­—å?ã®é•·ã?
192             * @param   typeParam   dbType パラメータ
193             * @param   isStrict    厳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ã‹ã©ã?‹[true:ã™ã‚‹/false:標準的]
194             *
195             * @return  エラーå†?®¹
196             */
197    //      public ErrorMessage valueCheck( final String key ,final String value ,
198    //                                                                      final int sizeX ,final int sizeY ,final String param ) {
199            @Override
200            public ErrorMessage valueCheck( final String key ,final String value ,
201                                                                            final int sizeX ,final int sizeY ,final String typeParam ,final boolean isStrict) {
202    
203                    ErrorMessage msg = new ErrorMessage();
204                    if( value == null || value.length() == 0 ) { return msg; }
205    
206                    int len = (sizeY == 0) ? sizeX : sizeX + sizeY + 1;
207                    // 5.2.2.0 (2010/11/01) 厳å¯?«ãƒã‚§ãƒ?‚¯(isStrict=true)ã™ã‚‹ãƒ•ラグを追åŠ?
208                    if( isStrict ) {
209                            if( len != value.length() ) {
210                                    // æ–?­—å?ã®é•·ã•ãŒæŒ?®šã?é•·ã•ã¨ç•°ãªã‚Šã¾ã™ã?
211                                    msg.addMessage( 0,ErrorMessage.NG,"ERR0011", key,value, String.valueOf( value.length() ), String.valueOf( len ) );
212                            }
213                    }
214                    else {
215                            if( len < value.length() ) {
216                                    // æ–?­—å?ã®é•·ã•ãŒæŒ?®šã?é•·ã•よりも長ã?§ã™ã?
217                                    msg.addMessage( 0,ErrorMessage.NG,"ERR0006",key,value,
218                                                                                    String.valueOf( value.length() ),String.valueOf( len ) );
219                            }
220                    }
221    
222    //              StringBuilder val = new StringBuilder();
223    //              boolean isError = false;
224    //              for( int i=0; i<value.length(); i++ ) {
225    //                      char ch = value.charAt( i );
226    //                      if( ('0' > ch || '9' < ch) ) {
227    //                              val.append( "<span class=\"NG\">" ).append( ch ).append( "</span>" );
228    //                              isError = true;
229    //                      }
230    //                      else {
231    //                              val.append( ch );
232    //                      }
233    //              }
234    //              if( isError ) {
235    //                      // æŒ?®šã?æ–?­—以外ã?æ–?­—ãŒä½¿ã‚れã¦ã?¾ã™ã?
236    //                      msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,val.toString() );
237    //              }
238    
239                    // 5.6.0.3 (2012/01/24) æ–?­—ã?ç¯?›²ãƒã‚§ãƒ?‚¯
240                    String check = DBTypeCheckUtil.rangeCheck( value, '0', '9' );
241                    if( check != null ) {
242                            // æŒ?®šã?æ–?­—以外ã?æ–?­—ãŒä½¿ã‚れã¦ã?¾ã™ã?
243                            msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check );
244                    }
245    
246                    // 5.6.0.3 (2012/01/24) 日付文字ã?æ•´åˆæ?ãƒã‚§ãƒ?‚¯
247                    // "0000","9999" ã§å§‹ã¾ã‚‹æ—¥ä»˜ã?未æ¡ä»¶è¨±å¯ã€?
248                    check = DBTypeCheckUtil.ymdFormatCheck( value );
249                    if( check != null ) {
250                            // æŒ?®šã?æ–?­—以外ã?æ–?­—ãŒä½¿ã‚れã¦ã?¾ã™ã?
251                            msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check );
252                    }
253    
254                    // 3.6.0.0 (2004/09/22) dbType パラメータを使用ã—ãŸãƒžãƒƒãƒãƒã‚§ãƒ?‚¯
255                    check = DBTypeCheckUtil.matcheCheck( value,typeParam );
256                    if( check != null ) {
257                            // æŒ?®šã?æ–?­—以外ã?æ–?­—ãŒä½¿ã‚れã¦ã?¾ã™ã?
258                            msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check );
259                    }
260    
261                    return msg;
262            }
263    }