[prev in list] [next in list] [prev in thread] [next in thread] 

List:       james-dev
Subject:    cvs commit: jakarta-james/src/conf sqlResources.xml
From:       pgoldstein () apache ! org
Date:       2002-11-27 8:11:53
[Download RAW message or body]

pgoldstein    2002/11/27 00:11:53

  Modified:    src/conf sqlResources.xml
  Log:
  Adding comments to the sqlResources.xml.
  
  Revision  Changes    Path
  1.16      +99 -9     jakarta-james/src/conf/sqlResources.xml
  
  Index: sqlResources.xml
  ===================================================================
  RCS file: /home/cvs/jakarta-james/src/conf/sqlResources.xml,v
  retrieving revision 1.15
  retrieving revision 1.16
  diff -u -r1.15 -r1.16
  --- sqlResources.xml	4 Nov 2002 03:15:36 -0000	1.15
  +++ sqlResources.xml	27 Nov 2002 08:11:53 -0000	1.16
  @@ -24,37 +24,54 @@
       <dbMatcher db="hypersonic" databaseProductName="HypersonicSQL"/>
   </dbMatchers>
   
  -<!-- SQL statements to use for various components.
  +<!-- SQL statements to use for various components. -->
  +<!-- -->
  +<!-- Parameter definitions ${param} are replaced with parameter values -->
  +<!-- read from the configuration file. -->
  +<!-- -->
  +<!-- If a named statement has a definition defined for the current database \
product, -->  +<!-- then that statement is used. Otherwise the default statement is \
used. -->  
  -     Parameter definitions ${param} are replaced with parameter values
  -     from the configuration file.
  -
  -     If a named statement has a definition defined for the current database \
                product,
  -     then that statement is used. Otherwise the default statement is used.
  --->
   <!-- SQL statements for the JamesUsersJdbcRepository -->
  +<!-- -->
  +<!-- The JamesUsersJdbcRepository allows James to use a JDBC compliant database \
-->  +<!-- to hold user related data.  This includes aliases, forward addresses, -->
  +<!-- and password data.  The last is stored as an irreversible hash. -->
   <sqlDefs name="org.apache.james.userrepository.JamesUsersJdbcRepository">
       <sql name="tableName">${table}</sql>
  +
  +    <!-- Statements used to retrieve all user information for a user from this \
                repository. -->
       <sql name="select">SELECT username, pwdHash, pwdAlgorithm, useForwarding,
                           forwardDestination, useAlias, alias
                    FROM ${table}
                    ORDER BY username
       </sql>
  +
  +    <!-- Statements used to get all user information for a user with a particular \
user name in a -->  +    <!-- case-insensitive fashion from this repository. -->
       <sql name="selectByLowercaseName">
                   SELECT username, pwdHash, pwdAlgorithm, useForwarding,
                           forwardDestination, useAlias, alias
                   FROM ${table}
                   WHERE lower(username) = ?
       </sql>
  +
  +    <!-- Statements used to insert a user into this repository. -->
       <sql name="insert">INSERT INTO ${table}
                       (username, pwdHash, pwdAlgorithm, useForwarding, \
forwardDestination, useAlias, alias)  VALUES (?,?,?,?,?,?,?)
       </sql>
  +
  +    <!-- Statements used to update information for a user from this repository. \
-->  <sql name="update">UPDATE ${table} SET
                       pwdHash = ?, pwdAlgorithm = ?, useForwarding = ?, \
forwardDestination = ?, useAlias = ?, alias = ?  WHERE username = ?
       </sql>
  +
  +    <!-- Statements used to delete a user from this repository. -->
       <sql name="delete">DELETE FROM ${table} WHERE username = ?</sql>
  +
  +    <!-- Statements used to create the table associated with this class. -->
       <sql name="createTable" db="hypersonic">CREATE CACHED TABLE ${table} (username \
VARCHAR(64) NOT NULL, pwdHash VARCHAR(50), pwdAlgorithm VARCHAR(20), useForwarding \
INTEGER, forwardDestination VARCHAR(255), useAlias INTEGER, alias VARCHAR(255), \
PRIMARY KEY(username))</sql>  <sql name="createTable">CREATE TABLE ${table} (username \
VARCHAR(64) NOT NULL, pwdHash VARCHAR(50), pwdAlgorithm VARCHAR(20), useForwarding \
SMALLINT, forwardDestination VARCHAR(255), useAlias SMALLINT, alias VARCHAR(255), \
PRIMARY KEY(username))</sql>  <!-- An example of a database-specific sql statement
  @@ -63,64 +80,112 @@
   </sqlDefs>
   
   <!-- SQL statements for the DefaultUsersJdbcRepository -->
  +<!-- -->
  +<!-- The DefaultUsersJdbcRepository allows James to use a JDBC compliant database \
-->  +<!-- to hold user ids and password data. The password is stored as an \
irreversible hash. -->  +<!-- Unlike the JamesUsersJdbcRepository, this repository \
implementation doesn't support -->  +<!-- aliases or forwards. -->
   <sqlDefs name="org.apache.james.userrepository.DefaultUsersJdbcRepository">
       <sql name="tableName">${table}</sql>
  +
  +    <!-- Statements used to retrieve all user information for a user from this \
