/*
* DBeaver - Universal Database Manager
* Copyright (C) 2013-2016 Denis Forveille (titou10.titou10@gmail.com)
* Copyright (C) 2010-2017 Serge Rider (serge@jkiss.org)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.jkiss.dbeaver.ext.db2.model;
import java.sql.ResultSet;
import java.sql.Timestamp;
import java.util.Collection;
import org.jkiss.code.NotNull;
import org.jkiss.code.Nullable;
import org.jkiss.dbeaver.DBException;
import org.jkiss.dbeaver.ext.db2.DB2Constants;
import org.jkiss.dbeaver.ext.db2.editors.DB2SourceObject;
import org.jkiss.dbeaver.ext.db2.model.cache.DB2ViewBaseDepCache;
import org.jkiss.dbeaver.ext.db2.model.dict.DB2ViewStatus;
import org.jkiss.dbeaver.model.exec.DBCException;
import org.jkiss.dbeaver.model.impl.jdbc.JDBCUtils;
import org.jkiss.dbeaver.model.meta.Association;
import org.jkiss.dbeaver.model.meta.Property;
import org.jkiss.dbeaver.model.runtime.DBRProgressMonitor;
import org.jkiss.dbeaver.model.sql.SQLUtils;
import org.jkiss.dbeaver.model.struct.DBSObject;
import org.jkiss.dbeaver.model.struct.DBSObjectState;
import org.jkiss.utils.CommonUtils;
/**
* Base class for view-like objects (Views, MQT)
*
* @author Denis Forveille
*/
public abstract class DB2ViewBase extends DB2TableBase implements DB2SourceObject {
protected final DB2ViewBaseDepCache viewBaseDepCache = new DB2ViewBaseDepCache();
private Timestamp alterTime;
private Timestamp invalidateTime;
private Timestamp lastRegenTime;
private DB2ViewStatus valid;
private String text;
private String funcPath;
// -----------------
// Constructors
// -----------------
public DB2ViewBase(DBRProgressMonitor monitor, DB2Schema schema, ResultSet dbResult)
{
super(monitor, schema, dbResult);
setName(JDBCUtils.safeGetString(dbResult, "TABNAME"));
this.valid = CommonUtils.valueOf(DB2ViewStatus.class, JDBCUtils.safeGetString(dbResult, "VALID"));
this.text = JDBCUtils.safeGetString(dbResult, "TEXT");
this.funcPath = JDBCUtils.safeGetString(dbResult, "FUNC_PATH");
this.invalidateTime = JDBCUtils.safeGetTimestamp(dbResult, "INVALIDATE_TIME");
this.lastRegenTime = JDBCUtils.safeGetTimestamp(dbResult, "LAST_REGEN_TIME");
if (getDataSource().isAtLeastV9_5()) {
this.alterTime = JDBCUtils.safeGetTimestamp(dbResult, "ALTER_TIME");
}
}
// -----------------
// Business Contract
// -----------------
@Override
public boolean isView()
{
return true;
}
@NotNull
@Override
public DBSObjectState getObjectState()
{
return valid.getState();
}
@Override
public void refreshObjectState(@NotNull DBRProgressMonitor monitor) throws DBCException
{
}
@Override
public DBSObject refreshObject(@NotNull DBRProgressMonitor monitor) throws DBException
{
super.refreshObject(monitor);
viewBaseDepCache.clearCache();
return this;
}
// -----------------
// Source
// -----------------
@Override
public String getObjectDefinitionText(DBRProgressMonitor monitor) throws DBException
{
return SQLUtils.formatSQL(getDataSource(), text);
}
// -----------------
// Association
// -----------------
@Association
public Collection<DB2ViewBaseDep> getViewDeps(DBRProgressMonitor monitor) throws DBException
{
return viewBaseDepCache.getAllObjects(monitor, this);
}
// -----------------
// Properties
// -----------------
@Nullable
@Override
@Property(viewable = false, editable = false, updatable = false)
public String getDescription()
{
return super.getDescription();
}
@NotNull
@Override
@Property(viewable = true, editable = false, order = 1)
public String getName()
{
return super.getName();
}
@Property(viewable = true, editable = false, order = 20)
public DB2ViewStatus getValid()
{
return valid;
}
@Property(viewable = false, editable = false, order = 20)
public String getFuncPath()
{
return funcPath;
}
@Property(viewable = false, editable = false, order = 101, category = DB2Constants.CAT_DATETIME)
public Timestamp getAlterTime()
{
return alterTime;
}
@Property(viewable = false, editable = false, order = 102, category = DB2Constants.CAT_DATETIME)
public Timestamp getInvalidateTime()
{
return invalidateTime;
}
@Property(viewable = false, editable = false, order = 103, category = DB2Constants.CAT_DATETIME)
public Timestamp getLastRegenTime()
{
return lastRegenTime;
}
}