| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
 | # BEGIN LICENSE BLOCK
# 
# Copyright (c) 2004 Kristian Hoffmann <khoff@fire2wire.com>
# Based on the original RT::URI::base and RT::URI::fsck_com_rt.
# 
# Copyright (c) 1996-2003 Jesse Vincent <jesse@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($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 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;
 |