#!/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 =< Hello World! E open RCK, "< ../keys/bob_cert.cert"; undef $/; my $rec_cert = ; open PVK, "< ../keys/alice_key.pem"; undef $/; my $pvt_key = ; 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};