home *** CD-ROM | disk | FTP | other *** search
/ PC Professionell 2004 December / PCpro_2004_12.ISO / files / webserver / xampp / xampp-cocoon-addon-1.4.9-installer.exe / user-list.xsp < prev    next >
Encoding:
Extensible Markup Language  |  2004-07-12  |  10.4 KB  |  276 lines

  1. <?xml version="1.0"?>
  2. <!--
  3.   Copyright 1999-2004 The Apache Software Foundation
  4.  
  5.   Licensed under the Apache License, Version 2.0 (the "License");
  6.   you may not use this file except in compliance with the License.
  7.   You may obtain a copy of the License at
  8.  
  9.       http://www.apache.org/licenses/LICENSE-2.0
  10.  
  11.   Unless required by applicable law or agreed to in writing, software
  12.   distributed under the License is distributed on an "AS IS" BASIS,
  13.   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14.   See the License for the specific language governing permissions and
  15.   limitations under the License.
  16. -->
  17.  
  18. <xsp:page language="java"
  19.      xmlns:xsp="http://apache.org/xsp"
  20.      xmlns:esql="http://apache.org/cocoon/SQL/v2"
  21.      xmlns:xsp-request="http://apache.org/xsp/request/2.0"
  22. >
  23.  
  24.   <xsp:structure>
  25.     <xsp:include>java.util.Enumeration</xsp:include>
  26.   </xsp:structure>
  27.     
  28.   <page>
  29.  
  30.     <resources>
  31.        <resource type="file" href="database.xml?cocoon-view=pretty-content">Descriptor</resource>
  32.        <resource type="file" href="schema.sql">Schema</resource>
  33.        <resource type="doc" href="userdocs/actions/database-actions.html">Actions</resource>
  34.        <resource type="doc" href="userdocs/xsp/esql.html">ESQL</resource>
  35.     </resources>
  36.  
  37.     <title>user-list</title>
  38.     
  39.     <content>
  40.         
  41.  
  42.       <h1>Modular Database Actions</h1> 
  43.  
  44.       <hr/> 
  45.  
  46.       <p>The intention is to factor out those parts that are dependent on
  47.       the utilised DBMS as well as the methods used to obtain the values
  48.       and communicate results. Therefore three classes of modules
  49.       exist:</p>
  50.  
  51.       <ol>
  52.         <li>Input Modules read data from some source (e.g. the request
  53.             object or session attributes or whatever)</li> 
  54.  
  55.        <li>Output Modules send the data to an arbitrary
  56.            destination. Again, this could be request attributes or
  57.            anything else. When the database transaction finishes, it is
  58.            signalled to them whether the transaction succeeded or
  59.            failed.</li>
  60.  
  61.         <li>Database Modules determine the value of a key attribute
  62.             column in a database if it's is of auto increment type. This
  63.             could be by querying the database, reading from an arbitrary
  64.             source (e.g. request object) or just skipping the column when
  65.             inserting a row and querying the database afterwards. This
  66.             needs to be done e.g. for Informix's SERIAL or HSQLDB's
  67.             IDENTITY column types.</li>
  68.  
  69.       </ol>
  70.       <hr/>
  71.  
  72.       <h2>Current database content</h2>
  73.  
  74.       <esql:connection>         
  75.         <esql:pool>personnel</esql:pool>
  76.               
  77.         <p>
  78.           <sqltbl>
  79.             <esql:execute-query>
  80.               <esql:query>select * from user order by name, firstname, uname, uid</esql:query>
  81.               <esql:results>
  82.                 <esql:row-results>
  83.                        
  84.                   <sqltblrow>
  85.                     <name>
  86.                       <esql:get-string column="name"/>
  87.                     </name>
  88.                     <firstname>
  89.                       <esql:get-string column="firstname"/>
  90.                     </firstname>
  91.                     <uname>
  92.                       <esql:get-string column="uname"/>
  93.                     </uname>
  94.                     <action>
  95.                       <form action="edit-groups">
  96.                         <input type="hidden" name="user.uid">
  97.                           <xsp:attribute name="value"><esql:get-string column="uid"/></xsp:attribute>
  98.                         </input>
  99.                         <input type="submit" name="edit-user" value="edit"/>
  100.                       </form>
  101.                       <form>
  102.                         <input type="hidden" name="user.uid">
  103.                           <xsp:attribute name="value"><esql:get-string column="uid"/></xsp:attribute>
  104.                         </input>
  105.                         <input type="submit" name="del-user" value="delete"/>
  106.                       </form>
  107.                     </action>
  108.                   </sqltblrow>
  109.                        
  110.                 </esql:row-results>
  111.               </esql:results>
  112.               <esql:error-results>
  113.                 <error><esql:get-message/></error>
  114.               </esql:error-results>
  115.             </esql:execute-query>
  116.             <form method="Get">
  117.               <sqltblrow>
  118.                 <name>
  119.                   <input type="text" name="user.name" size="20" maxsize="20">
  120.                     <xsp:attribute name="value"><!-- <xsp-request:get-parameter default="" name="user.name"/> --></xsp:attribute>
  121.                   </input>
  122.                 </name>
  123.                 <firstname>
  124.                   <input type="text" name="user.firstname" size="20" maxsize="20">
  125.                     <xsp:attribute name="value"><!-- <xsp-request:get-parameter default="" name="user.firstname"/> --></xsp:attribute>
  126.                   </input>
  127.                 </firstname>
  128.                 <uname>
  129.                   <input type="text" name="user.uname" size="20" maxsize="20">
  130.                     <xsp:attribute name="value"><!-- <xsp-request:get-parameter default="" name="user.uname"/> --></xsp:attribute>
  131.                   </input>
  132.                 </uname>
  133.                 <action>
  134.                   <select multiple="1" name="user_groups.gid" size="4">
  135.                     <esql:execute-query>
  136.                       <esql:query>select gid, gname from groups order by gname</esql:query>
  137.                       <esql:results>
  138.                         <esql:row-results>
  139.                           <option>                  
  140.                             <xsp:attribute name="value"><esql:get-string column="gid"/></xsp:attribute>
  141.                             <esql:get-string column="gname"/>
  142.                           </option>
  143.                         </esql:row-results>
  144.                       </esql:results>
  145.                     </esql:execute-query>
  146.                   </select>
  147.                   <input type="submit" name="add-user-groups" value="new user"/>
  148.                 </action>
  149.               </sqltblrow>   
  150.             </form>
  151.           </sqltbl>
  152.         </p>
  153.  
  154.         <p>
  155.           <sqltbl>
  156.             <esql:execute-query>
  157.               <esql:query>select * from groups order by gname</esql:query>
  158.               <esql:results>
  159.                 <esql:row-results>
  160.                   <form>
  161.                     <sqltblrow>
  162.                       <gname>
  163.                         <input type="text" name="groups.gname">
  164.                           <xsp:attribute name="value"><esql:get-string column="gname"/></xsp:attribute>
  165.                         </input>
  166.                         <input type="hidden" name="groups.gid">
  167.                           <xsp:attribute name="value"><esql:get-string column="gid"/></xsp:attribute>
  168.                         </input>
  169.                         <input type="submit" name="upd-group" value="update"/>
  170.                         <input type="submit" name="del-group" value="delete"/>
  171.                       </gname>
  172.                     </sqltblrow>
  173.                   </form>
  174.                 </esql:row-results>
  175.               </esql:results>
  176.               <esql:error-results>
  177.                 <error><esql:get-message/></error>
  178.               </esql:error-results>
  179.             </esql:execute-query>
  180.             <sqltblrow>
  181.               <gname>
  182.                 <form>
  183.                   <input type="text" name="groups.gname" size="20" maxsize="20">
  184.                     <xsp:attribute name="value"><!-- <xsp-request:get-parameter default="" name="groups.gname"/> --></xsp:attribute>
  185.                   </input>
  186.                   <input type="submit" name="add-group" value="new group"/>
  187.                 </form>
  188.               </gname>
  189.             </sqltblrow>
  190.           </sqltbl>
  191.         </p>
  192.  
  193.         <p>
  194.           <form>
  195.             <esql:execute-query>
  196.               <esql:query>select user.uid, user.uname, groups.gid, groups.gname from user, user_groups, groups where user.uid=user_groups.uid and user_groups.gid=groups.gid order by user.uname, groups.gname</esql:query>
  197.               <esql:results>
  198.                 <sqltbl>
  199.                   <esql:row-results>
  200.                     <form action="edit-groups">
  201.                       <sqltblrow>
  202.                         <uname>
  203.                           <input type="hidden" name="user.uid">
  204.                             <xsp:attribute name="value"><esql:get-string column="uid"/></xsp:attribute>
  205.                           </input>
  206.                           <esql:get-string column="uname"/>
  207.                         </uname>
  208.                         <gname><esql:get-string column="gname"/></gname>
  209.                         <action>
  210.                           <input value="edit groups" type="submit"/>
  211.                         </action>
  212.                       </sqltblrow>
  213.                     </form>
  214.                   </esql:row-results>
  215.                 </sqltbl>
  216.               </esql:results>
  217.               <esql:error-results>
  218.                 <error><esql:get-message/></error>
  219.               </esql:error-results>
  220.             </esql:execute-query>
  221.           </form>
  222.         </p>
  223.       </esql:connection>
  224.        
  225.       <hr/>
  226.  
  227.  
  228.       <p><h2>Status Information</h2></p>
  229.  
  230.       <p><h3>Request Attributes</h3></p>
  231.       <p>
  232.         <table border="0">
  233.           <tbody>
  234.             <xsp:logic>{
  235.                Enumeration e=request.getAttributeNames();
  236.                while ( e.hasMoreElements() ) {
  237.                   String attribute = (String) e.nextElement();
  238.                   Object value = request.getAttribute(attribute);
  239.                   <tr>
  240.                     <td align="right"><xsp:expr>attribute</xsp:expr></td>
  241.                     <td>="<xsp:expr>value</xsp:expr>"</td>
  242.                   </tr>
  243.                }
  244.             }</xsp:logic>
  245.           </tbody>
  246.         </table>
  247.       </p>
  248.  
  249.       <p><h3>Request Parameters</h3></p>
  250.       <p>
  251.         <table border="0">
  252.           <tbody>
  253.             <xsp:logic>{
  254.                Enumeration e=request.getParameterNames();
  255.                while ( e.hasMoreElements() ) {
  256.                   String attribute = (String) e.nextElement();
  257.                   Object[] value = request.getParameterValues(attribute);
  258.                   for (int i=0; i < value.length; i++) {
  259.                      <tr>
  260.                        <td align="right"><xsp:expr>attribute</xsp:expr>[<xsp:expr>i</xsp:expr>]</td>
  261.                        <td>="<xsp:expr>value[i]</xsp:expr>"</td>
  262.                      </tr>
  263.                   }
  264.                }
  265.             }</xsp:logic>
  266.           </tbody>
  267.         </table><br/>
  268.       </p>
  269.  
  270.       <hr/>
  271.       
  272.     </content>
  273.   </page>
  274. </xsp:page>
  275.  
  276.