freeside/rt/lib/RT/URI/freeside Internal.pm,NONE,1.1 XMLRPC.pm,NONE,1.1

Kristian Hoffmann khoff at pouncequick.420.am
Thu Mar 10 17:34:35 PST 2005


Update of /home/cvs/cvsroot/freeside/rt/lib/RT/URI/freeside
In directory pouncequick:/tmp/cvs-serv2432/rt/lib/RT/URI/freeside

Added Files:
	Internal.pm XMLRPC.pm 
Log Message:
Reorganized RT->Freeside integration to support Internal (single RT/Freeside database) and XMLRPC interfaces.
All the UI stuff is handled the same either way.
Integration type is changed by setting $RT::URI::freeside::IntegrationType to either 'Internal' or 'XMLRPC' in your RT_SiteConfig.pm.


--- NEW FILE: XMLRPC.pm ---
# BEGIN LICENSE BLOCK
# 
# Copyright (c) 2004 Kristian Hoffmann <khoff at fire2wire.com>
# Based on the original RT::URI::base and RT::URI::fsck_com_rt.
# 
# Copyright (c) 1996-2003 Jesse Vincent <jesse at bestpractical.com>
# 
# (Except where explictly superceded by other copyright notices)
# 
# This work is made available to you under the terms of Version 2 of
# the GNU General Public License. A copy of that license should have
# been provided with this software, but in any event can be snarfed
# from www.gnu.org.
# 
# This work 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.
# 
# Unless otherwise specified, all modifications, corrections or
# extensions to this work which alter its source code become the
# property of Best Practical Solutions, LLC when submitted for
# inclusion in the work.
# 
# 
# END LICENSE BLOCK

use strict;
no warnings qw(redefine);

use vars qw($URL $XMLRPC_URL $_FS_VERSION);

use Frontier::Client;

=head1 NAME

RT::URI::freeside::XMLRPC

=head1 DESCRIPTION

Overlay for the RT::URI::freeside URI handler implementing the XMLRPC integration type.

See L<RT::URI::freeside> for public/private interface documentation.

=cut


sub _XMLRPCRequest { #Subroutine

  my $method = shift;
  my @args = @_;

  my $result;
  eval {
    my $server = new Frontier::Client ( url => $XMLRPC_URL );
    $result = $server->call($method, @args);
  };

  if (not $@ and ref($result) eq 'ARRAY') {
    return (scalar(@$result) == 1) ? @$result[0] : @$result;
  } else {
    $RT::Logger->debug("Freeside XMLRPC: " . $result || $@);
    return ();
  }

}

sub _FreesideGetRecord {

  my $self = shift;
  my ($table, $pkey) = ($self->{'fstable'}, $self->{'fspkey'});
  my $record;

  $RT::Logger->debug("Called XMLRPC::_FreesideGetRecord()");

  #FIXME: Need a better way to get primary keys.
  # Maybe create a method for it and cache them like version?
  my %table_pkeys = (
    cust_main => 'custnum',
  );
    
  my $method = 'Record.qsearchs';
  my @args = ($table, { $table_pkeys{$table} => $pkey });
  my ($record) = &_XMLRPCRequest($method, @args);

  return $record;

}


sub FreesideGetConfig {

  return _XMLRPCRequest('Conf.config', @_);

}


sub FreesideURL {

  return $URL;

}

sub FreesideVersion {

  return $_FS_VERSION if ($_FS_VERSION =~ /^\d+\.\d+\.\d+/);

  $RT::Logger->debug("Requesting freeside version...");
  ($_FS_VERSION) = &_XMLRPCRequest('version');
  $RT::Logger->debug("Cached freeside version: ${_FS_VERSION}");
 
  return $_FS_VERSION;

}

sub smart_search { #Subroutine

  return _XMLRPCRequest('cust_main.smart_search', @_);

}

sub small_custview {

  return _XMLRPCRequest('CGI.small_custview', @_);

}

1;

--- NEW FILE: Internal.pm ---
# BEGIN LICENSE BLOCK
# 
# Copyright (c) 2004 Kristian Hoffmann <khoff at fire2wire.com>
# Based on the original RT::URI::base and RT::URI::fsck_com_rt.
# 
# Copyright (c) 1996-2003 Jesse Vincent <jesse at bestpractical.com>
# 
# (Except where explictly superceded by other copyright notices)
# 
# This work is made available to you under the terms of Version 2 of
# the GNU General Public License. A copy of that license should have
# been provided with this software, but in any event can be snarfed
# from www.gnu.org.
# 
# This work 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.
# 
# Unless otherwise specified, all modifications, corrections or
# extensions to this work which alter its source code become the
# property of Best Practical Solutions, LLC when submitted for
# inclusion in the work.
# 
# 
# END LICENSE BLOCK
#
use strict;
no warnings qw(redefine);

use vars qw($conf);

use FS;
use FS::UID qw(dbh);
use FS::CGI qw(popurl);
use FS::Conf;
use FS::Record qw(qsearchs qsearch dbdef);
use FS::cust_main;
use FS::cust_svc;

=head1 NAME

RT::URI::freeside::Internal

=head1 DESCRIPTION

Overlay for the RT::URI::freeside URI handler implementing the Internal integration type.

See L<RT::URI::freeside> for public/private interface documentation.

=cut



sub _FreesideGetRecord {

  my $self = shift;
  my ($table, $pkey) = ($self->{'fstable'}, $self->{'fspkey'});

  $RT::Logger->debug("Called _FreesideGetRecord()");

  #eval "use FS::$table;";

  my $dbdef = dbdef;
  unless ($dbdef) {
    $RT::Logger->error("Using Internal freeside integration type, ".
                       "but it doesn't look like we're running under ".
                       "freeside's Mason handler.");
    return;
  }

  my $pkeyfield = $dbdef->table($table)->primary_key;
  unless ($pkeyfield) {
    $RT::Logger->error("No primary key for freeside table '$table'");
    return;
  }

  my $fsrec = qsearchs($table, { $pkeyfield => $pkey });
  unless ($fsrec) {
    $RT::Logger->error("Record with '$pkeyfield' == '$pkey' does " .
                       "not exist in table $table");
    return;
  }

  return { $fsrec->hash };

}

sub FreesideURL {

  return popurl(3);

}

sub FreesideVersion {

  return $FS::VERSION;

}

sub FreesideGetConfig {

  $conf = new FS::Conf unless ref($conf);

  return $conf->config(@_);

}

sub smart_search { #Subroutine

  return map { { $_->hash } } &FS::cust_main::smart_search(@_);

}

sub small_custview {

  return &FS::CGI::small_custview(@_);

}

1;




More information about the freeside-commits mailing list