The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#!/usr/bin/env perl

# Copyright 2005,2006 WSO2, Inc. http://wso2.com
#
# 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

use WSO2::WSF;

# This client demonstrate how to encrypt a message before sending.  Assumes WSF/PHP is
# installed and all the samples can be accessed from http://localhost/samples

my $payload =<<E;
<ns1:echo xmlns:ns1="http://php.axis2.org/samples">
  <text>Hello World!</text>
</ns1:echo>
E

open RCK, "< ../keys/bob_cert.cert";
undef $/;
my $rec_cert = <RCK>;

open PVK, "< ../keys/alice_key.pem";
undef $/;
my $pvt_key = <PVK>;

my $req_message = new WSO2::WSF::WSMessage(
    { 'payload'   => $payload,
      'to'        => 'http://localhost:8787/samples/security/encryption/service.php',
      'action'    => 'http://php.axis2.org/samples/echoString',
      'log_level' => 4
    } );

my $sec_arr = { 'encrypt'                => 'TRUE',
	        'algorithmSuite'         => 'Basic256Rsa15',
	        'securityTokenReference' => 'IssuerSerial' };

my $policy = new WSO2::WSF::WSPolicy( { 'security' => $sec_arr } );

my $sec_token = new WSO2::WSF::WSSecurityToken( { 'privateKey'          => $pvt_key,
						  'receiverCertificate' => $rec_cert } );

my $client = new WSO2::WSF::WSClient( { 'useWSA'        => 'TRUE',
				        'policy'        => $policy,
				        'securityToken' => $sec_token } );

my $response = $client->request( $req_message );

print $response->{str};