source: branches/version-2_11-dev/data/module/SOAP/Server/Email_Gateway.php @ 21304

Revision 21304, 5.4 KB checked in by kotani, 12 years ago (diff)

#1521 (PEAR::SOAP 配布と異なる部分がある)

  • 新しいバージョンの配布ファイルを上書きすることで解決
  • →2.11.4には含めないため一旦コミットキャンセル

#1522 (PEAR::SOAP をバージョンアップ)

  • 0.11.0 -> 0.12.0
  • →2.11.4には含めないため一旦コミットキャンセル
  • Property svn:eol-style set to LF
  • Property svn:mime-type set to text/x-httpd-php; charset=UTF-8
Line 
1<?php
2/**
3 * This file contains the code for the email-HTTP SOAP gateway server.
4 *
5 * PHP versions 4 and 5
6 *
7 * LICENSE: This source file is subject to version 2.02 of the PHP license,
8 * that is bundled with this package in the file LICENSE, and is available at
9 * through the world-wide-web at http://www.php.net/license/2_02.txt.  If you
10 * did not receive a copy of the PHP license and are unable to obtain it
11 * through the world-wide-web, please send a note to license@php.net so we can
12 * mail you a copy immediately.
13 *
14 * @category   Web Services
15 * @package    SOAP
16 * @author     Shane Caraveo <Shane@Caraveo.com>   Port to PEAR and more
17 * @copyright  2003-2005 The PHP Group
18 * @license    http://www.php.net/license/2_02.txt  PHP License 2.02
19 * @link       http://pear.php.net/package/SOAP
20 */
21
22require_once 'SOAP/Server/Email.php';
23require_once 'SOAP/Transport.php';
24
25/**
26 * SOAP Server Class that implements an email SOAP server.
27 * http://www.pocketsoap.com/specs/smtpbinding/
28 *
29 * This class overrides the default HTTP server, providing the ability to
30 * parse an email message and execute soap calls.  This class DOES NOT pop the
31 * message; the message, complete with headers, must be passed in as a
32 * parameter to the service function call.
33 *
34 * This class calls a provided HTTP SOAP server, forwarding the email request,
35 * then sending the HTTP response out as an email.
36 *
37 * @access   public
38 * @package  SOAP
39 * @author   Shane Caraveo <shane@php.net>
40 */
41class SOAP_Server_Email_Gateway extends SOAP_Server_Email {
42
43    var $gateway = null;
44    var $dump = false;
45
46    function SOAP_Server_Email_Gateway($gateway = '', $send_response = true,
47                                       $dump = false)
48    {
49        parent::SOAP_Server();
50        $this->send_response = $send_response;
51        $this->gateway = $gateway;
52        $this->dump = $dump;
53    }
54
55    function service(&$data, $gateway = '', $endpoint = '',
56                     $send_response = true, $dump = false)
57    {
58        $this->endpoint = $endpoint;
59        $response = '';
60        $useEncoding = 'Mime';
61        $options = array();
62        if (!$gateway) {
63            $gateway = $this->gateway;
64        }
65
66        /* We have a full set of headers, need to find the first blank
67         * line. */
68        $this->_parseEmail($data);
69        if ($this->fault) {
70            $response = $this->fault->message();
71        }
72        if ($this->headers['content-type'] == 'application/dime')
73            $useEncoding = 'DIME';
74
75        /* Call the HTTP Server. */
76        if (!$response) {
77            $soap_transport =& SOAP_Transport::getTransport($gateway, $this->xml_encoding);
78            if ($soap_transport->fault) {
79                $response = $soap_transport->fault->message();
80            }
81        }
82
83        /* Send the message. */
84        if (!$response) {
85            $options['soapaction'] = $this->headers['soapaction'];
86            $options['headers']['Content-Type'] = $this->headers['content-type'];
87
88            $response = $soap_transport->send($data, $options);
89            if (isset($this->headers['mime-version']))
90                $options['headers']['MIME-Version'] = $this->headers['mime-version'];
91
92            if ($soap_transport->fault) {
93                $response = $soap_transport->fault->message();
94            } else {
95                foreach ($soap_transport->transport->attachments as $cid => $body) {
96                    $this->attachments[] = array('body' => $body, 'cid' => $cid, 'encoding' => 'base64');
97                }
98                if (count($this->_attachments)) {
99                    if ($useEncoding == 'Mime') {
100                        $soap_msg = $this->_makeMimeMessage($response);
101                        $options['headers']['MIME-Version'] = '1.0';
102                    } else {
103                        /* Default is DIME. */
104                        $soap_msg = $this->_makeDIMEMessage($response);
105                        $options['headers']['Content-Type'] = 'application/dime';
106                    }
107                    if (PEAR::isError($soap_msg)) {
108                        return $this->_raiseSoapFault($soap_msg);
109                    }
110                    if (is_array($soap_msg)) {
111                        $response = $soap_msg['body'];
112                        if (count($soap_msg['headers'])) {
113                            if (isset($options['headers'])) {
114                                $options['headers'] = array_merge($options['headers'], $soap_msg['headers']);
115                            } else {
116                                $options['headers'] = $soap_msg['headers'];
117                            }
118                        }
119                    }
120                }
121            }
122        }
123
124        if ($this->send_response) {
125            if ($this->dump || $dump) {
126                print $response;
127            } else {
128                $from = array_key_exists('reply-to', $this->headers) ? $this->headers['reply-to'] : $this->headers['from'];
129
130                $soap_transport =& SOAP_Transport::getTransport('mailto:' . $from, $this->response_encoding);
131                $from = $this->endpoint ? $this->endpoint : $this->headers['to'];
132                $headers = array('In-Reply-To' => $this->headers['message-id']);
133                $options = array('from' => $from, 'subject'=> $this->headers['subject'], 'headers' => $headers);
134                $soap_transport->send($response, $options);
135            }
136        }
137    }
138}
Note: See TracBrowser for help on using the repository browser.