repository. -->  <sql name="select">SELECT username, pwdHash, pwdAlgorithm
                    FROM ${table}
       </sql>
  +
  +    <!-- Statements used to insert a user into this repository. -->
       <sql name="insert">INSERT INTO ${table}
                       (username, pwdHash, pwdAlgorithm)
                   VALUES (?,?,?)
       </sql>
  +
  +    <!-- Statements used to update information for a user from this repository. \
-->  <sql name="update">UPDATE ${table} SET
                       pwdHash = ?, pwdAlgorithm = ?
                   WHERE username = ?
       </sql>
  +
  +    <!-- Statements used to delete a user from this repository. -->
       <sql name="delete">DELETE FROM ${table} WHERE username = ?</sql>
  +
  +    <!-- Statements used to create the table associated with this class. -->
       <sql name="createTable" db="hypersonic">CREATE CACHED TABLE ${table} (username \
VARCHAR(64) NOT NULL, pwdHash VARCHAR(50), pwdAlgorithm VARCHAR(20), PRIMARY \
                KEY(username))</sql>
       <sql name="createTable">CREATE TABLE ${table} (username VARCHAR(64) NOT NULL, \
pwdHash VARCHAR(50), pwdAlgorithm VARCHAR(20), PRIMARY KEY(username))</sql>  \
</sqlDefs>  
  -<!-- SQL statements for the ListUsersJdbcRepository
  -        (allowing multiple lists in one table) -->
  +<!-- SQL statements for the ListUsersJdbcRepository -->
  +<!-- -->
  +<!-- This class is used for basic list management.  The database table can -->
  +<!-- be used to store subscriber data for mulitple lists.  -->
   <sqlDefs name="org.apache.james.userrepository.ListUsersJdbcRepository">
       <!-- An example of defining "default" parameters within the definition file.
            This is used if no key parameter is specified in config. -->
       <parameters key="unknownList"/>
   
       <sql name="tableName">${table}</sql>
  +
  +    <!-- Statements used to retrieve all users on a particular list from this \
repository. -->  <sql name="select">SELECT listSubscriber
                    FROM ${table}
                    WHERE listName = '${key}'
       </sql>
  +
  +    <!-- Statements used to insert a user/list mapping into this repository. -->
       <sql name="insert">INSERT INTO ${table}
                       (listSubscriber, listName)
                   VALUES (?, '${key}')
       </sql>
  +
  +    <!-- Statements used to update a user/list mapping in this repository. -->
       <sql name="update">UPDATE ${table} SET
                       listSubscriber = ?
                   WHERE listSubscriber = ? AND listName = '${key}'
       </sql>
  +
  +    <!-- Statements used to delete a user/list mapping from this repository. -->
       <sql name="delete">DELETE FROM ${table}
                   WHERE listSubscriber = ? AND listName = '${key}'
       </sql>
  +
  +    <!-- Statements used to create the table associated with this class. -->
       <sql name="createTable" db="hypersonic">CREATE CACHED TABLE ${table} (listName \
VARCHAR(64) NOT NULL, listSubscriber VARCHAR(255) NOT NULL, PRIMARY KEY(listName, \
listSubscriber))</sql>  <sql name="createTable">CREATE TABLE ${table} (listName \
VARCHAR(64) NOT NULL, listSubscriber VARCHAR(255) NOT NULL, PRIMARY KEY(listName, \
listSubscriber))</sql>  </sqlDefs>
   
   <!-- SQL statements for the JdbcMailRepository  -->
   <sqlDefs name="org.apache.james.mailrepository.JDBCMailRepository">
  +
  +    <!-- Statements used to check whether a particular message exists in this \
                repository. -->
       <sql name="checkMessageExistsSQL">SELECT count(*) FROM ${table} WHERE \
message_name = ? AND repository_name = ?</sql>  +
  +    <!-- Statements used to update a message stored in this repository. -->
       <sql name="updateMessageSQL">UPDATE ${table} SET message_state = ?, \
error_message = ?, sender = ?, recipients = ?, remote_host = ?, remote_addr = ?, \
last_updated = ? WHERE message_name = ? AND repository_name = ?</sql>  +
  +    <!-- Statements used to update the body of a message stored in this \
                repository. -->
       <sql name="updateMessageBodySQL">UPDATE ${table} SET message_body = ? WHERE \
message_name = ? AND repository_name = ?</sql>  +
  +    <!-- Statements used to insert a message into this repository. -->
       <sql name="insertMessageSQL">INSERT INTO ${table} (message_name, \
repository_name, message_state, error_message, sender, recipients, remote_host, \
remote_addr, last_updated, message_body) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)</sql>  \
+  +    <!-- Statements used to retrieve a message stored in this repository. -->
       <sql name="retrieveMessageSQL">SELECT message_state, error_message, sender, \
recipients, remote_host, remote_addr, last_updated FROM ${table} WHERE message_name = \
? AND repository_name = ?</sql>  +
  +    <!-- Statements used to retrieve the body of a message stored in this \
                repository. -->
       <sql name="retrieveMessageBodySQL">SELECT message_body FROM ${table} WHERE \
