diff options
| author | ctrlaltca <> | 2012-08-31 13:57:52 +0000 | 
|---|---|---|
| committer | ctrlaltca <> | 2012-08-31 13:57:52 +0000 | 
| commit | 36fbeaf2e91dbbc7a2cb6d96faaf3c83ac756d52 (patch) | |
| tree | d4e87b9bff9dbc164eeffc7f2e75959da39f5cad | |
| parent | 8f7207361edb10527ca6468010e258f469b003cf (diff) | |
Quickstart tutorial page for the TRpcService
| -rw-r--r-- | .gitattributes | 1 | ||||
| -rw-r--r-- | demos/quickstart/protected/controls/Layout.tpl | 2 | ||||
| -rw-r--r-- | demos/quickstart/protected/controls/TopicList.tpl | 1 | ||||
| -rwxr-xr-x | demos/quickstart/protected/pages/Services/RpcService.page | 74 | 
4 files changed, 77 insertions, 1 deletions
| diff --git a/.gitattributes b/.gitattributes index 74f9a204..6541f9fb 100644 --- a/.gitattributes +++ b/.gitattributes @@ -1937,6 +1937,7 @@ demos/quickstart/protected/pages/GettingStarted/sequence.vsd -text  demos/quickstart/protected/pages/GettingStarted/zh/Introduction.page -text  demos/quickstart/protected/pages/Search.page -text  demos/quickstart/protected/pages/Search.php -text +demos/quickstart/protected/pages/Services/RpcService.page -text  demos/quickstart/protected/pages/Services/SoapService.page -text  demos/quickstart/protected/pages/Services/id/SoapService.page -text  demos/quickstart/protected/pages/Tutorial/AddressBook.page -text diff --git a/demos/quickstart/protected/controls/Layout.tpl b/demos/quickstart/protected/controls/Layout.tpl index ac41d1de..2faaf1b0 100644 --- a/demos/quickstart/protected/controls/Layout.tpl +++ b/demos/quickstart/protected/controls/Layout.tpl @@ -50,7 +50,7 @@  </table>
  <div id="footer">
 -Copyright © 2005-2007 <a href="http://www.pradosoft.com">PradoSoft</a>.
 +Copyright © 2005-2012 <a href="http://www.pradosoft.com">PradoSoft</a>.
  <br/><br/>
  <%= Prado::poweredByPrado() %>
  <a href="http://validator.w3.org/check?uri=referer"><img border="0" src="http://www.w3.org/Icons/valid-xhtml10" alt="Valid XHTML 1.0 Transitional" height="31" width="88" /></a>
 diff --git a/demos/quickstart/protected/controls/TopicList.tpl b/demos/quickstart/protected/controls/TopicList.tpl index 94860067..adcdff4a 100644 --- a/demos/quickstart/protected/controls/TopicList.tpl +++ b/demos/quickstart/protected/controls/TopicList.tpl @@ -66,6 +66,7 @@  <ul>
      <li><a href="?page=Fundamentals.Services">Page Service</a></li>
      <li><a href="?page=Services.SoapService">SOAP Service</a></li>
 +    <li><a href="?page=Services.RpcService">RPC Service</a></li>
  </ul>
  </div>
 diff --git a/demos/quickstart/protected/pages/Services/RpcService.page b/demos/quickstart/protected/pages/Services/RpcService.page new file mode 100755 index 00000000..4eb06f37 --- /dev/null +++ b/demos/quickstart/protected/pages/Services/RpcService.page @@ -0,0 +1,74 @@ +<com:TContent ID="body" >
 +
 +<h1>RPC Service</h1>
 +
 +<p class="block-content">
 +RPC Service stands for "Remote Procedure Call" Service and is a common name used to identify a service that exposes an interface that can be called by remote programs in order to execute a procedure.
 +An RPC Service tipically exposes one or more APIs (Application programming interface), permitting remote clients to make requests to the available methods and receive a proper response.
 +The interface itself is not bound to a specific programming language, but uses a standard data exchange protocol (tipically xml or json).
 +PRADO provides <tt>TRpcService</tt> that makes developing a RPC server application an extremely easy task.
 +</p>
 +
 +<p class="block-content">
 +To use <tt>TRpcService</tt>, configure it in the application specification like following:
 +</p>
 +<com:TTextHighlighter Language="xml" CssClass="source block-content">
 +<services>
 +  <service id="rpc" class="System.Web.Services.TRpcService">
 +    <rpcapi id="stockquote" class="path.to.StockQuote" />
 +    <!--
 +    <rpcapi...other api... />
 +    -->
 +  </service>
 +</services>
 +</com:TTextHighlighter>
 +<p class="block-content">
 +The example specifies a RPC service provider named <tt>stockquote</tt> which implements the <tt>getPrice</tt> RPC method in the provider class <tt>StockQuote</tt>,
 +</p>
 +<com:TTextHighlighter Language="php" CssClass="source block-content">
 +class StockQuote
 +{
 +	/**
 +	 * @param string $symbol the symbol of the stock
 +	 * @return float the stock price
 +	 * @soapmethod
 +	 */
 +	public function getPrice($symbol)
 +	{
 +		....return stock price for $symbol
 +	}
 +
 +    /**
 +     * Register the available methods
 +     * @return the list of implemented methods
 +     */
 +    public function registerMethods()
 +    {
 +        return array(
 +        'getPrice' => array('method' => array($this, 'getPrice')),
 +        );
 +    }
 +
 +}
 +</com:TTextHighlighter>
 +
 +<p class="block-content">
 +PRADO already bundles two common protocols: <tt>TXmlRpcService</tt> and <tt>TJsonRpcService</tt>: requests made by clients using one of these protocol will be automatically resolved and will call the user-specified APIs.
 +</p>
 +
 +<div class="note"><b class="tip">Note:</b>
 +<tt>TXmlRpcService</tt> is based on <a href="http://www.php.net/manual/it/book.xmlrpc.php">PHP XML-RPC extension</a> and thus requires the extension to be installed.
 +</div>
 +
 +<p class="block-content">
 +With the above simple code, we already finish a simple RPC service that allows other applications to query the price of a specific stock. A client needs to know the exact url of the service, the name of the method and the list of parameters needed by the method.
 +</p>
 +<com:TTextHighlighter Language="php" CssClass="source block-content">
 +// Assuming we're using the json-rpc php library from http://jsonrpcphp.org/
 +
 +require_once 'jsonRPCClient.php'; 
 +$client=new jsonRPCClient('http://path/to/index.php?rpc=stockquote');
 +echo $client->getPrice('IBM');
 +</com:TTextHighlighter>
 +
 +</com:TContent>
 | 
