NAME

Siebel::COM::App::DataControl - Perl extension for access Siebel COM Data Control

SYNOPSIS

use feature 'say';
use Siebel::COM::App::DataControl;
use TryCatch;

my $input_file = shift;
chomp($input_file);

open( my $input, '<', $input_file ) or die "Cannot read $input_file: $!\n";
my @lines = <$input>;
close($input);

my $app = Siebel::COM::App::DataControl->new(
    {
        user       => 'sadmin',
        password   => 'sadmin',
        host       => 'foobar',
        enterprise => 'SIEBEL',
        lang       => 'ENU',
        aom        => 'eCommunicationsObjMgr_enu'
    }
);

try {

    $app->login();

    my $bo = $app->get_bus_object('Account');
    my $bc = $bo->get_bus_comp('Account');

    $bc->activate_field('Location');
    $bc->activate_field('Extension Phone Number');

    foreach my $loc (@lines) {

        chomp($loc);

        $bc->clear_query();
        $bc->set_view_mode();

        $bc->set_search_spec( 'Location', "='$loc'" );
        $bc->query();

        if ( $bc->first_record() ) {

            do {

                my $val = $bc->get_field_value('Location');

                if ( defined($val) ) {

                    $bc->set_field_value( 'Extension Phone Number', '' );
                    $bc->write_record();

                }

                say 'updated';

            } while ( $bc->next_record() )

        }
        else {

            say 'Could not find the account';

        }

    }

}
catch {

    die 'Exception: ' . $app->get_last_error();

}

DESCRIPTION

Siebel::COM::App::DataControl is a subclass of Siebel::COM::App, providing access to the Siebel COM Data Control environment as well as additional functionality.

Usually using Data Control is the preferable way to access Siebel with COM, but Siebel COM Data Server has it's advantages. Please check Siebel::COM::App::DataServer for more details on that.

This class extends Siebel::COM::App superclass, adding more attributees and methods or overriding the inherited ones as necessary.

ATTRIBUTES

host

A string that holds the host part of the connection string of Siebel COM Data Control.

The definition of this attribute during object creation is obligatory.

enterprise

A string that holds the enterprise part of the connection string of Siebel COM Data Control.

The definition of this attribute during object creation is obligatory.

lang

A string that holds the language code to be used as part of the connection string of Siebel COM Data Control. This parameter is optional.

aom

A string that holds the AOM part of the connection string of Siebel COM Data Control.

The definition of this attribute during object creation is obligatory.

transport

A string that holds the transport part of the connection string of Siebel COM Data Control.

The definition of this attribute during object creation is optional, but defaults to "TCPIP".

encryption

A string that holds the encryption part of the connection string of Siebel COM Data Control.

The definition of this attribute during object creation is optional, but defaults to "none".

compression

A string that holds the compression part of the connection string of Siebel COM Data Control.

The definition of this attribute during object creation is optional, but defaults to "none".

connected

A boolean to indicate if the object instance is connected or not to a Siebel Enterprise.

It is not required during object creation and defaults to false (0). For obvious reasons, one should not use it to instantiate a new object.

This attribute is read-only.

ole_class

A string represeting the class name to be instantied by Win32::OLE. It defaults to "SiebelDataControl.SiebelDataControl.1" and most probably you don't want to change that.

This attribute is read-only.

METHODS

All attributes defaults to have their getters/setters methods as the same name of the attribute, with some exceptions:

  • ole_class is read-only

  • connected is read-only. The getter for it is is_connected.

Additionally by those defined by the superclass, this class have the following methods:

BUILD

Additionally by the superclass BUILD, this methods automatically enables exceptions for errors during usage of Data Control.

DEMOLISH

This is a Moose based DEMOLISH method. Takes care of invoking logoff if the object it is still connected to a Siebel Enterprise during object destruction.

get_conn_str

Returns a formatted string of the connection string used by Siebel COM Data Control to connect to a Siebel Enterprise through COM.

logoff

Executes the logoff of a Siebel Enterprise. Can be invoked anytime, but it will be invoked by default during object destruction if is_connected method returns true.

EXPORT

None by default.

SEE ALSO

AUTHOR

Alceu Rodrigues de Freitas Junior, <arfreitas@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2012 of Alceu Rodrigues de Freitas Junior, <arfreitas@cpan.org>

This file is part of Siebel COM project.

Siebel COM is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

Siebel COM is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with Siebel COM. If not, see <http://www.gnu.org/licenses/>.