message_name = ? AND repository_name = ?</sql>  +
  +    <!-- Statements used to retrieve the size of the body of a message stored in \
this repository. -->  +    <!-- NOTE: This statement is optional and need not be \
                implemented for a particular database to be supported. -->
       <sql name="retrieveMessageBodySizeSQL" db="mssql">SELECT \
datalength(message_body) FROM ${table} WHERE message_name = ? AND repository_name = \
                ?</sql>
       <sql name="retrieveMessageBodySizeSQL" db="mysql">SELECT length(message_body) \
                FROM ${table} WHERE message_name = ? AND repository_name = ?</sql>
       <sql name="retrieveMessageBodySizeSQL" db="hypersonic">SELECT \
length(message_body) FROM ${table} WHERE message_name = ? AND repository_name = \
?</sql>  +
  +    <!-- Statements used to delete a message stored in this repository. -->
       <sql name="removeMessageSQL">DELETE FROM ${table} WHERE message_name = ? AND \
repository_name = ?</sql>  +
  +    <!-- Statements used to list all messages stored in this repository. -->
       <sql name="listMessagesSQL">SELECT message_name, message_state, last_updated \
FROM ${table} WHERE repository_name = ? ORDER BY last_updated ASC</sql>  +
  +    <!-- Statements used to create the table associated with this class. -->
       <sql name="createTable" db="mysql">
           CREATE TABLE ${table} (
               message_name varchar (200) NOT NULL,
  @@ -205,18 +270,43 @@
       </sql>
   </sqlDefs>
   
  +<!-- SQL statements to support the JDBCSpoolRepository class -->
  +<!-- -->
  +<!-- The JDBCSpoolRepository allows James to use a JDBC compliant database -->
  +<!-- to hold messages that are on the spool. -->
   <sqlDefs name="org.apache.james.mailrepository.JDBCSpoolRepository">
  +
  +    <!-- Statements used to check whether a particular message exists in this \
                repository. -->
       <sql name="checkMessageExistsSQL">SELECT count(*) FROM ${table} WHERE \
message_name = ? AND repository_name = ?</sql>  +
  +    <!-- Statements used to update a message stored in this repository. -->
       <sql name="updateMessageSQL">UPDATE ${table} SET message_state = ?, \
error_message = ?, sender = ?, recipients = ?, remote_host = ?, remote_addr = ?, \
last_updated = ? WHERE message_name = ? AND repository_name = ?</sql>  +
  +    <!-- Statements used to update the body of a message stored in this \
                repository. -->
       <sql name="updateMessageBodySQL">UPDATE ${table} SET message_body = ? WHERE \
message_name = ? AND repository_name = ?</sql>  +
  +    <!-- Statements used to insert a message into this repository. -->
       <sql name="insertMessageSQL">INSERT INTO ${table} (message_name, \
repository_name, message_state, error_message, sender, recipients, remote_host, \
remote_addr, last_updated, message_body) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)</sql>  \
+  +    <!-- Statements used to retrieve a message stored in this repository. -->
       <sql name="retrieveMessageSQL">SELECT message_state, error_message, sender, \
recipients, remote_host, remote_addr, last_updated FROM ${table} WHERE message_name = \
? AND repository_name = ?</sql>  +
  +    <!-- Statements used to retrieve the body of a message stored in this \
                repository. -->
       <sql name="retrieveMessageBodySQL">SELECT message_body FROM ${table} WHERE \
message_name = ? AND repository_name = ?</sql>  +
  +    <!-- Statements used to retrieve the size of the body of a message stored in \
this repository. -->  +    <!-- NOTE: This statement is optional and need not be \
                implemented for a particular database to be supported. -->
       <sql name="retrieveMessageBodySizeSQL" db="mssql">SELECT \
datalength(message_body) FROM ${table} WHERE message_name = ? AND repository_name = \
                ?</sql>
       <sql name="retrieveMessageBodySizeSQL" db="mysql">SELECT length(message_body) \
                FROM ${table} WHERE message_name = ? AND repository_name = ?</sql>
       <sql name="retrieveMessageBodySizeSQL" db="hypersonic">SELECT \
length(message_body) FROM ${table} WHERE message_name = ? AND repository_name = \
?</sql>  +
  +    <!-- Statements used to delete a message stored in this repository. -->
       <sql name="removeMessageSQL">DELETE FROM ${table} WHERE message_name = ? AND \
repository_name = ?</sql>  +
  +    <!-- Statements used to list all messages stored in this repository. -->
       <sql name="listMessagesSQL">SELECT message_name, message_state, last_updated \
FROM ${table} WHERE repository_name = ? ORDER BY last_updated ASC</sql>  +
  +    <!-- Statements used to create the table associated with this class. -->
       <sql name="createTable" db="hypersonic">
           CREATE TABLE ${table} (
               message_name varchar (200) NOT NULL,
  
  
  

--
To unsubscribe, e-mail:   <mailto:james-dev-unsubscribe@jakarta.apache.org>
For additional commands, e-mail: <mailto:james-dev-help@jakarta.apache.org>


[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic