All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.efaps.db.PrintQuery Maven / Gradle / Ivy

/*
 * Copyright 2003 - 2012 The eFaps Team
 *
 * 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.
 *
 * Revision:        $Rev: 7483 $
 * Last Changed:    $Date: 2012-05-11 11:57:38 -0500 (Fri, 11 May 2012) $
 * Last Changed By: $Author: [email protected] $
 */

package org.efaps.db;

import java.util.ArrayList;
import java.util.List;

import org.efaps.admin.access.AccessTypeEnums;
import org.efaps.admin.datamodel.Type;
import org.efaps.util.EFapsException;

/**
 * PrintQuery is a query uses to get the value for one object, specified by one
 * instance. The PrintQuery is able to execute various of the parts for the
 * select from EQL definition.
 *
 * TODO description!
 * TODO .value
 * TODO .attribute[ValueUOM].number
 * .attribute[ValueUOM].uom .attribute[ValueUOM].base
 *
 * @author The eFaps Team
 * @version $Id: PrintQuery.java 7483 2012-05-11 16:57:38Z [email protected] $
 */
public class PrintQuery extends AbstractPrintQuery
{

    /**
     * Instance this PrintQuery is based on.
     */
    private final Instance instance;

    /**
     * Initializes this print query depending on a _type and
     * _id.
     *
     * @param _type     type of the eFaps object to print
     * @param _id       id of the eFaps object to print
     * @throws EFapsException on error
     */
    public PrintQuery(final Type _type,
                      final String _id)
        throws EFapsException
    {
        this(Instance.get(_type, _id));
    }

    /**
     * Initializes this print query depending on a _type and
     * _id.
     *
     * @param _type     type of the eFaps object to print
     * @param _id       id of the eFaps object to print
     * @throws EFapsException on error
     */
    public PrintQuery(final Type _type,
                      final long _id)
        throws EFapsException
    {
        this(Instance.get(_type, _id));
    }

    /**
     * Initializes this print query depending on a _type and
     * _id.
     *
     * @param _type     type of the eFaps object to print
     * @param _id       id of the eFaps object to print
     * @throws EFapsException on error
     */
    public PrintQuery(final String _type,
                      final String _id)
        throws EFapsException
    {
        this(Instance.get(_type, _id));
    }

    /**
     * @param _oid OID of the instance to be updated.
     * @throws EFapsException on error
     */
    public PrintQuery(final String _oid)
        throws EFapsException
    {
        this(Instance.get(_oid));
    }

    /**
     * @param _instance instance to be updated.
     * @throws EFapsException on error
     */
    public PrintQuery(final Instance _instance)
        throws EFapsException
    {
        this.instance = _instance;
    }

    /**
     * Getter method for instance variable {@link #instance}.
     *
     * @return value of instance variable {@link #instance}
     */
    public Instance getInstance()
    {
        return this.instance;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Type getMainType()
    {
        return this.instance.getType();
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Instance getCurrentInstance()
    {
        return this.instance;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public List getInstanceList()
    {
        final List ret = new ArrayList();
        ret.add(this.instance);
        return ret;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public boolean execute() throws EFapsException
    {
        boolean ret = false;
        if (isMarked4execute()) {
            if (getMainType().hasAccess(this.instance, AccessTypeEnums.SHOW.getAccessType())) {
                ret = executeWithoutAccessCheck();
            }
        }
        return ret;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy