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.plugin.column;
017
018import org.opengion.fukurou.util.StringUtil;
019import org.opengion.hayabusa.db.AbstractDBType;
020
021/**
022 * DATA_DEFAULT カラムで、内容の整合性を整えます。
023 *
024 * DATA_DEFAULT(初期値)カラムは、データベース上に設定されていますが、
025 * DB定義スクリプトや、データベースの種類によって、本来必要な形式で
026 * 取得できないときがあります。
027 * ここでは、初期値の後ろに コメントがある場合は、削除し、
028 * データそのものに、シングルクオートをはずします。
029 * 定義情報出力時には、カラムの属性(数字型、文字型)
030 * また、postgreSQL 対応として、::属性情報が入るので、削除します。
031 * シーケンス使用時にも、nextval が自動的にセットされますが、
032 * 削除します。
033 *
034 * このクラスは、valueAction メソッドで、action="VALSET" でのみ
035 * 動作します。
036 *
037 * @og.group データ属性
038 * @og.rev 5.1.3.0 (2010/02/01) 新規作成
039 *
040 * @version  4.0
041 * @author       Kazuhiko Hasegawa
042 * @since    JDK5.0,
043 */
044public class DBType_DD extends AbstractDBType {
045        //* このプログラムのVERSION文字列を設定します。   {@value} */
046        private static final String VERSION = "5.7.6.3 (2014/05/23)" ;
047
048        /**
049         * action で指定されたコマンドを実行して、値の変換を行います。
050         * oldValue(旧データ)は、元のDBTableModelに設定されていた値です。通常は、
051         * この値を使用してカラム毎に変換を行います。newValue(新データ)は、引数で
052         * 指定された新しい値です。この値には、パラメータを指定して変換方法を
053         * 制御することも可能です。
054         * 指定のアクションがカラムで処理できない場合は、エラーになります。
055         *
056         * @og.rev 5.1.3.0 (2010/02/01) 新規追加
057         * @og.rev 5.7.6.2 (2014/05/16) -- コメント対応。処理の全面見直し
058         * @og.rev 5.7.6.3 (2014/05/23) 処理対象以外は、newValue を返すだけ。
059         *
060         * @param   action アクションコマンド
061         * @param   oldValue 入力データ(旧データ)
062         * @param   newValue 入力データ(新データ)
063         *
064         * @return      実行後のデータ
065         */
066        @Override
067        public String valueAction( final String action,final String oldValue,final String newValue ) {
068//              if( "VALSET".equals( action ) ) {
069                if( "VALSET".equals( action ) && oldValue != null ) {
070//                      String val = StringUtil.rTrim( oldValue ) ;
071                        String val = oldValue.trim() ;
072
073//                      if( val != null && val.length() > 0 ) {
074                        if( val.length() > 0 ) {
075                                // 共通:初期値に /* */ コメントが入ることがあるので、削除
076                                int pos = val.indexOf( "/*" );
077                                if( pos > 0 ) { val = val.substring( 0,pos ); }
078
079                                // 共通:初期値に -- コメントが入ることがあるので、削除
080                                pos = val.indexOf( "--" );
081                                if( pos > 0 ) { val = val.substring( 0,pos ); }
082
083                                // postgreSQL 対応:属性情報が入るので、削除
084                                pos = val.indexOf( "::" );
085                                if( pos > 0 ) { val = val.substring( 0,pos ); }
086
087                                // postgreSQL 対応:シーケンス使用時にも、nextval が自動的にセットされるので、削除
088                                pos = val.indexOf( "nextval" );
089                                if( pos > 0 ) { val = val.substring( 0,pos ); }
090
091                                val = val.trim();                               // 一旦、trim します。
092
093                                // 共通:5.7.6.3 (2014/05/23) シングルクオートはずし(先頭か、末尾に付いている場合は、すべてのシングルクオートを外します。)
094                                if( val.startsWith("'") || val.endsWith("'") ) {
095                                        val = StringUtil.replace( val,"'","" );
096                                }
097
098// 共通:シングルクオートはずし(先頭に付いている場合、次の位置を発見して、以降を削除)
099//                              if( val.indexOf( "'" ) == 0 ) {
100//                                      pos = val.indexOf( "'",1 );
101//                                      if( pos > 1 ) { val = val.substring( 1,pos ); }
102//                              }
103                        }
104
105                        return val ;
106                }
107                else {
108                        // 5.7.6.3 (2014/05/23) 処理対象以外は、newValue を返すだけ。
109//                      return super.valueAction( action,oldValue,newValue ) ;
110                        return newValue;
111                }
112        }
113}