Removing temporary release candidate tag
git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@832155 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
b8bb66d4a6
commit
b848f8f799
416 changed files with 0 additions and 41096 deletions
|
@ -1,7 +0,0 @@
|
|||
Apache Tuscany is an effort undergoing incubation at The Apache Software
|
||||
Foundation (ASF), sponsored by the Apache Web Services PMC. Incubation is
|
||||
required of all newly accepted projects until a further review indicates that
|
||||
the infrastructure, communications, and decision making process have stabilized
|
||||
in a manner consistent with other successful ASF projects. While incubation
|
||||
status is not necessarily a reflection of the completeness or stability of the
|
||||
code, it does indicate that the project has yet to be fully endorsed by the ASF.
|
|
@ -1,353 +0,0 @@
|
|||
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
|
||||
1. Definitions.
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following
|
||||
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||
replaced with your own identifying information. (Don't include
|
||||
the brackets!) The text should be enclosed in the appropriate
|
||||
comment syntax for the file format. We also recommend that a
|
||||
file or class name and description of purpose be included on the
|
||||
same "printed page" as the copyright notice for easier
|
||||
identification within third-party archives.
|
||||
|
||||
Copyright [yyyy] [name of copyright owner]
|
||||
|
||||
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
|
||||
limitations under the License.
|
||||
|
||||
===============================================================================================================
|
||||
|
||||
Other components and dependencies under Apache Software License 2.0 :
|
||||
|
||||
log4j-1.2.14.jar - Apache Logging Services
|
||||
derby 10.2.2.0.jar - Apache Derby
|
||||
stax-api-1.0.1.jar - The Streaming API for XML (StAX)
|
||||
wstx-asl-3.2.0.jar - WoodStox StAX implementation
|
||||
standard-1.1.1.jar - The Apache Jackarta Taglibs
|
||||
jstl-1.1.2.jar - The Apache Jackarta Taglibs
|
||||
*.tld - The Apache Jackarta Taglibs
|
||||
|
||||
===============================================================================================================
|
||||
|
||||
|
||||
Apache Tuscany SDO for Java Subcomponents
|
||||
=========================================:
|
||||
|
||||
The Tuscany SDO for Java release includes a number of subcomponents with
|
||||
separate copyright notices and license terms. Your use of the source
|
||||
code for the these subcomponents is subject to the terms and
|
||||
conditions of the following licenses.
|
||||
|
||||
License for the Service Data Objects JavaDoc and Interface Definition files. (tuscany-sdo-api-r2.1-1.0-incubating.jar)
|
||||
|
||||
Permission to copy, make derivative works of, and distribute the Service Data Objects
|
||||
JavaDoc and Interface Definition Files files in any medium without fee or royalty as part
|
||||
of a compliant implementation of the Service Data Objects Specification is hereby granted.
|
||||
The Service Data Objects Specification may be found at any of the following locations:
|
||||
|
||||
http://dev2dev.bea.com/technologies/commonj/index.jsp
|
||||
http://www.ibm.com/developerworks/library/specification/ws-sdo/
|
||||
http://oracle.com/technology/webservices/sca
|
||||
https://www.sdn.sap.com/
|
||||
http://www.xcalia/xdn/specs/sdo
|
||||
|
||||
THE SERVICE DATA OBJECTS SPECIFICATION AND THE JAVADOC AND INTERFACE DEFINITION FILES
|
||||
ARE PROVIDED "AS IS," AND THE AUTHORS MAKE NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, REGARDING THIS
|
||||
SPECIFICATION OR THE JAVADOC AND INTERFACE DEFINITION FILES AND THE IMPLEMENTATION OF THEIR CONTENTS,
|
||||
INCLUDING, BUT NOT LIMITED TO, WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE,
|
||||
NON-INFRINGEMENT OR TITLE. THE AUTHORS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL,
|
||||
INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF OR RELATING TO ANY USE OR DISTRIBUTION OF THE
|
||||
SERVICE DATA OBJECTS SPECIFICATION OR THE JAVADOC OR INTERFACE DEFINTION FILES.
|
||||
|
||||
The name and trademarks of the Authors may NOT be used in any manner, including advertising or
|
||||
publicity pertaining to the Service Component Architecture Specification or its contents without specific,
|
||||
written prior permission. Title to copyright in the Service Data Objects Specification and the
|
||||
JavaDoc and Interface Definition Files will at all times remain with the Authors.
|
||||
|
||||
No other rights are granted by implication, estoppel or otherwise.
|
||||
|
||||
=================================================================================================================
|
||||
|
||||
For the Eclipse EMF components
|
||||
(codegen-2.2.3.jar
|
||||
codegen-ecore-2.2.3.jar
|
||||
common-2.2.3.jar
|
||||
ecore-2.2.3.jar
|
||||
ecore-change-2.2.3.jar
|
||||
ecore-xmi-2.2.3.jar
|
||||
xsd-2.2.3.jar)
|
||||
|
||||
Eclipse Public License - v 1.0
|
||||
|
||||
THE ACCOMPANYING PROGRAM IS PROVIDED UNDER THE TERMS OF THIS ECLIPSE PUBLIC LICENSE ("AGREEMENT"). ANY USE, REPRODUCTION OR DISTRIBUTION OF THE PROGRAM CONSTITUTES RECIPIENT'S ACCEPTANCE OF THIS AGREEMENT.
|
||||
|
||||
1. DEFINITIONS
|
||||
|
||||
"Contribution" means:
|
||||
|
||||
a) in the case of the initial Contributor, the initial code and documentation distributed under this Agreement, and
|
||||
b) in the case of each subsequent Contributor:
|
||||
|
||||
i) changes to the Program, and
|
||||
|
||||
ii) additions to the Program;
|
||||
|
||||
where such changes and/or additions to the Program originate from and are distributed by that particular Contributor. A Contribution 'originates' from a Contributor if it was added to the Program by such Contributor itself or anyone acting on such Contributor's behalf. Contributions do not include additions to the Program which: (i) are separate modules of software distributed in conjunction with the Program under their own license agreement, and (ii) are not derivative works of the Program.
|
||||
|
||||
"Contributor" means any person or entity that distributes the Program.
|
||||
|
||||
"Licensed Patents " mean patent claims licensable by a Contributor which are necessarily infringed by the use or sale of its Contribution alone or when combined with the Program.
|
||||
|
||||
"Program" means the Contributions distributed in accordance with this Agreement.
|
||||
|
||||
"Recipient" means anyone who receives the Program under this Agreement, including all Contributors.
|
||||
|
||||
2. GRANT OF RIGHTS
|
||||
|
||||
a) Subject to the terms of this Agreement, each Contributor hereby grants Recipient a non-exclusive, worldwide, royalty-free copyright license to reproduce, prepare derivative works of, publicly display, publicly perform, distribute and sublicense the Contribution of such Contributor, if any, and such derivative works, in source code and object code form.
|
||||
|
||||
b) Subject to the terms of this Agreement, each Contributor hereby grants Recipient a non-exclusive, worldwide, royalty-free patent license under Licensed Patents to make, use, sell, offer to sell, import and otherwise transfer the Contribution of such Contributor, if any, in source code and object code form. This patent license shall apply to the combination of the Contribution and the Program if, at the time the Contribution is added by the Contributor, such addition of the Contribution causes such combination to be covered by the Licensed Patents. The patent license shall not apply to any other combinations which include the Contribution. No hardware per se is licensed hereunder.
|
||||
|
||||
c) Recipient understands that although each Contributor grants the licenses to its Contributions set forth herein, no assurances are provided by any Contributor that the Program does not infringe the patent or other intellectual property rights of any other entity. Each Contributor disclaims any liability to Recipient for claims brought by any other entity based on infringement of intellectual property rights or otherwise. As a condition to exercising the rights and licenses granted hereunder, each Recipient hereby assumes sole responsibility to secure any other intellectual property rights needed, if any. For example, if a third party patent license is required to allow Recipient to distribute the Program, it is Recipient's responsibility to acquire that license before distributing the Program.
|
||||
|
||||
d) Each Contributor represents that to its knowledge it has sufficient copyright rights in its Contribution, if any, to grant the copyright license set forth in this Agreement.
|
||||
|
||||
3. REQUIREMENTS
|
||||
|
||||
A Contributor may choose to distribute the Program in object code form under its own license agreement, provided that:
|
||||
|
||||
a) it complies with the terms and conditions of this Agreement; and
|
||||
|
||||
b) its license agreement:
|
||||
|
||||
i) effectively disclaims on behalf of all Contributors all warranties and conditions, express and implied, including warranties or conditions of title and non-infringement, and implied warranties or conditions of merchantability and fitness for a particular purpose;
|
||||
|
||||
ii) effectively excludes on behalf of all Contributors all liability for damages, including direct, indirect, special, incidental and consequential damages, such as lost profits;
|
||||
|
||||
iii) states that any provisions which differ from this Agreement are offered by that Contributor alone and not by any other party; and
|
||||
|
||||
iv) states that source code for the Program is available from such Contributor, and informs licensees how to obtain it in a reasonable manner on or through a medium customarily used for software exchange.
|
||||
|
||||
When the Program is made available in source code form:
|
||||
|
||||
a) it must be made available under this Agreement; and
|
||||
|
||||
b) a copy of this Agreement must be included with each copy of the Program.
|
||||
|
||||
Contributors may not remove or alter any copyright notices contained within the Program.
|
||||
|
||||
Each Contributor must identify itself as the originator of its Contribution, if any, in a manner that reasonably allows subsequent Recipients to identify the originator of the Contribution.
|
||||
|
||||
4. COMMERCIAL DISTRIBUTION
|
||||
|
||||
Commercial distributors of software may accept certain responsibilities with respect to end users, business partners and the like. While this license is intended to facilitate the commercial use of the Program, the Contributor who includes the Program in a commercial product offering should do so in a manner which does not create potential liability for other Contributors. Therefore, if a Contributor includes the Program in a commercial product offering, such Contributor ("Commercial Contributor") hereby agrees to defend and indemnify every other Contributor ("Indemnified Contributor") against any losses, damages and costs (collectively "Losses") arising from claims, lawsuits and other legal actions brought by a third party against the Indemnified Contributor to the extent caused by the acts or omissions of such Commercial Contributor in connection with its distribution of the Program in a commercial product offering. The obligations in this section do not apply to any claims or Losses relating to any actual or alleged intellectual property infringement. In order to qualify, an Indemnified Contributor must: a) promptly notify the Commercial Contributor in writing of such claim, and b) allow the Commercial Contributor to control, and cooperate with the Commercial Contributor in, the defense and any related settlement negotiations. The Indemnified Contributor may participate in any such claim at its own expense.
|
||||
|
||||
For example, a Contributor might include the Program in a commercial product offering, Product X. That Contributor is then a Commercial Contributor. If that Commercial Contributor then makes performance claims, or offers warranties related to Product X, those performance claims and warranties are such Commercial Contributor's responsibility alone. Under this section, the Commercial Contributor would have to defend claims against the other Contributors related to those performance claims and warranties, and if a court requires any other Contributor to pay any damages as a result, the Commercial Contributor must pay those damages.
|
||||
|
||||
5. NO WARRANTY
|
||||
|
||||
EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is solely responsible for determining the appropriateness of using and distributing the Program and assumes all risks associated with its exercise of rights under this Agreement , including but not limited to the risks and costs of program errors, compliance with applicable laws, damage to or loss of data, programs or equipment, and unavailability or interruption of operations.
|
||||
|
||||
6. DISCLAIMER OF LIABILITY
|
||||
|
||||
EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
7. GENERAL
|
||||
|
||||
If any provision of this Agreement is invalid or unenforceable under applicable law, it shall not affect the validity or enforceability of the remainder of the terms of this Agreement, and without further action by the parties hereto, such provision shall be reformed to the minimum extent necessary to make such provision valid and enforceable.
|
||||
|
||||
If Recipient institutes patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Program itself (excluding combinations of the Program with other software or hardware) infringes such Recipient's patent(s), then such Recipient's rights granted under Section 2(b) shall terminate as of the date such litigation is filed.
|
||||
|
||||
All Recipient's rights under this Agreement shall terminate if it fails to comply with any of the material terms or conditions of this Agreement and does not cure such failure in a reasonable period of time after becoming aware of such noncompliance. If all Recipient's rights under this Agreement terminate, Recipient agrees to cease use and distribution of the Program as soon as reasonably practicable. However, Recipient's obligations under this Agreement and any licenses granted by Recipient relating to the Program shall continue and survive.
|
||||
|
||||
Everyone is permitted to copy and distribute copies of this Agreement, but in order to avoid inconsistency the Agreement is copyrighted and may only be modified in the following manner. The Agreement Steward reserves the right to publish new versions (including revisions) of this Agreement from time to time. No one other than the Agreement Steward has the right to modify this Agreement. The Eclipse Foundation is the initial Agreement Steward. The Eclipse Foundation may assign the responsibility to serve as the Agreement Steward to a suitable separate entity. Each new version of the Agreement will be given a distinguishing version number. The Program (including Contributions) may always be distributed subject to the version of the Agreement under which it was received. In addition, after a new version of the Agreement is published, Contributor may elect to distribute the Program (including its Contributions) under the new version. Except as expressly stated in Sections 2(a) and 2(b) above, Recipient receives no rights or licenses to the intellectual property of any Contributor under this Agreement, whether expressly, by implication, estoppel or otherwise. All rights in the Program not expressly granted under this Agreement are reserved.
|
||||
|
||||
This Agreement is governed by the laws of the State of New York and the intellectual property laws of the United States of America. No party to this Agreement will bring a legal action under this Agreement more than one year after the cause of action arose. Each party waives its rights to a jury trial in any resulting litigation.
|
||||
|
||||
===================================================================================================
|
|
@ -1,24 +0,0 @@
|
|||
Apache Tuscany SDO for Java
|
||||
Copyright 2006, 2007 The Apache Software Foundation
|
||||
|
||||
This product includes software developed at
|
||||
The Apache Software Foundation (http://www.apache.org/).
|
||||
|
||||
Unless otherwise indicated, all distribution made available by the Apache Software Foundation
|
||||
is provided to you under the terms and conditions of the Apache License Version 2.0 ("AL").
|
||||
A copy of the AL is provided with this distribution as the LICENSE file present in the
|
||||
root directory, and is also available at http://www.apache.org/licenses/.
|
||||
|
||||
The terms and conditions governing the distribution may refer to the AL or other license
|
||||
agreements, notices or terms and conditions. Some of these other license agreements may
|
||||
include (but are not limited to):
|
||||
|
||||
. Eclipse Public License Version 1.0 (available at http://www.eclipse.org/legal/epl-v10.html)
|
||||
|
||||
It is your obligation to read and accept all such terms and conditions prior to use of the
|
||||
distribution. If term or condition is provided, please contact the Apache Software Foundation
|
||||
to determine what terms and conditions govern that particular distribution.
|
||||
|
||||
This product also includes software developed by the Open Service Oriented Architecture organisation
|
||||
(http://osoa.org). The license for this software may be found in the LICENSE file contained in this
|
||||
distribution.
|
|
@ -1,10 +0,0 @@
|
|||
Apache Tuscany
|
||||
-------------------------------------------
|
||||
|
||||
Welcome to Tuscany! Please read the release notes (RELEASE_NOTES) in this directory for
|
||||
details on the current release.
|
||||
|
||||
Thanks from all of us on the Tuscany team for downloading the package; help
|
||||
us make it better by sending comments to tuscany-user@ws.apache.org.
|
||||
|
||||
|
|
@ -1,33 +0,0 @@
|
|||
DAS - Data Access Services
|
||||
|
||||
Service Data Object(SDO) provides a uniform API for handling different types of data. Data Access Service (DAS)
|
||||
simplifies handling of data when interacting with the back-end data source and frees application developers
|
||||
from dealing with tedious and error-prone transformation between end source types and SDO Data Object Types/properties..
|
||||
|
||||
What's new in Apache Tuscany DAS beta2
|
||||
======================================
|
||||
|
||||
The main purpose of the DAS beta2 release is to fix incompatibilites that were found with SDO 1.0 release.
|
||||
|
||||
The following JIRAs also were fixed on DAS beta2
|
||||
|
||||
- TUSCANY-986 - DAS integration with SDO 2.1 APIs
|
||||
- TUSCANY-961 - DAS: Using deprected SDO method causes Type lookup failure
|
||||
- TUSCANY-1353 - Exception attempting to insert rows using DAS w/DataDirect JDBC driver
|
||||
- TUSCANY-1453 - DAS can't read or write the blob field
|
||||
- TUSCANY-1463 - Support for Clob and Array fields
|
||||
- TUSCANY-1462 - Consistent use of Parameters in Config
|
||||
- TUSCANY-1464 - Wrong query results when SELECT misses PKs
|
||||
- TUSCANY-1465 - Allow passing ResultDescriptor for dynamic Commands
|
||||
- TUSCANY-1720 - Modify sample readmes for - steps to run sample with other databases
|
||||
|
||||
|
||||
|
||||
Details are described below.
|
||||
|
||||
DAS Java beta2 is a superset of previous DAS Java M1,M2 and Beta1 releases.
|
||||
Anything in these previous releases is also in beta2, but beta2 contains features and bug fixes not present on them.
|
||||
|
||||
Compatibility Concerns
|
||||
|
||||
- SDO Static types should be regenerated based on SDO 1.0 tools.
|
|
@ -1,87 +0,0 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!--
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
-->
|
||||
<project>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<parent>
|
||||
<groupId>org.apache.tuscany.das</groupId>
|
||||
<artifactId>tuscany-das</artifactId>
|
||||
<version>1.0-incubating-beta2</version>
|
||||
</parent>
|
||||
|
||||
<groupId>org.apache.tuscany.das.distribution</groupId>
|
||||
<artifactId>tuscany-das-bin</artifactId>
|
||||
<packaging>pom</packaging>
|
||||
<name>Tuscany DAS Distribution (Binary)</name>
|
||||
<description>Tuscany Distribution for DAS.</description>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.apache.tuscany.das</groupId>
|
||||
<artifactId>tuscany-das-rdb</artifactId>
|
||||
<version>${das.version}</version>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>org.apache.tuscany.das.samples</groupId>
|
||||
<artifactId>tuscany-das-sample-company-webapp</artifactId>
|
||||
<version>${das.version}</version>
|
||||
<type>war</type>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>org.apache.tuscany.das.samples</groupId>
|
||||
<artifactId>tuscany-das-sample-customer</artifactId>
|
||||
<version>${das.version}</version>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>org.apache.tuscany.das.samples</groupId>
|
||||
<artifactId>tuscany-das-sample-advanced-webapp</artifactId>
|
||||
<version>${das.version}</version>
|
||||
<type>war</type>
|
||||
</dependency>
|
||||
|
||||
</dependencies>
|
||||
|
||||
<build>
|
||||
<defaultGoal>install</defaultGoal>
|
||||
<finalName>tuscany-das-${das.version}</finalName>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-assembly-plugin</artifactId>
|
||||
<version>2.2-SNAPSHOT</version>
|
||||
<executions>
|
||||
<execution>
|
||||
<phase>package</phase>
|
||||
<goals>
|
||||
<goal>single</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
</executions>
|
||||
<configuration>
|
||||
<descriptors>
|
||||
<descriptor>src/main/assembly/das.xml</descriptor>
|
||||
</descriptors>
|
||||
</configuration>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
</project>
|
|
@ -1,120 +0,0 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!--
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
-->
|
||||
<assembly>
|
||||
<id>bin</id>
|
||||
<includeBaseDirectory>false</includeBaseDirectory>
|
||||
<formats>
|
||||
<format>zip</format>
|
||||
<format>tar.gz</format>
|
||||
</formats>
|
||||
|
||||
<fileSets>
|
||||
<!-- include legal and other files -->
|
||||
<fileSet>
|
||||
<outputDirectory>tuscany-das-${das.version}</outputDirectory>
|
||||
<includes>
|
||||
<include>LICENSE*</include>
|
||||
<include>NOTICE*</include>
|
||||
<include>DISCLAIMER*</include>
|
||||
<include>README*</include>
|
||||
<include>RELEASE_NOTES*</include>
|
||||
</includes>
|
||||
</fileSet>
|
||||
|
||||
<!-- include javadocs -->
|
||||
<!-- this will silient fail and generate empty distribution if javadoc is not available -->
|
||||
<fileSet>
|
||||
<directory>../../rdb/target/apidocs</directory>
|
||||
<outputDirectory>tuscany-das-${das.version}/doc</outputDirectory>
|
||||
</fileSet>
|
||||
|
||||
</fileSets>
|
||||
|
||||
<files>
|
||||
<!-- include readme for companyweb sample -->
|
||||
<file>
|
||||
<source>../../samples/company-webapp/readme.htm</source>
|
||||
<outputDirectory>tuscany-das-${das.version}/samples/company-webapp</outputDirectory>
|
||||
<fileMode>0644</fileMode>
|
||||
</file>
|
||||
<!-- include companyweb sample -->
|
||||
<file>
|
||||
<source>../../samples/company-webapp/target/sample-company-webapp.war</source>
|
||||
<outputDirectory>tuscany-das-${das.version}/samples/company-webapp</outputDirectory>
|
||||
<fileMode>0644</fileMode>
|
||||
</file>
|
||||
|
||||
|
||||
|
||||
<!-- include readme for ajax das sample -->
|
||||
<file>
|
||||
<source>../../samples/advanced-webapp/readme.htm</source>
|
||||
<outputDirectory>tuscany-das-${das.version}/samples/advanced-webapp</outputDirectory>
|
||||
<fileMode>0644</fileMode>
|
||||
</file>
|
||||
<!-- include ajax das sample -->
|
||||
<file>
|
||||
<source>../../samples/advanced-webapp/target/sample-advanced-webapp.war</source>
|
||||
<outputDirectory>tuscany-das-${das.version}/samples/advanced-webapp</outputDirectory>
|
||||
<fileMode>0644</fileMode>
|
||||
</file>
|
||||
|
||||
|
||||
<!-- include readme for customer sample -->
|
||||
<file>
|
||||
<source>../../samples/customer/readme.htm</source>
|
||||
<outputDirectory>tuscany-das-${das.version}/samples/customer</outputDirectory>
|
||||
<fileMode>0644</fileMode>
|
||||
</file>
|
||||
<!-- include ajax das sample -->
|
||||
<file>
|
||||
<source>../../samples/customer/target/sample-customer.jar</source>
|
||||
<outputDirectory>tuscany-das-${das.version}/samples/customer</outputDirectory>
|
||||
<fileMode>0644</fileMode>
|
||||
</file>
|
||||
<file>
|
||||
<source>../../samples/customer/build.xml</source>
|
||||
<outputDirectory>tuscany-das-${das.version}/samples/customer</outputDirectory>
|
||||
<fileMode>0644</fileMode>
|
||||
</file>
|
||||
</files>
|
||||
|
||||
|
||||
<dependencySets>
|
||||
<!-- DAS api impl -->
|
||||
<dependencySet>
|
||||
<outputDirectory>tuscany-das-${das.version}/lib</outputDirectory>
|
||||
<includes>
|
||||
<include>org.apache.tuscany.das:tuscany-das-rdb</include>
|
||||
</includes>
|
||||
<fileMode>0644</fileMode>
|
||||
</dependencySet>
|
||||
|
||||
<!-- DAS Samples - Customer derby dependency-->
|
||||
<dependencySet>
|
||||
<outputDirectory>tuscany-das-${das.version}/samples/customer</outputDirectory>
|
||||
<includes>
|
||||
<include>org.apache.derby:derby</include>
|
||||
</includes>
|
||||
<fileMode>0644</fileMode>
|
||||
</dependencySet>
|
||||
|
||||
</dependencySets>
|
||||
</assembly>
|
|
@ -1,47 +0,0 @@
|
|||
Building the Apache Tuscany DAS beta1
|
||||
=====================================
|
||||
|
||||
Initial Setup
|
||||
-------------
|
||||
|
||||
1) Install J2SE 5.0 SDK, which can be downloaded from
|
||||
http://java.sun.com/j2se/1.5.0/download.jsp. Use version of 1.5.0_06 JDK.
|
||||
|
||||
2) Make sure that your JAVA_HOME environment variable is set to the newly installed
|
||||
JDK location, and that your PATH includes %JAVA_HOME%\bin (windows) or
|
||||
$JAVA_HOME$/bin (unix).
|
||||
|
||||
3) Install Maven 2.0.5, which can be downloaded from http://maven.apache.org/download.html.
|
||||
Make sure that your PATH includes the MVN_HOME/bin directory.
|
||||
|
||||
|
||||
Building
|
||||
--------
|
||||
|
||||
1) Change to the top level directory to Apache Tuscany source distribution.
|
||||
2) Run
|
||||
|
||||
$> mvn
|
||||
|
||||
This will compile Apache Tuscany DAS and run all of the tests in the source
|
||||
distribution.
|
||||
|
||||
Depending on the load of remote Maven 2.0 repositories, you may have
|
||||
to run "mvn" several times utill the required dependencies are
|
||||
all located in your local maven repository. It usually takes some time for
|
||||
maven to download required dependencies in the first build. Once all the
|
||||
dependencies have been downloaded you may use the -o option to run maven
|
||||
in offline mode, for example, 'mvn clean install -o'.
|
||||
|
||||
|
||||
Building the distributions
|
||||
--------------------------
|
||||
|
||||
1) Change to the top level directory to Apache Tuscany source distribution.
|
||||
2) If you haven't run a complete build, please follow the steps above
|
||||
3) Run
|
||||
|
||||
$> mvn -Pdistribution
|
||||
|
||||
This will build the binary and source distribution with .zip and .gz
|
||||
formats in the distribution/target directory.
|
|
@ -1,7 +0,0 @@
|
|||
Apache Tuscany is an effort undergoing incubation at The Apache Software
|
||||
Foundation (ASF), sponsored by the Apache Web Services PMC. Incubation is
|
||||
required of all newly accepted projects until a further review indicates that
|
||||
the infrastructure, communications, and decision making process have stabilized
|
||||
in a manner consistent with other successful ASF projects. While incubation
|
||||
status is not necessarily a reflection of the completeness or stability of the
|
||||
code, it does indicate that the project has yet to be fully endorsed by the ASF.
|
|
@ -1,353 +0,0 @@
|
|||
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
|
||||
1. Definitions.
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following
|
||||
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||
replaced with your own identifying information. (Don't include
|
||||
the brackets!) The text should be enclosed in the appropriate
|
||||
comment syntax for the file format. We also recommend that a
|
||||
file or class name and description of purpose be included on the
|
||||
same "printed page" as the copyright notice for easier
|
||||
identification within third-party archives.
|
||||
|
||||
Copyright [yyyy] [name of copyright owner]
|
||||
|
||||
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
|
||||
limitations under the License.
|
||||
|
||||
===============================================================================================================
|
||||
|
||||
Other components and dependencies under Apache Software License 2.0 :
|
||||
|
||||
log4j-1.2.14.jar - Apache Logging Services
|
||||
derby 10.2.2.0.jar - Apache Derby
|
||||
stax-api-1.0.1.jar - The Streaming API for XML (StAX)
|
||||
wstx-asl-3.2.0.jar - WoodStox StAX implementation
|
||||
standard-1.1.1.jar - The Apache Jackarta Taglibs
|
||||
jstl-1.1.2.jar - The Apache Jackarta Taglibs
|
||||
*.tld - The Apache Jackarta Taglibs
|
||||
|
||||
===============================================================================================================
|
||||
|
||||
|
||||
Apache Tuscany SDO for Java Subcomponents
|
||||
=========================================:
|
||||
|
||||
The Tuscany SDO for Java release includes a number of subcomponents with
|
||||
separate copyright notices and license terms. Your use of the source
|
||||
code for the these subcomponents is subject to the terms and
|
||||
conditions of the following licenses.
|
||||
|
||||
License for the Service Data Objects JavaDoc and Interface Definition files. (tuscany-sdo-api-r2.1-1.0-incubating.jar)
|
||||
|
||||
Permission to copy, make derivative works of, and distribute the Service Data Objects
|
||||
JavaDoc and Interface Definition Files files in any medium without fee or royalty as part
|
||||
of a compliant implementation of the Service Data Objects Specification is hereby granted.
|
||||
The Service Data Objects Specification may be found at any of the following locations:
|
||||
|
||||
http://dev2dev.bea.com/technologies/commonj/index.jsp
|
||||
http://www.ibm.com/developerworks/library/specification/ws-sdo/
|
||||
http://oracle.com/technology/webservices/sca
|
||||
https://www.sdn.sap.com/
|
||||
http://www.xcalia/xdn/specs/sdo
|
||||
|
||||
THE SERVICE DATA OBJECTS SPECIFICATION AND THE JAVADOC AND INTERFACE DEFINITION FILES
|
||||
ARE PROVIDED "AS IS," AND THE AUTHORS MAKE NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, REGARDING THIS
|
||||
SPECIFICATION OR THE JAVADOC AND INTERFACE DEFINITION FILES AND THE IMPLEMENTATION OF THEIR CONTENTS,
|
||||
INCLUDING, BUT NOT LIMITED TO, WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE,
|
||||
NON-INFRINGEMENT OR TITLE. THE AUTHORS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL,
|
||||
INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF OR RELATING TO ANY USE OR DISTRIBUTION OF THE
|
||||
SERVICE DATA OBJECTS SPECIFICATION OR THE JAVADOC OR INTERFACE DEFINTION FILES.
|
||||
|
||||
The name and trademarks of the Authors may NOT be used in any manner, including advertising or
|
||||
publicity pertaining to the Service Component Architecture Specification or its contents without specific,
|
||||
written prior permission. Title to copyright in the Service Data Objects Specification and the
|
||||
JavaDoc and Interface Definition Files will at all times remain with the Authors.
|
||||
|
||||
No other rights are granted by implication, estoppel or otherwise.
|
||||
|
||||
=================================================================================================================
|
||||
|
||||
For the Eclipse EMF components
|
||||
(codegen-2.2.3.jar
|
||||
codegen-ecore-2.2.3.jar
|
||||
common-2.2.3.jar
|
||||
ecore-2.2.3.jar
|
||||
ecore-change-2.2.3.jar
|
||||
ecore-xmi-2.2.3.jar
|
||||
xsd-2.2.3.jar)
|
||||
|
||||
Eclipse Public License - v 1.0
|
||||
|
||||
THE ACCOMPANYING PROGRAM IS PROVIDED UNDER THE TERMS OF THIS ECLIPSE PUBLIC LICENSE ("AGREEMENT"). ANY USE, REPRODUCTION OR DISTRIBUTION OF THE PROGRAM CONSTITUTES RECIPIENT'S ACCEPTANCE OF THIS AGREEMENT.
|
||||
|
||||
1. DEFINITIONS
|
||||
|
||||
"Contribution" means:
|
||||
|
||||
a) in the case of the initial Contributor, the initial code and documentation distributed under this Agreement, and
|
||||
b) in the case of each subsequent Contributor:
|
||||
|
||||
i) changes to the Program, and
|
||||
|
||||
ii) additions to the Program;
|
||||
|
||||
where such changes and/or additions to the Program originate from and are distributed by that particular Contributor. A Contribution 'originates' from a Contributor if it was added to the Program by such Contributor itself or anyone acting on such Contributor's behalf. Contributions do not include additions to the Program which: (i) are separate modules of software distributed in conjunction with the Program under their own license agreement, and (ii) are not derivative works of the Program.
|
||||
|
||||
"Contributor" means any person or entity that distributes the Program.
|
||||
|
||||
"Licensed Patents " mean patent claims licensable by a Contributor which are necessarily infringed by the use or sale of its Contribution alone or when combined with the Program.
|
||||
|
||||
"Program" means the Contributions distributed in accordance with this Agreement.
|
||||
|
||||
"Recipient" means anyone who receives the Program under this Agreement, including all Contributors.
|
||||
|
||||
2. GRANT OF RIGHTS
|
||||
|
||||
a) Subject to the terms of this Agreement, each Contributor hereby grants Recipient a non-exclusive, worldwide, royalty-free copyright license to reproduce, prepare derivative works of, publicly display, publicly perform, distribute and sublicense the Contribution of such Contributor, if any, and such derivative works, in source code and object code form.
|
||||
|
||||
b) Subject to the terms of this Agreement, each Contributor hereby grants Recipient a non-exclusive, worldwide, royalty-free patent license under Licensed Patents to make, use, sell, offer to sell, import and otherwise transfer the Contribution of such Contributor, if any, in source code and object code form. This patent license shall apply to the combination of the Contribution and the Program if, at the time the Contribution is added by the Contributor, such addition of the Contribution causes such combination to be covered by the Licensed Patents. The patent license shall not apply to any other combinations which include the Contribution. No hardware per se is licensed hereunder.
|
||||
|
||||
c) Recipient understands that although each Contributor grants the licenses to its Contributions set forth herein, no assurances are provided by any Contributor that the Program does not infringe the patent or other intellectual property rights of any other entity. Each Contributor disclaims any liability to Recipient for claims brought by any other entity based on infringement of intellectual property rights or otherwise. As a condition to exercising the rights and licenses granted hereunder, each Recipient hereby assumes sole responsibility to secure any other intellectual property rights needed, if any. For example, if a third party patent license is required to allow Recipient to distribute the Program, it is Recipient's responsibility to acquire that license before distributing the Program.
|
||||
|
||||
d) Each Contributor represents that to its knowledge it has sufficient copyright rights in its Contribution, if any, to grant the copyright license set forth in this Agreement.
|
||||
|
||||
3. REQUIREMENTS
|
||||
|
||||
A Contributor may choose to distribute the Program in object code form under its own license agreement, provided that:
|
||||
|
||||
a) it complies with the terms and conditions of this Agreement; and
|
||||
|
||||
b) its license agreement:
|
||||
|
||||
i) effectively disclaims on behalf of all Contributors all warranties and conditions, express and implied, including warranties or conditions of title and non-infringement, and implied warranties or conditions of merchantability and fitness for a particular purpose;
|
||||
|
||||
ii) effectively excludes on behalf of all Contributors all liability for damages, including direct, indirect, special, incidental and consequential damages, such as lost profits;
|
||||
|
||||
iii) states that any provisions which differ from this Agreement are offered by that Contributor alone and not by any other party; and
|
||||
|
||||
iv) states that source code for the Program is available from such Contributor, and informs licensees how to obtain it in a reasonable manner on or through a medium customarily used for software exchange.
|
||||
|
||||
When the Program is made available in source code form:
|
||||
|
||||
a) it must be made available under this Agreement; and
|
||||
|
||||
b) a copy of this Agreement must be included with each copy of the Program.
|
||||
|
||||
Contributors may not remove or alter any copyright notices contained within the Program.
|
||||
|
||||
Each Contributor must identify itself as the originator of its Contribution, if any, in a manner that reasonably allows subsequent Recipients to identify the originator of the Contribution.
|
||||
|
||||
4. COMMERCIAL DISTRIBUTION
|
||||
|
||||
Commercial distributors of software may accept certain responsibilities with respect to end users, business partners and the like. While this license is intended to facilitate the commercial use of the Program, the Contributor who includes the Program in a commercial product offering should do so in a manner which does not create potential liability for other Contributors. Therefore, if a Contributor includes the Program in a commercial product offering, such Contributor ("Commercial Contributor") hereby agrees to defend and indemnify every other Contributor ("Indemnified Contributor") against any losses, damages and costs (collectively "Losses") arising from claims, lawsuits and other legal actions brought by a third party against the Indemnified Contributor to the extent caused by the acts or omissions of such Commercial Contributor in connection with its distribution of the Program in a commercial product offering. The obligations in this section do not apply to any claims or Losses relating to any actual or alleged intellectual property infringement. In order to qualify, an Indemnified Contributor must: a) promptly notify the Commercial Contributor in writing of such claim, and b) allow the Commercial Contributor to control, and cooperate with the Commercial Contributor in, the defense and any related settlement negotiations. The Indemnified Contributor may participate in any such claim at its own expense.
|
||||
|
||||
For example, a Contributor might include the Program in a commercial product offering, Product X. That Contributor is then a Commercial Contributor. If that Commercial Contributor then makes performance claims, or offers warranties related to Product X, those performance claims and warranties are such Commercial Contributor's responsibility alone. Under this section, the Commercial Contributor would have to defend claims against the other Contributors related to those performance claims and warranties, and if a court requires any other Contributor to pay any damages as a result, the Commercial Contributor must pay those damages.
|
||||
|
||||
5. NO WARRANTY
|
||||
|
||||
EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is solely responsible for determining the appropriateness of using and distributing the Program and assumes all risks associated with its exercise of rights under this Agreement , including but not limited to the risks and costs of program errors, compliance with applicable laws, damage to or loss of data, programs or equipment, and unavailability or interruption of operations.
|
||||
|
||||
6. DISCLAIMER OF LIABILITY
|
||||
|
||||
EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
7. GENERAL
|
||||
|
||||
If any provision of this Agreement is invalid or unenforceable under applicable law, it shall not affect the validity or enforceability of the remainder of the terms of this Agreement, and without further action by the parties hereto, such provision shall be reformed to the minimum extent necessary to make such provision valid and enforceable.
|
||||
|
||||
If Recipient institutes patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Program itself (excluding combinations of the Program with other software or hardware) infringes such Recipient's patent(s), then such Recipient's rights granted under Section 2(b) shall terminate as of the date such litigation is filed.
|
||||
|
||||
All Recipient's rights under this Agreement shall terminate if it fails to comply with any of the material terms or conditions of this Agreement and does not cure such failure in a reasonable period of time after becoming aware of such noncompliance. If all Recipient's rights under this Agreement terminate, Recipient agrees to cease use and distribution of the Program as soon as reasonably practicable. However, Recipient's obligations under this Agreement and any licenses granted by Recipient relating to the Program shall continue and survive.
|
||||
|
||||
Everyone is permitted to copy and distribute copies of this Agreement, but in order to avoid inconsistency the Agreement is copyrighted and may only be modified in the following manner. The Agreement Steward reserves the right to publish new versions (including revisions) of this Agreement from time to time. No one other than the Agreement Steward has the right to modify this Agreement. The Eclipse Foundation is the initial Agreement Steward. The Eclipse Foundation may assign the responsibility to serve as the Agreement Steward to a suitable separate entity. Each new version of the Agreement will be given a distinguishing version number. The Program (including Contributions) may always be distributed subject to the version of the Agreement under which it was received. In addition, after a new version of the Agreement is published, Contributor may elect to distribute the Program (including its Contributions) under the new version. Except as expressly stated in Sections 2(a) and 2(b) above, Recipient receives no rights or licenses to the intellectual property of any Contributor under this Agreement, whether expressly, by implication, estoppel or otherwise. All rights in the Program not expressly granted under this Agreement are reserved.
|
||||
|
||||
This Agreement is governed by the laws of the State of New York and the intellectual property laws of the United States of America. No party to this Agreement will bring a legal action under this Agreement more than one year after the cause of action arose. Each party waives its rights to a jury trial in any resulting litigation.
|
||||
|
||||
===================================================================================================
|
|
@ -1,24 +0,0 @@
|
|||
Apache Tuscany SDO for Java
|
||||
Copyright 2006, 2007 The Apache Software Foundation
|
||||
|
||||
This product includes software developed at
|
||||
The Apache Software Foundation (http://www.apache.org/).
|
||||
|
||||
Unless otherwise indicated, all distribution made available by the Apache Software Foundation
|
||||
is provided to you under the terms and conditions of the Apache License Version 2.0 ("AL").
|
||||
A copy of the AL is provided with this distribution as the LICENSE file present in the
|
||||
root directory, and is also available at http://www.apache.org/licenses/.
|
||||
|
||||
The terms and conditions governing the distribution may refer to the AL or other license
|
||||
agreements, notices or terms and conditions. Some of these other license agreements may
|
||||
include (but are not limited to):
|
||||
|
||||
. Eclipse Public License Version 1.0 (available at http://www.eclipse.org/legal/epl-v10.html)
|
||||
|
||||
It is your obligation to read and accept all such terms and conditions prior to use of the
|
||||
distribution. If term or condition is provided, please contact the Apache Software Foundation
|
||||
to determine what terms and conditions govern that particular distribution.
|
||||
|
||||
This product also includes software developed by the Open Service Oriented Architecture organisation
|
||||
(http://osoa.org). The license for this software may be found in the LICENSE file contained in this
|
||||
distribution.
|
|
@ -1,10 +0,0 @@
|
|||
Apache Tuscany
|
||||
-------------------------------------------
|
||||
|
||||
Welcome to Tuscany! Please read the release notes (RELEASE_NOTES) in this directory for
|
||||
details on the current release.
|
||||
|
||||
Thanks from all of us on the Tuscany team for downloading the package; help
|
||||
us make it better by sending comments to tuscany-user@ws.apache.org.
|
||||
|
||||
|
|
@ -1,33 +0,0 @@
|
|||
DAS - Data Access Services
|
||||
|
||||
Service Data Object(SDO) provides a uniform API for handling different types of data. Data Access Service (DAS)
|
||||
simplifies handling of data when interacting with the back-end data source and frees application developers
|
||||
from dealing with tedious and error-prone transformation between end source types and SDO Data Object Types/properties..
|
||||
|
||||
What's new in Apache Tuscany DAS beta2
|
||||
======================================
|
||||
|
||||
The main purpose of the DAS beta2 release is to fix incompatibilites that were found with SDO 1.0 release.
|
||||
|
||||
The following JIRAs also were fixed on DAS beta2
|
||||
|
||||
- TUSCANY-986 - DAS integration with SDO 2.1 APIs
|
||||
- TUSCANY-961 - DAS: Using deprected SDO method causes Type lookup failure
|
||||
- TUSCANY-1353 - Exception attempting to insert rows using DAS w/DataDirect JDBC driver
|
||||
- TUSCANY-1453 - DAS can't read or write the blob field
|
||||
- TUSCANY-1463 - Support for Clob and Array fields
|
||||
- TUSCANY-1462 - Consistent use of Parameters in Config
|
||||
- TUSCANY-1464 - Wrong query results when SELECT misses PKs
|
||||
- TUSCANY-1465 - Allow passing ResultDescriptor for dynamic Commands
|
||||
- TUSCANY-1720 - Modify sample readmes for - steps to run sample with other databases
|
||||
|
||||
|
||||
|
||||
Details are described below.
|
||||
|
||||
DAS Java beta2 is a superset of previous DAS Java M1,M2 and Beta1 releases.
|
||||
Anything in these previous releases is also in beta2, but beta2 contains features and bug fixes not present on them.
|
||||
|
||||
Compatibility Concerns
|
||||
|
||||
- SDO Static types should be regenerated based on SDO 1.0 tools.
|
|
@ -1,66 +0,0 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!--
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
-->
|
||||
<project>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<parent>
|
||||
<groupId>org.apache.tuscany.das</groupId>
|
||||
<artifactId>tuscany-das</artifactId>
|
||||
<version>1.0-incubating-beta2</version>
|
||||
</parent>
|
||||
|
||||
<groupId>org.apache.tuscany.das.distribution</groupId>
|
||||
<artifactId>tuscany-das-src</artifactId>
|
||||
<packaging>pom</packaging>
|
||||
<name>Tuscany DAS Distribution (Source)</name>
|
||||
<description>Tuscany Distribution for DAS.</description>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.apache.tuscany.das</groupId>
|
||||
<artifactId>tuscany-das-rdb</artifactId>
|
||||
<version>${das.version}</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
|
||||
<build>
|
||||
<defaultGoal>install</defaultGoal>
|
||||
<finalName>tuscany-das-${das.version}</finalName>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-assembly-plugin</artifactId>
|
||||
<version>2.2-SNAPSHOT</version>
|
||||
<executions>
|
||||
<execution>
|
||||
<phase>package</phase>
|
||||
<goals>
|
||||
<goal>single</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
</executions>
|
||||
<configuration>
|
||||
<descriptors>
|
||||
<descriptor>src/main/assembly/src.xml</descriptor>
|
||||
</descriptors>
|
||||
</configuration>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
</project>
|
|
@ -1,63 +0,0 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!--
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
-->
|
||||
|
||||
<assembly>
|
||||
<id>src</id>
|
||||
<baseDirectory>tuscany-das-${das.version}-src</baseDirectory>
|
||||
<formats>
|
||||
<format>zip</format>
|
||||
<format>tar.gz</format>
|
||||
</formats>
|
||||
<fileSets>
|
||||
<fileSet>
|
||||
<includes>
|
||||
<include>BUILDING*</include>
|
||||
<include>LICENSE*</include>
|
||||
<include>NOTICE*</include>
|
||||
<include>DISCLAIMER*</include>
|
||||
<include>README*</include>
|
||||
<include>RELEASE_NOTES*</include>
|
||||
<include>pom.xml</include>
|
||||
</includes>
|
||||
<useDefaultExcludes>true</useDefaultExcludes>
|
||||
</fileSet>
|
||||
<fileSet>
|
||||
<directory>../../</directory>
|
||||
<outputDirectory></outputDirectory>
|
||||
<useDefaultExcludes>true</useDefaultExcludes>
|
||||
|
||||
<lineEnding>keep</lineEnding>
|
||||
<includes>
|
||||
<include>**/*.*</include>
|
||||
</includes>
|
||||
<excludes>
|
||||
<exclude>**/ldap/**</exclude>
|
||||
<exclude>**/target/**</exclude>
|
||||
<exclude>**/dastest/**</exclude>
|
||||
<exclude>**/.settings/**</exclude>
|
||||
<exclude>**/**.mdl</exclude>
|
||||
<exclude>**/derby.log</exclude>
|
||||
<exclude>**/.project</exclude>
|
||||
<exclude>**/.classpath</exclude>
|
||||
</excludes>
|
||||
<fileMode>0644</fileMode>
|
||||
</fileSet>
|
||||
</fileSets>
|
||||
</assembly>
|
|
@ -1,157 +0,0 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!--
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
-->
|
||||
<project>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<parent>
|
||||
<groupId>org.apache.tuscany</groupId>
|
||||
<artifactId>parent</artifactId>
|
||||
<version>2-incubating</version>
|
||||
</parent>
|
||||
<groupId>org.apache.tuscany.das</groupId>
|
||||
<artifactId>tuscany-das</artifactId>
|
||||
<version>1.0-incubating-beta2</version>
|
||||
<packaging>pom</packaging>
|
||||
<name>Apache Tuscany DAS Implementation project</name>
|
||||
|
||||
<scm>
|
||||
<connection>scm:svn:http://svn.apache.org/repos/asf/incubator/tuscany/java/das</connection>
|
||||
<developerConnection>scm:svn:https://svn.apache.org/repos/asf/incubator/tuscany/java/das</developerConnection>
|
||||
<url>http://svn.apache.org/repos/asf/incubator/tuscany/java/das/</url>
|
||||
</scm>
|
||||
|
||||
<properties>
|
||||
<das.version>1.0-incubating-beta2</das.version>
|
||||
<sdo.version>1.0-incubating</sdo.version>
|
||||
</properties>
|
||||
|
||||
<!-- definition of repositories where the parent pom can be found -->
|
||||
<repositories>
|
||||
<repository>
|
||||
<id>apache.snapshots</id>
|
||||
<name>Apache Snapshot Repository</name>
|
||||
<url>http://people.apache.org/repo/m2-snapshot-repository</url>
|
||||
<releases>
|
||||
<enabled>false</enabled>
|
||||
</releases>
|
||||
<snapshots>
|
||||
<enabled>true</enabled>
|
||||
</snapshots>
|
||||
</repository>
|
||||
<repository>
|
||||
<id>apache.incubator</id>
|
||||
<name>Apache Incubator Repository</name>
|
||||
<url>http://people.apache.org/repo/m2-incubating-repository/</url>
|
||||
<releases>
|
||||
<enabled>true</enabled>
|
||||
</releases>
|
||||
<snapshots>
|
||||
<enabled>false</enabled>
|
||||
</snapshots>
|
||||
</repository>
|
||||
</repositories>
|
||||
|
||||
<dependencyManagement>
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.apache.tuscany.sdo</groupId>
|
||||
<artifactId>tuscany-sdo-impl</artifactId>
|
||||
<version>${sdo.version}</version>
|
||||
<scope>compile</scope>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>junit</groupId>
|
||||
<artifactId>junit</artifactId>
|
||||
<version>3.8.1</version>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
</dependencyManagement>
|
||||
|
||||
<build>
|
||||
<defaultGoal>install</defaultGoal>
|
||||
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-compiler-plugin</artifactId>
|
||||
<configuration>
|
||||
<source>1.4</source>
|
||||
<target>1.4</target>
|
||||
</configuration>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-surefire-plugin</artifactId>
|
||||
<configuration>
|
||||
<includes>
|
||||
<include>**/*TestCase.java</include>
|
||||
</includes>
|
||||
<reportFormat>brief</reportFormat>
|
||||
<useFile>false</useFile>
|
||||
</configuration>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-jar-plugin</artifactId>
|
||||
<configuration>
|
||||
<archive>
|
||||
<manifestEntries>
|
||||
<Extension-Name>${project.artifactId}</Extension-Name>
|
||||
<Specification-Title>${name}</Specification-Title>
|
||||
<Specification-Vendor>The Apache Software Foundation</Specification-Vendor>
|
||||
<Specification-Version>${version}</Specification-Version>
|
||||
<Implementation-Title>${name}</Implementation-Title>
|
||||
<Implementation-Vendor-Id>org.apache</Implementation-Vendor-Id>
|
||||
<Implementation-Vendor>The Apache Software Foundation</Implementation-Vendor>
|
||||
<Implementation-Version>${version}</Implementation-Version>
|
||||
</manifestEntries>
|
||||
</archive>
|
||||
</configuration>
|
||||
<version>2.1</version>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
|
||||
<profiles>
|
||||
<profile>
|
||||
<id>default</id>
|
||||
<activation>
|
||||
<activeByDefault>true</activeByDefault>
|
||||
</activation>
|
||||
|
||||
<modules>
|
||||
<module>rdb</module>
|
||||
<module>samples</module>
|
||||
</modules>
|
||||
</profile>
|
||||
|
||||
<profile>
|
||||
<id>distribution</id>
|
||||
<modules>
|
||||
<module>rdb</module>
|
||||
<module>samples</module>
|
||||
<module>distribution/binary</module>
|
||||
<module>distribution/source</module>
|
||||
</modules>
|
||||
</profile>
|
||||
</profiles>
|
||||
|
||||
</project>
|
|
@ -1,253 +0,0 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!--
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
-->
|
||||
<project>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<parent>
|
||||
<groupId>org.apache.tuscany.das</groupId>
|
||||
<artifactId>tuscany-das</artifactId>
|
||||
<version>1.0-incubating-beta2</version>
|
||||
</parent>
|
||||
|
||||
<artifactId>tuscany-das-rdb</artifactId>
|
||||
<name>Tuscany DAS for Relational Databases</name>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.apache.tuscany.sdo</groupId>
|
||||
<artifactId>tuscany-sdo-impl</artifactId>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>stax</groupId>
|
||||
<artifactId>stax-api</artifactId>
|
||||
<version>1.0.1</version>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>junit</groupId>
|
||||
<artifactId>junit</artifactId>
|
||||
<version>3.8.1</version>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>org.apache.derby</groupId>
|
||||
<artifactId>derby</artifactId>
|
||||
<version>10.2.2.0</version>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>log4j</groupId>
|
||||
<artifactId>log4j</artifactId>
|
||||
<version>1.2.14</version>
|
||||
<scope>compile</scope>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
|
||||
<build>
|
||||
<defaultGoal>install</defaultGoal>
|
||||
</build>
|
||||
|
||||
|
||||
<profiles>
|
||||
<profile>
|
||||
<id>default</id>
|
||||
<activation>
|
||||
<activeByDefault>true</activeByDefault>
|
||||
</activation>
|
||||
|
||||
<build>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.apache.tuscany.sdo</groupId>
|
||||
<artifactId>tuscany-sdo-plugin</artifactId>
|
||||
<version>${sdo.version}</version>
|
||||
<executions>
|
||||
<execution>
|
||||
<id>config</id>
|
||||
<configuration>
|
||||
<schemaFile>${basedir}/src/main/resources/config.xsd</schemaFile>
|
||||
<noNotification>true</noNotification>
|
||||
<noUnsettable>true</noUnsettable>
|
||||
</configuration>
|
||||
<goals>
|
||||
<goal>generate</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
<execution>
|
||||
<id>companynoid</id>
|
||||
<configuration>
|
||||
<schemaFile>${basedir}/src/test/resources/companynoid.xsd</schemaFile>
|
||||
<noUnsettable>true</noUnsettable>
|
||||
</configuration>
|
||||
<goals>
|
||||
<goal>generate</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
<execution>
|
||||
<id>company</id>
|
||||
<configuration>
|
||||
<schemaFile>${basedir}/src/test/resources/company.xsd</schemaFile>
|
||||
<noUnsettable>true</noUnsettable>
|
||||
</configuration>
|
||||
<goals>
|
||||
<goal>generate</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
<execution>
|
||||
<id>customer</id>
|
||||
<configuration>
|
||||
<schemaFile>${basedir}/src/test/resources/customer.xsd</schemaFile>
|
||||
<noUnsettable>true</noUnsettable>
|
||||
</configuration>
|
||||
<goals>
|
||||
<goal>generate</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
</executions>
|
||||
</plugin>
|
||||
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-surefire-plugin</artifactId>
|
||||
<configuration>
|
||||
<includes>
|
||||
<include>**/*AllTestsDerby.java</include>
|
||||
</includes>
|
||||
</configuration>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
|
||||
</profile>
|
||||
|
||||
<profile>
|
||||
<id>distribution</id>
|
||||
|
||||
<build>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.apache.tuscany.sdo</groupId>
|
||||
<artifactId>tuscany-sdo-plugin</artifactId>
|
||||
<version>${sdo.version}</version>
|
||||
<executions>
|
||||
<execution>
|
||||
<id>config</id>
|
||||
<configuration>
|
||||
<schemaFile>${basedir}/src/main/resources/config.xsd</schemaFile>
|
||||
<noNotification>true</noNotification>
|
||||
<noUnsettable>true</noUnsettable>
|
||||
</configuration>
|
||||
<goals>
|
||||
<goal>generate</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
<execution>
|
||||
<id>companynoid</id>
|
||||
<configuration>
|
||||
<schemaFile>${basedir}/src/test/resources/companynoid.xsd</schemaFile>
|
||||
<noUnsettable>true</noUnsettable>
|
||||
</configuration>
|
||||
<goals>
|
||||
<goal>generate</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
<execution>
|
||||
<id>company</id>
|
||||
<configuration>
|
||||
<schemaFile>${basedir}/src/test/resources/company.xsd</schemaFile>
|
||||
<noUnsettable>true</noUnsettable>
|
||||
</configuration>
|
||||
<goals>
|
||||
<goal>generate</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
<execution>
|
||||
<id>customer</id>
|
||||
<configuration>
|
||||
<schemaFile>${basedir}/src/test/resources/customer.xsd</schemaFile>
|
||||
<noUnsettable>true</noUnsettable>
|
||||
</configuration>
|
||||
<goals>
|
||||
<goal>generate</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
</executions>
|
||||
</plugin>
|
||||
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-surefire-plugin</artifactId>
|
||||
<configuration>
|
||||
<includes>
|
||||
<include>**/*AllTestsDerby.java</include>
|
||||
</includes>
|
||||
</configuration>
|
||||
</plugin>
|
||||
|
||||
|
||||
<!-- Generates JavaDoc for DAS RDB API -->
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-javadoc-plugin</artifactId>
|
||||
<configuration>
|
||||
<version>2.0</version>
|
||||
<quiet>true</quiet>
|
||||
<maven.javadoc.failonerror>0</maven.javadoc.failonerror>
|
||||
<maven.javadoc.warningsreport>false</maven.javadoc.warningsreport>
|
||||
</configuration>
|
||||
<executions>
|
||||
<execution>
|
||||
<id>package</id>
|
||||
<phase>package</phase>
|
||||
<goals>
|
||||
<goal>jar</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
</executions>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
|
||||
</profile>
|
||||
</profiles>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
</project>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
|
@ -1,138 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.io.OutputStream;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.ResultDescriptor;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
/**
|
||||
* A Command is used to execute a read or write to a database
|
||||
*/
|
||||
public interface Command {
|
||||
|
||||
/**
|
||||
* Performs the function defined by the command
|
||||
*/
|
||||
void execute();
|
||||
|
||||
/**
|
||||
* Performs the function defined by the command and return the results in the root DataObject
|
||||
*
|
||||
* @return the root DataObject
|
||||
*/
|
||||
DataObject executeQuery();
|
||||
|
||||
/**
|
||||
* Sets the value of the associated Parameter
|
||||
*
|
||||
* @param index
|
||||
* the index of the Parameter
|
||||
* @param value
|
||||
* the value for the Parameter
|
||||
*/
|
||||
void setParameter(int index, Object value);
|
||||
|
||||
/**
|
||||
* Returns the value of the associated Parameter
|
||||
*
|
||||
* @param index
|
||||
* the index of the Parameter
|
||||
* @return the value of the Parameter
|
||||
*/
|
||||
Object getParameter(int index);
|
||||
|
||||
/**
|
||||
*
|
||||
* @param name Name of parameter - should match exact name of database table column
|
||||
* as appearing in Command
|
||||
* @param value
|
||||
* the value of the parameter
|
||||
*/
|
||||
void setParameter(String name, Object value);
|
||||
|
||||
/**
|
||||
*
|
||||
* @param name
|
||||
* the name of the parameter - should match exact name of database table column
|
||||
* @return the value of the parameter
|
||||
*/
|
||||
Object getParameter(String name);
|
||||
|
||||
/**
|
||||
* Returns the value of the database-generated key. This method is specific
|
||||
* to an "insert" command and will be valid only after the command has
|
||||
* been executed.
|
||||
*
|
||||
* @return the generated key
|
||||
*/
|
||||
int getGeneratedKey();
|
||||
|
||||
/**
|
||||
* Allow set of ResultDescriptor when command is created on-the-fly
|
||||
* @param resultDescriptorList
|
||||
*/
|
||||
void setResultDescriptors(List resultDescriptorList);
|
||||
|
||||
List getResultDescriptors();
|
||||
|
||||
/**
|
||||
* Add/replace based on columnIndex (>=0)embedded in resultDescriptor else add at end
|
||||
* @param resultDescriptor
|
||||
*/
|
||||
void addResultDescriptor(ResultDescriptor resultDescriptor);
|
||||
|
||||
/**
|
||||
* remove ResultDescriptor at given columnIndex(>=0) and return same. If not
|
||||
* present return null. For -ve index, return null
|
||||
* @param columnIndex
|
||||
* @return
|
||||
*/
|
||||
ResultDescriptor removeResultDescriptor(int columnIndex);
|
||||
|
||||
/**
|
||||
* Remove resultDescriptor only if matched for index(>=0), name, type, schema
|
||||
* name and table name and return same, else return null For -ve index, ignore
|
||||
* index and if unique match for rest of the attriutes, remove/return, if multiple
|
||||
* matches found, throw RuntimeException
|
||||
* @param resultDescriptor
|
||||
* @return
|
||||
*/
|
||||
ResultDescriptor removeResultDescriptor(ResultDescriptor resultDescriptor);
|
||||
|
||||
/**
|
||||
* Return resultDescriptor if exact match for columnIndex(>=0) found
|
||||
* else return null;
|
||||
*
|
||||
* @param columnIndex
|
||||
* @return
|
||||
*/
|
||||
ResultDescriptor getResultDescriptor(int columnIndex);
|
||||
|
||||
/**
|
||||
* Utility method
|
||||
* @param ostrm
|
||||
* @throws IOException
|
||||
*/
|
||||
void printResultDescriptors(OutputStream ostrm) throws IOException;
|
||||
}
|
|
@ -1,287 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb;
|
||||
|
||||
import java.io.InputStream;
|
||||
import java.util.Vector;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Column;
|
||||
import org.apache.tuscany.das.rdb.config.Command;
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.ConfigFactory;
|
||||
import org.apache.tuscany.das.rdb.config.Parameters;
|
||||
import org.apache.tuscany.das.rdb.config.Relationship;
|
||||
import org.apache.tuscany.das.rdb.config.Table;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.util.ConfigUtil;
|
||||
import org.apache.tuscany.das.rdb.impl.ParametersExtendedImpl;
|
||||
|
||||
/**
|
||||
* A ConfigHelper is used as an aid in programmatic construction of Config instances.
|
||||
* Manual contrution fo COnfig is an alternative to providing needed configuration
|
||||
* information in an XML file
|
||||
*
|
||||
*/
|
||||
public class ConfigHelper {
|
||||
|
||||
private Config config;
|
||||
|
||||
private MappingWrapper configWrapper;
|
||||
|
||||
private ConfigFactory factory = ConfigFactory.INSTANCE;
|
||||
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
public ConfigHelper() {
|
||||
config = factory.createConfig();
|
||||
configWrapper = new MappingWrapper(config);
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructor that receives a Config stream
|
||||
* This is usefull to extend a config file
|
||||
* @param configStream The configuration stream
|
||||
*/
|
||||
public ConfigHelper(InputStream configStream) {
|
||||
this.config = ConfigUtil.loadConfig(configStream);
|
||||
configWrapper = new MappingWrapper(config);
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructor that receives a Config object
|
||||
* @param config The configuration object
|
||||
*/
|
||||
public ConfigHelper(Config config) {
|
||||
this.config = config;
|
||||
configWrapper = new MappingWrapper(config);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add PK information
|
||||
* @param columnName The column to be taken as PK
|
||||
*/
|
||||
public void addPrimaryKey(String columnName) {
|
||||
configWrapper.addPrimaryKey(columnName);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add relationship information
|
||||
* @param parentName
|
||||
* @param childName
|
||||
* @return
|
||||
*/
|
||||
public Relationship addRelationship(String parentName, String childName) {
|
||||
return configWrapper.addRelationship(parentName, childName);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add relationship information
|
||||
* @param parentNames
|
||||
* @param childNames
|
||||
* @return
|
||||
*/
|
||||
public Relationship addRelationship(Vector parentNames, Vector childNames) {
|
||||
return configWrapper.addRelationship(parentNames, childNames);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add table information
|
||||
* @param name
|
||||
* @param typeName
|
||||
* @return
|
||||
*/
|
||||
public Table addTable(String name, String typeName) {
|
||||
return configWrapper.addTable(name, typeName);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add table information with schema information
|
||||
* @param name
|
||||
* @param schemaName
|
||||
* @param typeName
|
||||
* @return
|
||||
*/
|
||||
public Table addTable(String name, String schemaName, String typeName) {
|
||||
return configWrapper.addTable(name, schemaName, typeName);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add column information
|
||||
* @param table
|
||||
* @param columnName
|
||||
* @param propertyName
|
||||
* @return
|
||||
*/
|
||||
public Column addColumn(Table table, String columnName, String propertyName) {
|
||||
return configWrapper.addColumn(table, columnName, propertyName);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add an update statement for a given table
|
||||
* @param table
|
||||
* @param statement
|
||||
* @param parameters String - names separated with space
|
||||
*/
|
||||
public void addUpdateStatement(Table table, String statement, String parameters) {
|
||||
ParametersExtendedImpl parametersExtendedImpl = new ParametersExtendedImpl();
|
||||
parametersExtendedImpl.addParameters(ParametersExtendedImpl.getParameters(parameters));
|
||||
configWrapper.addUpdateStatement(table, statement, parametersExtendedImpl);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add an update statement for a given table
|
||||
* @param table
|
||||
* @param statement
|
||||
* @param parameters <Parameters>
|
||||
*/
|
||||
public void addUpdateStatement(Table table, String statement, Parameters parameters) {
|
||||
configWrapper.addUpdateStatement(table, statement, parameters);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add create statement for a given table
|
||||
* @param table
|
||||
* @param statement
|
||||
* @param parameters String - names separated with space
|
||||
*/
|
||||
public void addCreateStatement(Table table, String statement, String parameters) {
|
||||
ParametersExtendedImpl parametersExtendedImpl = new ParametersExtendedImpl();
|
||||
parametersExtendedImpl.addParameters(ParametersExtendedImpl.getParameters(parameters));
|
||||
configWrapper.addCreateStatement(table, statement, parametersExtendedImpl);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add create statement for a given table
|
||||
* @param table
|
||||
* @param statement
|
||||
* @param parameters <Parameters>
|
||||
*/
|
||||
public void addCreateStatement(Table table, String statement, Parameters parameters) {
|
||||
configWrapper.addCreateStatement(table, statement, parameters);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add delete statement for a given table
|
||||
* @param table
|
||||
* @param statement
|
||||
* @param parameters String - names separated with space
|
||||
*/
|
||||
public void addDeleteStatement(Table table, String statement, String parameters) {
|
||||
ParametersExtendedImpl parametersExtendedImpl = new ParametersExtendedImpl();
|
||||
parametersExtendedImpl.addParameters(ParametersExtendedImpl.getParameters(parameters));
|
||||
configWrapper.addDeleteStatement(table, statement, parametersExtendedImpl);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add delete statement for a given table
|
||||
* @param table
|
||||
* @param statement
|
||||
* @param parameters <Parameters>
|
||||
*/
|
||||
public void addDeleteStatement(Table table, String statement, Parameters parameters) {
|
||||
configWrapper.addDeleteStatement(table, statement, parameters);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add datasource connection information
|
||||
* @param dataSourceName
|
||||
*/
|
||||
public void addConnectionInfo(String dataSourceName) {
|
||||
configWrapper.addConnectionInfo(dataSourceName, true);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add datasource connection information and flag about using managed transactions
|
||||
* @param dataSourceName
|
||||
* @param managedtx
|
||||
*/
|
||||
public void addConnectionInfo(String dataSourceName, boolean managedtx) {
|
||||
configWrapper.addConnectionInfo(dataSourceName, managedtx);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add driver manager connection information
|
||||
* @param driverClass
|
||||
* @param databaseURL
|
||||
* @param user
|
||||
* @param password
|
||||
* @param loginTimeout
|
||||
*/
|
||||
public void addConnectionInfo(String driverClass, String databaseURL, String user, String password, int loginTimeout) {
|
||||
configWrapper.addConnectionInfo(driverClass, databaseURL, user, password, loginTimeout);
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the data object model
|
||||
* @param dataObjectModel
|
||||
*/
|
||||
public void setDataObjectModel(String dataObjectModel) {
|
||||
configWrapper.getConfig().setDataObjectModel(dataObjectModel);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a select command
|
||||
* @param name
|
||||
* @param sql
|
||||
* @return
|
||||
*/
|
||||
public Command addSelectCommand(String name, String sql) {
|
||||
return configWrapper.addCommand(name, sql, "select");
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a update command
|
||||
* @param name
|
||||
* @param sql
|
||||
* @return
|
||||
*/
|
||||
public Command addUpdateCommand(String name, String sql) {
|
||||
return configWrapper.addCommand(name, sql, "update");
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a insert command
|
||||
* @param name
|
||||
* @param sql
|
||||
* @return
|
||||
*/
|
||||
public Command addInsertCommand(String name, String sql) {
|
||||
return configWrapper.addCommand(name, sql, "insert");
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a delete command
|
||||
* @param name
|
||||
* @param sql
|
||||
* @return
|
||||
*/
|
||||
public Command addDeleteCommand(String name, String sql) {
|
||||
return configWrapper.addCommand(name, sql, "delete");
|
||||
}
|
||||
|
||||
/**
|
||||
* Get a reference to the config object
|
||||
* @return
|
||||
*/
|
||||
public Config getConfig() {
|
||||
return config;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,54 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb;
|
||||
|
||||
/**
|
||||
* A lightweight Table-column <--> DataObject-property converter framework. Converters
|
||||
* allow a user to insert a transformation between a column value
|
||||
* and is destination DataObject property value. For example, by default, a VARCHAR
|
||||
* column will be represented as a String in its corresponding
|
||||
* DataObject property. A user could insert a converter that transforms the the VARCHAR
|
||||
* value to an Integer. If this is done then although the column
|
||||
* returns character data, the DataObject property will be an Integer
|
||||
*
|
||||
*
|
||||
*/
|
||||
public interface Converter {
|
||||
|
||||
/**
|
||||
* Transform the columnData object to a new value and possibly
|
||||
* new type. This should be the invers operation of #getColumnValue
|
||||
*
|
||||
* @param columnData
|
||||
* The column value to transorm
|
||||
* @return Returns the transformed value
|
||||
*/
|
||||
Object getPropertyValue(Object columnData);
|
||||
|
||||
/**
|
||||
* Transform the columnData object to a new value and possibly new
|
||||
* type. This should be the invers operation of #getPropertyValue
|
||||
*
|
||||
* @param propertyData
|
||||
* The property value to transform
|
||||
* @return Returns the transformed value
|
||||
*/
|
||||
Object getColumnValue(Object propertyData);
|
||||
|
||||
}
|
|
@ -1,67 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb;
|
||||
|
||||
import org.apache.tuscany.das.rdb.impl.DASFactoryImpl;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
/**
|
||||
* A CommandGroup represents a set of {@link Command} and single {@link ApplyChangesCommand}
|
||||
* that are created from a common config file.
|
||||
*
|
||||
*/
|
||||
public interface DAS {
|
||||
|
||||
DASFactory FACTORY = new DASFactoryImpl();
|
||||
|
||||
/**
|
||||
* The change history is scanned and modifications to the graph of data objects are flushed to the database.
|
||||
*
|
||||
* @param root
|
||||
* the topmost containing data object
|
||||
*/
|
||||
void applyChanges(DataObject root);
|
||||
|
||||
/**
|
||||
* Gets the named command from this factory's inventory
|
||||
*
|
||||
* @param name
|
||||
* The identifying name of the requested command
|
||||
* @return Returns the identified command
|
||||
*/
|
||||
Command getCommand(String name);
|
||||
|
||||
/**
|
||||
* If the CommandGroup is managing connections then this method must be called
|
||||
* when the client is done with the instance.
|
||||
*
|
||||
*/
|
||||
void releaseResources();
|
||||
|
||||
/**
|
||||
* Creates a Command based on the provided SQL statement
|
||||
*
|
||||
* @param sql
|
||||
* The SQL statement
|
||||
* @return returns a Command instance
|
||||
*/
|
||||
Command createCommand(String sql);
|
||||
|
||||
}
|
|
@ -1,74 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb;
|
||||
|
||||
import java.io.InputStream;
|
||||
import java.sql.Connection;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
|
||||
/**
|
||||
* A DASFactory produces {@link DAS} instances.
|
||||
*/
|
||||
public interface DASFactory {
|
||||
|
||||
/**
|
||||
* Creates a DAS based on the provided config file stream
|
||||
*
|
||||
* @param configStream
|
||||
* A stream over a DAS config file
|
||||
* @return returns a DAS instance
|
||||
*/
|
||||
DAS createDAS(InputStream configStream);
|
||||
|
||||
/**
|
||||
* Creates a DAS based on the provide config file stream and connection
|
||||
* @param configStream
|
||||
* @param connection
|
||||
* @return
|
||||
*/
|
||||
DAS createDAS(InputStream configStream, Connection connection);
|
||||
|
||||
/**
|
||||
* Creates a DAS based on the provided config
|
||||
*
|
||||
* @param config
|
||||
* A DAS config object
|
||||
* @return returns a DAS instance
|
||||
*/
|
||||
DAS createDAS(Config config);
|
||||
|
||||
/**
|
||||
* Creates a DAS based on the provided config and connection
|
||||
* @param config
|
||||
* @param connection
|
||||
* @return
|
||||
*/
|
||||
DAS createDAS(Config config, Connection connection);
|
||||
|
||||
/**
|
||||
* Creates a DAS based on the provided connection
|
||||
* @param connection
|
||||
* @return
|
||||
*/
|
||||
DAS createDAS(Connection connection);
|
||||
|
||||
|
||||
}
|
||||
|
|
@ -1,64 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
/**
|
||||
* An iterator-like interface to conveniently move through chunks of data. The
|
||||
* idea is that a Pager works with a read Command. The read command
|
||||
* returns a large amount of data and the client wants to work with chunks
|
||||
* of it at a time. So the Pager is created on the command and each call to
|
||||
* next returns the next chunk of data. This is done completely disconnected.
|
||||
* No cursor is maintained between calls to #next.
|
||||
*
|
||||
* TODO - This is very preliminary. We need to look at this interface
|
||||
* in the context of disonnected scenarios such as a web app. The Pager instance
|
||||
* will probably be saved in session so it must be very light and cannot
|
||||
* reference a connection. Also, we probably need to define a factory or add a
|
||||
* method to set page size.
|
||||
*
|
||||
*
|
||||
*/
|
||||
public interface Pager {
|
||||
|
||||
/**
|
||||
* Get the next page of data
|
||||
*
|
||||
* @return the next page of data
|
||||
*/
|
||||
DataObject next();
|
||||
|
||||
/**
|
||||
* Get the page prior to the last page returned
|
||||
*
|
||||
* @return the previous page
|
||||
*/
|
||||
DataObject previous();
|
||||
|
||||
/**
|
||||
* Return a specific identified page.
|
||||
*
|
||||
* @param page
|
||||
* The number of the page to return
|
||||
* @return the indicated page
|
||||
*/
|
||||
DataObject getPage(int page);
|
||||
|
||||
}
|
|
@ -1,738 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.config.wrapper;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.Collections;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Vector;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.Column;
|
||||
import org.apache.tuscany.das.rdb.config.Command;
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.ConfigFactory;
|
||||
import org.apache.tuscany.das.rdb.config.ConnectionInfo;
|
||||
import org.apache.tuscany.das.rdb.config.ConnectionProperties;
|
||||
import org.apache.tuscany.das.rdb.config.Create;
|
||||
import org.apache.tuscany.das.rdb.config.Delete;
|
||||
import org.apache.tuscany.das.rdb.config.KeyPair;
|
||||
import org.apache.tuscany.das.rdb.config.Parameters;
|
||||
import org.apache.tuscany.das.rdb.config.Relationship;
|
||||
import org.apache.tuscany.das.rdb.config.Table;
|
||||
import org.apache.tuscany.das.rdb.config.Update;
|
||||
|
||||
import commonj.sdo.Property;
|
||||
|
||||
public class MappingWrapper {
|
||||
|
||||
private static final ConfigFactory FACTORY = ConfigFactory.INSTANCE;
|
||||
|
||||
private final Logger logger = Logger.getLogger(MappingWrapper.class);
|
||||
|
||||
private Config config;
|
||||
|
||||
public MappingWrapper() {
|
||||
config = FACTORY.createConfig();
|
||||
//JIRA-952
|
||||
this.checkSchemaNameSupport();
|
||||
}
|
||||
|
||||
//JIRA-952 - check if there is any entry with no schemaName when support is ON
|
||||
public void checkSchemaNameSupport(){
|
||||
if(config.isDatabaseSchemaNameSupported()){
|
||||
List tableList = config.getTable();
|
||||
for(int i=0; i<tableList.size(); i++){
|
||||
Table t = (Table)tableList.get(i);
|
||||
if(t.getSchemaName() == null || t.getSchemaName().equals("")){
|
||||
throw new RuntimeException("No schemaName provided for tableName "+t.getTableName()+" when schemaNameSupport is ON");
|
||||
}
|
||||
|
||||
if(t.getTypeName()==null){
|
||||
t.setTypeName(t.getSchemaName()+"."+t.getTableName());
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
public MappingWrapper(Config mapping) {
|
||||
if (mapping == null) {
|
||||
this.config = FACTORY.createConfig();
|
||||
} else {
|
||||
this.config = mapping;
|
||||
}
|
||||
//JIRA-952
|
||||
checkSchemaNameSupport();
|
||||
}
|
||||
|
||||
public Config getConfig() {
|
||||
return this.config;
|
||||
}
|
||||
|
||||
public Table getTable(String tableName) {
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Looking for table " + tableName);
|
||||
}
|
||||
|
||||
Iterator i = config.getTable().iterator();
|
||||
while (i.hasNext()) {
|
||||
Table t = (Table) i.next();
|
||||
//JIRA-952
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
if (tableName.equalsIgnoreCase(t.getSchemaName()+"."+t.getTableName())) {
|
||||
return t;
|
||||
}
|
||||
}else{
|
||||
if (tableName.equalsIgnoreCase(t.getTableName())) {
|
||||
return t;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public Table getTableByTypeName(String typeName) {
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Looking for table by property: " + typeName);
|
||||
}
|
||||
|
||||
Iterator i = config.getTable().iterator();
|
||||
while (i.hasNext()) {
|
||||
Table t = (Table) i.next();
|
||||
TableWrapper wrapper = new TableWrapper(t);
|
||||
if (typeName.equals(wrapper.getTypeName())) {
|
||||
return t;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
|
||||
}
|
||||
|
||||
public void addImpliedRelationship(String parentTableName, String childTableName, String fkColumnName) {
|
||||
|
||||
// Don't create a relationship for something like Book.Book_ID
|
||||
if (parentTableName.equalsIgnoreCase(childTableName)) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Don't create a relationship if one already exists in the config
|
||||
Iterator i = config.getRelationship().iterator();
|
||||
while (i.hasNext()) {
|
||||
Relationship r = (Relationship) i.next();
|
||||
if (r.getPrimaryKeyTable().equals(parentTableName) && r.getForeignKeyTable().equals(childTableName)) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
Relationship r = FACTORY.createRelationship();
|
||||
r.setName(childTableName);
|
||||
r.setPrimaryKeyTable(parentTableName);
|
||||
r.setForeignKeyTable(childTableName);
|
||||
|
||||
KeyPair pair = FACTORY.createKeyPair();
|
||||
pair.setPrimaryKeyColumn("ID");
|
||||
pair.setForeignKeyColumn(fkColumnName);
|
||||
|
||||
r.getKeyPair().add(pair);
|
||||
r.setMany(true);
|
||||
|
||||
config.getRelationship().add(r);
|
||||
}
|
||||
|
||||
public Relationship addRelationship(String parentName, String childName) {
|
||||
|
||||
//JIRA-952
|
||||
QualifiedColumn parent = null;
|
||||
QualifiedColumn child = null;
|
||||
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
parent = new QualifiedColumn(parentName, true);
|
||||
child = new QualifiedColumn(childName, true);
|
||||
}
|
||||
else{
|
||||
parent = new QualifiedColumn(parentName);
|
||||
child = new QualifiedColumn(childName);
|
||||
}
|
||||
|
||||
Relationship r = FACTORY.createRelationship();
|
||||
//JIRA-952
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
r.setName(child.getSchemaName()+"."+child.getTableName());
|
||||
r.setPrimaryKeyTable(parent.getSchemaName()+"."+parent.getTableName());
|
||||
r.setForeignKeyTable(child.getSchemaName()+"."+child.getTableName());
|
||||
}
|
||||
else{
|
||||
r.setName(child.getTableName());
|
||||
r.setPrimaryKeyTable(parent.getTableName());
|
||||
r.setForeignKeyTable(child.getTableName());
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Created relationship from " + r.getPrimaryKeyTable()
|
||||
+ " to " + r.getForeignKeyTable() + " named " + r.getName());
|
||||
}
|
||||
|
||||
KeyPair pair = FACTORY.createKeyPair();
|
||||
pair.setPrimaryKeyColumn(parent.getColumnName());
|
||||
pair.setForeignKeyColumn(child.getColumnName());
|
||||
|
||||
r.getKeyPair().add(pair);
|
||||
r.setMany(true);
|
||||
|
||||
config.getRelationship().add(r);
|
||||
|
||||
return r;
|
||||
|
||||
}
|
||||
|
||||
public Relationship addRelationship(Vector parentNames, Vector childNames) {
|
||||
//create vector for each
|
||||
if(parentNames.size() != childNames.size()){
|
||||
throw new RuntimeException("Can not for relationship for multiple keys, different sizes");
|
||||
}
|
||||
|
||||
Vector parentColumns = new Vector();
|
||||
Vector childColumns = new Vector();
|
||||
|
||||
for(int i=0; i<parentNames.size(); i++){
|
||||
QualifiedColumn parent = null;
|
||||
QualifiedColumn child = null;
|
||||
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
parent = new QualifiedColumn((String)parentNames.get(i), true);
|
||||
child = new QualifiedColumn((String)childNames.get(i), true);
|
||||
}
|
||||
else{
|
||||
parent = new QualifiedColumn((String)parentNames.get(i));
|
||||
child = new QualifiedColumn((String)childNames.get(i));
|
||||
}
|
||||
|
||||
parentColumns.add(parent);
|
||||
childColumns.add(child);
|
||||
}
|
||||
|
||||
//all parent columns should be from same table and schema
|
||||
//all child columns should be from same table and schema
|
||||
checkTableNames(parentColumns);
|
||||
checkSchemaNames(parentColumns);
|
||||
|
||||
checkTableNames(childColumns);
|
||||
checkSchemaNames(childColumns);
|
||||
|
||||
Relationship r = FACTORY.createRelationship();
|
||||
//JIRA-952
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
r.setName(((QualifiedColumn)childColumns.get(0)).getSchemaName()+"."
|
||||
+((QualifiedColumn)childColumns.get(0)).getTableName());
|
||||
r.setPrimaryKeyTable(((QualifiedColumn)parentColumns.get(0)).getSchemaName()+"."
|
||||
+((QualifiedColumn)parentColumns.get(0)).getTableName());
|
||||
r.setForeignKeyTable(((QualifiedColumn)childColumns.get(0)).getSchemaName()+"."
|
||||
+((QualifiedColumn)childColumns.get(0)).getTableName());
|
||||
}
|
||||
else{
|
||||
r.setName(((QualifiedColumn)childColumns.get(0)).getTableName());
|
||||
r.setPrimaryKeyTable(((QualifiedColumn)parentColumns.get(0)).getTableName());
|
||||
r.setForeignKeyTable(((QualifiedColumn)childColumns.get(0)).getTableName());
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Created relationship from " + r.getPrimaryKeyTable()
|
||||
+ " to " + r.getForeignKeyTable() + " named " + r.getName());
|
||||
}
|
||||
|
||||
KeyPair pair = null;
|
||||
|
||||
for(int i=0; i<parentColumns.size(); i++){
|
||||
pair = FACTORY.createKeyPair();
|
||||
pair.setPrimaryKeyColumn(((QualifiedColumn)parentColumns.get(i)).getColumnName());
|
||||
pair.setForeignKeyColumn(((QualifiedColumn)childColumns.get(i)).getColumnName());
|
||||
r.getKeyPair().add(pair);
|
||||
}
|
||||
|
||||
r.setMany(true);
|
||||
config.getRelationship().add(r);
|
||||
|
||||
return r;
|
||||
}
|
||||
|
||||
public void checkTableNames(Vector columns){
|
||||
String expectedTableName = ((QualifiedColumn)columns.get(0)).getTableName();
|
||||
|
||||
for(int i=0; i<columns.size(); i++){
|
||||
QualifiedColumn currColumn = (QualifiedColumn)columns.get(i);
|
||||
String currTableName = currColumn.getTableName();
|
||||
|
||||
if(!currTableName.equals(expectedTableName)){
|
||||
throw new RuntimeException("Columns in one side of relationship can not be from different tables");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void checkSchemaNames(Vector columns){
|
||||
if(!this.config.isDatabaseSchemaNameSupported()){
|
||||
return;
|
||||
}
|
||||
|
||||
String expectedSchemaName = ((QualifiedColumn)columns.get(0)).getSchemaName();
|
||||
|
||||
for(int i=0; i<columns.size(); i++){
|
||||
QualifiedColumn currColumns = (QualifiedColumn)columns.get(i);
|
||||
String currSchemaName = currColumns.getSchemaName();
|
||||
|
||||
if(!currSchemaName.equals(expectedSchemaName)){
|
||||
throw new RuntimeException("Columns in one side of relationship can not be from different schema");
|
||||
}
|
||||
}
|
||||
}
|
||||
public void addPrimaryKey(String columnName) {
|
||||
addPrimaryKey(Collections.singletonList(columnName));
|
||||
}
|
||||
|
||||
public void addPrimaryKey(List columnNames) {
|
||||
|
||||
Iterator i = columnNames.iterator();
|
||||
while (i.hasNext()) {
|
||||
String columnName = (String) i.next();
|
||||
|
||||
QualifiedColumn pkColumn = null;
|
||||
pkColumn = new QualifiedColumn(columnName, this.config.isDatabaseSchemaNameSupported());
|
||||
//Table t = findOrCreateTable(pkColumn.getTableName());
|
||||
Table t = findOrCreateTable(pkColumn);
|
||||
Column c = findOrCreateColumn(t, pkColumn.getColumnName());
|
||||
c.setPrimaryKey(true);
|
||||
}
|
||||
}
|
||||
|
||||
public String getTableTypeName(String tableName) {
|
||||
Table t = getTable(tableName);
|
||||
if (t == null) {
|
||||
return tableName;
|
||||
}
|
||||
String propertyName = t.getTypeName();
|
||||
|
||||
if (propertyName == null) {
|
||||
return tableName;
|
||||
}
|
||||
|
||||
return propertyName;
|
||||
}
|
||||
|
||||
public Column getColumn(Table t, String columnName) {
|
||||
if (t == null) {
|
||||
return null;
|
||||
}
|
||||
Iterator i = t.getColumn().iterator();
|
||||
while (i.hasNext()) {
|
||||
Column c = (Column) i.next();
|
||||
if (c.getColumnName().equals(columnName)) {
|
||||
return c;
|
||||
}
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("WARNING: Could not find column " + columnName + " in table " + t.getTableName());
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public Column getColumnByPropertyName(Table t, String propertyName) {
|
||||
if (t == null) {
|
||||
return null;
|
||||
}
|
||||
|
||||
Iterator i = t.getColumn().iterator();
|
||||
while (i.hasNext()) {
|
||||
Column c = (Column) i.next();
|
||||
|
||||
if (c.getColumnName().equals(propertyName)) {
|
||||
return c;
|
||||
}
|
||||
|
||||
if (c.getPropertyName() != null && c.getPropertyName().equals(propertyName)) {
|
||||
return c;
|
||||
}
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("WARNING: Could not find column " + propertyName + " in table " + t.getTableName());
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public String getColumnPropertyName(String tableName, String columnName) {
|
||||
Table t = getTable(tableName);
|
||||
Column c = getColumn(t, columnName);
|
||||
if (c == null) {
|
||||
return columnName;
|
||||
}
|
||||
|
||||
String propertyName = c.getPropertyName();
|
||||
if (propertyName == null) {
|
||||
return c.getColumnName();
|
||||
}
|
||||
|
||||
return propertyName;
|
||||
}
|
||||
|
||||
public Table addTable(String tableName, String typeName) {
|
||||
Table table = getTable(tableName);
|
||||
if (table != null) {
|
||||
throw new RuntimeException("Table " + tableName + "already exists");
|
||||
}
|
||||
|
||||
table = ConfigFactory.INSTANCE.createTable();
|
||||
table.setTableName(tableName);
|
||||
table.setTypeName(typeName);
|
||||
config.getTable().add(table);
|
||||
|
||||
return table;
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
public Table addTable(String tableName, String schemaName, String typeName) {
|
||||
Table table = null;
|
||||
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
table = getTable(schemaName+"."+tableName);
|
||||
}
|
||||
else{
|
||||
table = getTable(tableName);
|
||||
}
|
||||
|
||||
if (table != null) {
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
throw new RuntimeException("Table " + schemaName+"."+tableName + "already exists");
|
||||
}
|
||||
else{
|
||||
throw new RuntimeException("Table " + tableName + "already exists");
|
||||
}
|
||||
}
|
||||
|
||||
table = ConfigFactory.INSTANCE.createTable();
|
||||
table.setTableName(tableName);
|
||||
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
table.setSchemaName(schemaName);
|
||||
}
|
||||
else{
|
||||
table.setSchemaName("");
|
||||
}
|
||||
|
||||
table.setTypeName(typeName);
|
||||
config.getTable().add(table);
|
||||
|
||||
return table;
|
||||
}
|
||||
public Column addColumn(Table table, String name, String propertyName) {
|
||||
Column column = ConfigFactory.INSTANCE.createColumn();
|
||||
column.setColumnName(name);
|
||||
column.setPropertyName(propertyName);
|
||||
|
||||
table.getColumn().add(column);
|
||||
return column;
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
private Table findOrCreateTable(String schemaName, String tableName) {
|
||||
Table table = null;
|
||||
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
table = getTable(schemaName+"."+tableName);
|
||||
}
|
||||
else{
|
||||
table = getTable(tableName);
|
||||
}
|
||||
if (table == null) {
|
||||
table = ConfigFactory.INSTANCE.createTable();
|
||||
table.setTableName(tableName);
|
||||
table.setSchemaName(schemaName);
|
||||
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
table.setTypeName(schemaName+"."+tableName);
|
||||
}
|
||||
else{
|
||||
table.setTypeName(tableName);
|
||||
}
|
||||
config.getTable().add(table);
|
||||
}
|
||||
return table;
|
||||
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
private Table findOrCreateTable(QualifiedColumn column) {
|
||||
Table table = null;
|
||||
if(this.config.isDatabaseSchemaNameSupported()){
|
||||
table = getTable(column.getSchemaName()+"."+column.getTableName());
|
||||
}
|
||||
else{
|
||||
table = getTable(column.getTableName());
|
||||
}
|
||||
|
||||
if (table == null) {
|
||||
table = ConfigFactory.INSTANCE.createTable();
|
||||
table.setTableName(column.getTableName());
|
||||
table.setSchemaName(column.getSchemaName());
|
||||
config.getTable().add(table);
|
||||
}
|
||||
return table;
|
||||
|
||||
}
|
||||
private Column findOrCreateColumn(Table t, String name) {
|
||||
Iterator i = t.getColumn().iterator();
|
||||
while (i.hasNext()) {
|
||||
Column c = (Column) i.next();
|
||||
if (name.equals(c.getColumnName())) {
|
||||
return c;
|
||||
}
|
||||
}
|
||||
|
||||
Column c = ConfigFactory.INSTANCE.createColumn();
|
||||
c.setColumnName(name);
|
||||
t.getColumn().add(c);
|
||||
return c;
|
||||
}
|
||||
|
||||
public boolean hasRecursiveRelationships() {
|
||||
if (config != null) {
|
||||
Iterator i = getConfig().getRelationship().iterator();
|
||||
while (i.hasNext()) {
|
||||
Relationship r = (Relationship) i.next();
|
||||
if (r.getPrimaryKeyTable().equals(r.getForeignKeyTable())) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public Collection getRelationshipsByChildTable(String name) {
|
||||
List results = new ArrayList();
|
||||
if (config != null) {
|
||||
Iterator i = getConfig().getRelationship().iterator();
|
||||
while (i.hasNext()) {
|
||||
Relationship r = (Relationship) i.next();
|
||||
if (name.equals(r.getForeignKeyTable())) {
|
||||
results.add(r);
|
||||
}
|
||||
}
|
||||
}
|
||||
return results;
|
||||
}
|
||||
|
||||
// TODO optimize
|
||||
public List getInsertOrder() {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Getting insert order");
|
||||
}
|
||||
|
||||
List inserts = new ArrayList();
|
||||
Map parentToChild = new HashMap();
|
||||
|
||||
List parents = new ArrayList();
|
||||
List children = new ArrayList();
|
||||
if (config != null) {
|
||||
Iterator i = getConfig().getRelationship().iterator();
|
||||
while (i.hasNext()) {
|
||||
Relationship r = (Relationship) i.next();
|
||||
parents.add(r.getPrimaryKeyTable());
|
||||
children.add(r.getForeignKeyTable());
|
||||
parentToChild.put(r.getPrimaryKeyTable(), r.getForeignKeyTable());
|
||||
}
|
||||
while (parents.size() > 0) {
|
||||
String parent = (String) parents.get(0);
|
||||
if (!children.contains(parent)) {
|
||||
if (!inserts.contains(parent)) {
|
||||
inserts.add(parent);
|
||||
}
|
||||
String child = (String) parentToChild.get(parent);
|
||||
if (!inserts.contains(child)) {
|
||||
inserts.add(child);
|
||||
}
|
||||
parents.remove(parent);
|
||||
children.remove(child);
|
||||
} else {
|
||||
parents.add(parents.remove(0));
|
||||
}
|
||||
}
|
||||
inserts.addAll(children);
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug(inserts);
|
||||
}
|
||||
|
||||
return inserts;
|
||||
}
|
||||
|
||||
public List getDeleteOrder() {
|
||||
List deleteOrder = new ArrayList();
|
||||
deleteOrder.addAll(getInsertOrder());
|
||||
Collections.reverse(deleteOrder);
|
||||
return deleteOrder;
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
public void addConverter(String name, String converter) {
|
||||
QualifiedColumn column = new QualifiedColumn(name, this.config.isDatabaseSchemaNameSupported());
|
||||
Table t = null;
|
||||
t = findOrCreateTable(column);
|
||||
Column c = findOrCreateColumn(t, column.getColumnName());
|
||||
c.setConverterClassName(converter);
|
||||
}
|
||||
|
||||
public String getConverter(String tableName, String columnName) {
|
||||
Table t = getTable(tableName);
|
||||
Column c = getColumn(t, columnName);
|
||||
if (c != null) {
|
||||
return c.getConverterClassName();
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public Map getConverters(Table table) {
|
||||
Map converters = new HashMap();
|
||||
|
||||
Iterator columns = table.getColumn().iterator();
|
||||
while (columns.hasNext()) {
|
||||
Column c = (Column) columns.next();
|
||||
if (c.getConverterClassName() != null) {
|
||||
String property = c.getPropertyName();
|
||||
if (property == null) {
|
||||
property = c.getColumnName();
|
||||
}
|
||||
converters.put(property, c.getConverterClassName());
|
||||
}
|
||||
}
|
||||
return converters;
|
||||
}
|
||||
|
||||
public Relationship getRelationshipByReference(Property ref) {
|
||||
Iterator i = config.getRelationship().iterator();
|
||||
while (i.hasNext()) {
|
||||
Relationship r = (Relationship) i.next();
|
||||
if (ref.getName().equals(r.getName()) || ref.getOpposite().getName().equals(r.getName())) {
|
||||
return r;
|
||||
}
|
||||
}
|
||||
throw new RuntimeException("Could not find relationship " + ref.getName() + " in the configuration");
|
||||
}
|
||||
|
||||
public Relationship getRelationshipByName(String name) {
|
||||
Iterator i = config.getRelationship().iterator();
|
||||
while (i.hasNext()) {
|
||||
Relationship r = (Relationship) i.next();
|
||||
if (name.equals(r.getName())) {
|
||||
return r;
|
||||
}
|
||||
}
|
||||
throw new RuntimeException("Could not find relationship " + name + " in the configuration");
|
||||
}
|
||||
|
||||
public void addUpdateStatement(Table table, String statement, Parameters parameters) {
|
||||
|
||||
Update update = ConfigFactory.INSTANCE.createUpdate();
|
||||
update.setSql(statement);
|
||||
update.setParameters(parameters);
|
||||
table.setUpdate(update);
|
||||
|
||||
}
|
||||
|
||||
public void addDeleteStatement(Table table, String statement, Parameters parameters) {
|
||||
|
||||
Delete delete = ConfigFactory.INSTANCE.createDelete();
|
||||
delete.setSql(statement);
|
||||
delete.setParameters(parameters);
|
||||
table.setDelete(delete);
|
||||
|
||||
}
|
||||
|
||||
public void addCreateStatement(Table table, String statement, Parameters parameters) {
|
||||
|
||||
Create create = ConfigFactory.INSTANCE.createCreate();
|
||||
create.setSql(statement);
|
||||
create.setParameters(parameters);
|
||||
table.setCreate(create);
|
||||
|
||||
}
|
||||
|
||||
//JIRA-948 support for driver manager connection
|
||||
public void addConnectionInfo(String dataSourceName, boolean managedtx){
|
||||
ConnectionInfo info = ConfigFactory.INSTANCE.createConnectionInfo();
|
||||
info.setDataSource(dataSourceName);
|
||||
info.setManagedtx(managedtx);
|
||||
|
||||
config.setConnectionInfo(info);
|
||||
}
|
||||
|
||||
public void addConnectionInfo(String driverClass, String connectionURL, String user, String password, int loginTimeout) {
|
||||
ConnectionInfo info = ConfigFactory.INSTANCE.createConnectionInfo();
|
||||
|
||||
ConnectionProperties connectionProperties = ConfigFactory.INSTANCE.createConnectionProperties();
|
||||
connectionProperties.setDriverClass(driverClass);
|
||||
connectionProperties.setDatabaseURL(connectionURL);
|
||||
connectionProperties.setUserName(user);
|
||||
connectionProperties.setPassword(password);
|
||||
connectionProperties.setLoginTimeout(loginTimeout);
|
||||
|
||||
info.setConnectionProperties(connectionProperties);
|
||||
config.setConnectionInfo(info);
|
||||
}
|
||||
//JIRA-948 end
|
||||
|
||||
public Command addCommand(String name, String sql, String kind) {
|
||||
Command cmd = ConfigFactory.INSTANCE.createCommand();
|
||||
cmd.setName(name);
|
||||
cmd.setKind(kind);
|
||||
cmd.setSQL(sql);
|
||||
|
||||
config.getCommand().add(cmd);
|
||||
|
||||
return cmd;
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
public void addImpliedPrimaryKey(String schemaName, String tableName, String columnName) {
|
||||
Table t = findOrCreateTable(schemaName, tableName);//JIRA-952
|
||||
|
||||
Iterator i = t.getColumn().iterator();
|
||||
boolean hasPK = false;
|
||||
while (i.hasNext()) {
|
||||
Column c = (Column) i.next();
|
||||
if (c.isPrimaryKey()) {
|
||||
hasPK = true;
|
||||
}
|
||||
}
|
||||
|
||||
if (!hasPK) {
|
||||
Column c = findOrCreateColumn(t, columnName);
|
||||
c.setPrimaryKey(true);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -1,94 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.config.wrapper;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
public class QualifiedColumn {
|
||||
|
||||
private final String tableName;
|
||||
|
||||
private final String columnName;
|
||||
private final String schemaName;//JIRA-952
|
||||
|
||||
private final Logger logger = Logger.getLogger(QualifiedColumn.class);
|
||||
|
||||
public QualifiedColumn(String name) {
|
||||
this.schemaName = "";
|
||||
int index = name.indexOf('.');
|
||||
if ( index == -1 ) {
|
||||
throw new RuntimeException("Column " + name + " must be qualified with a table name");
|
||||
}
|
||||
tableName = name.substring(0, index);
|
||||
columnName = name.substring(index + 1);
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Table name: " + tableName);
|
||||
this.logger.debug("Column name: " + columnName);
|
||||
}
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
public QualifiedColumn(String name, boolean isDatabaseSchemaNameSupported) {
|
||||
int index = name.indexOf('.');
|
||||
if ( index == -1 ) {
|
||||
throw new RuntimeException("Column " + name + " must be qualified with a table name and optional schema name");
|
||||
}
|
||||
|
||||
int lastIndex = name.lastIndexOf('.');
|
||||
|
||||
if(index == lastIndex && isDatabaseSchemaNameSupported){
|
||||
throw new RuntimeException("Column " + name + " must be qualified with a table name and schema name");
|
||||
}
|
||||
|
||||
if(isDatabaseSchemaNameSupported){
|
||||
schemaName = name.substring(0, index);
|
||||
tableName = name.substring(index+1, lastIndex);
|
||||
columnName = name.substring(lastIndex + 1);
|
||||
}
|
||||
else{
|
||||
schemaName = "";
|
||||
tableName = name.substring(0, index);
|
||||
columnName = name.substring(index + 1);
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Table name: " + tableName);
|
||||
this.logger.debug("Column name: " + columnName);
|
||||
}
|
||||
}
|
||||
public String getTableName() {
|
||||
return this.tableName;
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
public String getSchemaName() {
|
||||
return this.schemaName;
|
||||
}
|
||||
public String getColumnName() {
|
||||
return this.columnName;
|
||||
}
|
||||
//JIRA-952
|
||||
public String toString(){
|
||||
if(this.schemaName == null || this.schemaName.equals(""))
|
||||
return this.tableName+"."+this.columnName;
|
||||
else
|
||||
return this.schemaName+"."+this.tableName+"."+this.columnName;
|
||||
}
|
||||
}
|
|
@ -1,47 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.config.wrapper;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.KeyPair;
|
||||
import org.apache.tuscany.das.rdb.config.Relationship;
|
||||
|
||||
public class RelationshipWrapper {
|
||||
|
||||
private Relationship relationship;
|
||||
|
||||
public RelationshipWrapper(Relationship r) {
|
||||
this.relationship = r;
|
||||
}
|
||||
|
||||
public Collection getForeignKeys() {
|
||||
List keys = new ArrayList();
|
||||
Iterator i = this.relationship.getKeyPair().iterator();
|
||||
while (i.hasNext()) {
|
||||
KeyPair pair = (KeyPair) i.next();
|
||||
keys.add(pair.getForeignKeyColumn());
|
||||
}
|
||||
return keys;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,149 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.config.wrapper;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Column;
|
||||
import org.apache.tuscany.das.rdb.config.Table;
|
||||
|
||||
public class TableWrapper {
|
||||
|
||||
private Table table;
|
||||
|
||||
public TableWrapper(Table table) {
|
||||
this.table = table;
|
||||
}
|
||||
|
||||
public String getTypeName() {
|
||||
return table.getTypeName() == null ? table.getTableName() : table.getTypeName();
|
||||
}
|
||||
|
||||
public String getTableName() {
|
||||
return table.getTableName();
|
||||
}
|
||||
|
||||
public Collection getPrimaryKeyNames() {
|
||||
List pkNames = new ArrayList();
|
||||
Iterator i = table.getColumn().iterator();
|
||||
while (i.hasNext()) {
|
||||
Column c = (Column) i.next();
|
||||
if (c.isPrimaryKey()) {
|
||||
pkNames.add(c.getColumnName());
|
||||
}
|
||||
}
|
||||
return pkNames;
|
||||
}
|
||||
|
||||
public Collection getPrimaryKeyProperties() {
|
||||
|
||||
List keyProperties = new ArrayList();
|
||||
Iterator columns = table.getColumn().iterator();
|
||||
while (columns.hasNext()) {
|
||||
Column c = (Column) columns.next();
|
||||
if (c.isPrimaryKey()) {
|
||||
keyProperties.add(getColumnPropertyName(c));
|
||||
}
|
||||
}
|
||||
|
||||
return keyProperties;
|
||||
}
|
||||
|
||||
private String getColumnPropertyName(Column c) {
|
||||
if (c.getPropertyName() != null) {
|
||||
return c.getPropertyName();
|
||||
}
|
||||
|
||||
return c.getColumnName();
|
||||
}
|
||||
|
||||
public boolean isGeneratedColumnProperty(String name) {
|
||||
Column c = getColumnByPropertyName(name);
|
||||
return c == null ? false : c.isGenerated();
|
||||
}
|
||||
|
||||
public String getConverter(String propertyName) {
|
||||
Column c = getColumnByPropertyName(propertyName);
|
||||
return (c == null) ? null : c.getConverterClassName();
|
||||
}
|
||||
|
||||
public Column getColumnByPropertyName(String propertyName) {
|
||||
Iterator columns = table.getColumn().iterator();
|
||||
while (columns.hasNext()) {
|
||||
Column c = (Column) columns.next();
|
||||
String property = c.getPropertyName();
|
||||
if (property == null) {
|
||||
property = c.getColumnName();
|
||||
}
|
||||
if (propertyName.equals(property)) {
|
||||
return c;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public Column getCollisionColumn() {
|
||||
Iterator columns = table.getColumn().iterator();
|
||||
while (columns.hasNext()) {
|
||||
Column c = (Column) columns.next();
|
||||
if (c.isCollision()) {
|
||||
return c;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
|
||||
}
|
||||
|
||||
public String getCollisionColumnPropertyName() {
|
||||
Column c = getCollisionColumn();
|
||||
if (c.getPropertyName() != null) {
|
||||
return c.getPropertyName();
|
||||
}
|
||||
return c.getColumnName();
|
||||
|
||||
}
|
||||
|
||||
public String getManagedColumnPropertyName() {
|
||||
Iterator i = table.getColumn().iterator();
|
||||
while (i.hasNext()) {
|
||||
Column c = (Column) i.next();
|
||||
if (c.isCollision() && c.isManaged()) {
|
||||
return c.getPropertyName() == null ? c.getColumnName() : c.getPropertyName();
|
||||
}
|
||||
}
|
||||
return null;
|
||||
|
||||
}
|
||||
|
||||
public Column getManagedColumn() {
|
||||
Iterator i = table.getColumn().iterator();
|
||||
while (i.hasNext()) {
|
||||
Column c = (Column) i.next();
|
||||
if (c.isCollision() && c.isManaged()) {
|
||||
return c;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
}
|
|
@ -1,36 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.exception;
|
||||
|
||||
public class DataSourceInitializationException extends RuntimeException {
|
||||
|
||||
private static final long serialVersionUID = 302160989411041041L;
|
||||
|
||||
public DataSourceInitializationException(String string) {
|
||||
super(string);
|
||||
}
|
||||
|
||||
public DataSourceInitializationException(Throwable e){
|
||||
super(e);
|
||||
}
|
||||
|
||||
public DataSourceInitializationException(String string, Throwable e) {
|
||||
super(string, e);
|
||||
}
|
||||
}
|
|
@ -1,31 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.exception;
|
||||
|
||||
|
||||
public class OptimisticConcurrencyException extends RuntimeException {
|
||||
|
||||
private static final long serialVersionUID = -8430445422807942933L;
|
||||
|
||||
public OptimisticConcurrencyException(String string) {
|
||||
super(string);
|
||||
}
|
||||
|
||||
|
||||
}
|
|
@ -1,36 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.generator.impl;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Converter;
|
||||
|
||||
public class BaseGenerator {
|
||||
|
||||
protected Converter getConverter(String converter) {
|
||||
if (converter != null) {
|
||||
try {
|
||||
return (Converter) Thread.currentThread().getContextClassLoader().loadClass(converter).newInstance();
|
||||
} catch (Exception ex) {
|
||||
throw new RuntimeException(ex);
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,91 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.generator.impl;
|
||||
|
||||
import java.util.Iterator;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.Table;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.TableWrapper;
|
||||
import org.apache.tuscany.das.rdb.impl.DeleteCommandImpl;
|
||||
import org.apache.tuscany.das.rdb.impl.ParameterExtendedImpl;
|
||||
import org.apache.tuscany.das.rdb.impl.SDODataTypeHelper;
|
||||
import org.apache.tuscany.das.rdb.impl.SDODataTypes;
|
||||
|
||||
public final class DeleteGenerator extends BaseGenerator {
|
||||
|
||||
public static final DeleteGenerator INSTANCE = new DeleteGenerator();
|
||||
|
||||
private final Logger logger = Logger.getLogger(DeleteGenerator.class);
|
||||
|
||||
private DeleteGenerator() {
|
||||
super();
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
private String getDeleteStatement(MappingWrapper mapping, Table t) {
|
||||
TableWrapper table = new TableWrapper(t);
|
||||
|
||||
StringBuffer statement = new StringBuffer();
|
||||
statement.append("delete from ");
|
||||
if(mapping.getConfig().isDatabaseSchemaNameSupported()){
|
||||
statement.append(t.getSchemaName()+"."+t.getTableName());
|
||||
}
|
||||
else{
|
||||
statement.append(t.getTableName());
|
||||
}
|
||||
statement.append(" where ");
|
||||
|
||||
Iterator names = table.getPrimaryKeyNames().iterator();
|
||||
Iterator properties = table.getPrimaryKeyProperties().iterator();
|
||||
while (names.hasNext() && properties.hasNext()) {
|
||||
String name = (String) names.next();
|
||||
statement.append(name);
|
||||
statement.append(" = ?");
|
||||
if (names.hasNext() && properties.hasNext()) {
|
||||
statement.append(" and ");
|
||||
}
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug(statement.toString());
|
||||
}
|
||||
|
||||
return statement.toString();
|
||||
}
|
||||
|
||||
public DeleteCommandImpl getDeleteCommand(MappingWrapper mapping, Table t) {
|
||||
TableWrapper tw = new TableWrapper(t);
|
||||
DeleteCommandImpl deleteCommand = new DeleteCommandImpl(getDeleteStatement(mapping, t));
|
||||
|
||||
Iterator i = tw.getPrimaryKeyProperties().iterator();
|
||||
for (int idx = 1; i.hasNext(); idx++) {
|
||||
String property = (String) i.next();
|
||||
ParameterExtendedImpl p = new ParameterExtendedImpl();
|
||||
p.setName(property);
|
||||
p.setColumnType(SDODataTypeHelper.columnTypeForSDOType(SDODataTypes.OBJECT));
|
||||
p.setConverter(getConverter(tw.getConverter(property)));
|
||||
p.setIndex(idx);
|
||||
deleteCommand.addParameter(p);
|
||||
}
|
||||
return deleteCommand;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,182 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.generator.impl;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.Column;
|
||||
import org.apache.tuscany.das.rdb.config.Relationship;
|
||||
import org.apache.tuscany.das.rdb.config.Table;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.RelationshipWrapper;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.TableWrapper;
|
||||
import org.apache.tuscany.das.rdb.impl.InsertCommandImpl;
|
||||
import org.apache.tuscany.das.rdb.impl.ParameterExtendedImpl;
|
||||
import org.apache.tuscany.das.rdb.impl.SDODataTypeHelper;
|
||||
import org.apache.tuscany.das.rdb.util.CollectionsUtil;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.Property;
|
||||
|
||||
public final class InsertGenerator extends BaseGenerator {
|
||||
|
||||
public static final InsertGenerator INSTANCE = new InsertGenerator();
|
||||
|
||||
private final Logger logger = Logger.getLogger(InsertGenerator.class);
|
||||
|
||||
private InsertGenerator() {
|
||||
super();
|
||||
}
|
||||
|
||||
public InsertCommandImpl getInsertCommand(MappingWrapper config, DataObject changedObject, Table t) {
|
||||
List parameters = new ArrayList();
|
||||
TableWrapper table = new TableWrapper(t);
|
||||
StringBuffer statement = new StringBuffer("insert into ");
|
||||
//JIRA-952
|
||||
if(config.getConfig().isDatabaseSchemaNameSupported()){
|
||||
statement.append(t.getSchemaName()+"."+t.getTableName());
|
||||
}
|
||||
else{
|
||||
statement.append(t.getTableName());
|
||||
}
|
||||
HashSet changedProperties = getAttributeProperties(changedObject, config, table);
|
||||
Iterator i;
|
||||
if ( changedProperties.isEmpty() ) {
|
||||
i = changedObject.getType().getProperties().iterator();
|
||||
} else {
|
||||
i = changedProperties.iterator();
|
||||
}
|
||||
|
||||
List attributes = new ArrayList();
|
||||
List generatedKeys = new ArrayList();
|
||||
while (i.hasNext()) {
|
||||
Property attr = (Property) i.next();
|
||||
if ( attr.getType().isDataType()) {
|
||||
if (table.isGeneratedColumnProperty(attr.getName())) {
|
||||
generatedKeys.add(attr.getName());
|
||||
} else {
|
||||
attributes.add(attr.getName());
|
||||
parameters.add(changedObject.getType().getProperty(attr.getName()));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
statement.append("(");
|
||||
Iterator attrs = attributes.iterator();
|
||||
while (attrs.hasNext()) {
|
||||
String name = (String) attrs.next();
|
||||
statement.append("");
|
||||
Column c = config.getColumnByPropertyName(t, name);
|
||||
statement.append(c == null ? name : c.getColumnName());
|
||||
if (attrs.hasNext()) {
|
||||
statement.append(", ");
|
||||
} else {
|
||||
statement.append(")");
|
||||
}
|
||||
}
|
||||
|
||||
statement.append(" values (");
|
||||
for (int idx = 1; idx <= attributes.size(); idx++) {
|
||||
statement.append('?');
|
||||
if (idx < attributes.size()) {
|
||||
statement.append(", ");
|
||||
} else {
|
||||
statement.append(")");
|
||||
}
|
||||
}
|
||||
|
||||
InsertCommandImpl cmd = new InsertCommandImpl(statement.toString(),
|
||||
(String[]) generatedKeys.toArray(new String[0]));
|
||||
Iterator params = parameters.iterator();
|
||||
for (int idx = 1; params.hasNext(); idx++) {
|
||||
Property property = (Property) params.next();
|
||||
ParameterExtendedImpl p = new ParameterExtendedImpl();
|
||||
p.setName(property.getName());
|
||||
p.setType(property.getType());
|
||||
p.setColumnType(SDODataTypeHelper.columnTypeForSDOType(property.getType()));
|
||||
p.setConverter(getConverter(table.getConverter(property.getName())));
|
||||
p.setIndex(idx);
|
||||
cmd.addParameter(p);
|
||||
|
||||
}
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug(statement.toString());
|
||||
}
|
||||
|
||||
return cmd;
|
||||
|
||||
}
|
||||
|
||||
private HashSet getAttributeProperties(DataObject obj, MappingWrapper config, TableWrapper tw) {
|
||||
HashSet fields = new HashSet();
|
||||
Iterator i = obj.getType().getProperties().iterator();
|
||||
while (i.hasNext()) {
|
||||
Property p = (Property) i.next();
|
||||
if (p.getType().isDataType()) {
|
||||
if (obj.isSet(p)) {
|
||||
if (fields.add(p) == false) {
|
||||
throw new RuntimeException("Foreign key properties should not be set when the corrsponding relationship has changed");
|
||||
}
|
||||
}
|
||||
} else {
|
||||
if (obj.isSet(p)) {
|
||||
Relationship relationship = config.getRelationshipByReference(p);
|
||||
if ((p.getOpposite() != null && p.getOpposite().isMany())
|
||||
|| (hasState(tw, relationship, obj))) {
|
||||
RelationshipWrapper r = new RelationshipWrapper(relationship);
|
||||
Iterator keys = r.getForeignKeys().iterator();
|
||||
while (keys.hasNext()) {
|
||||
String key = (String) keys.next();
|
||||
String keyProperty = config.getColumnPropertyName(tw.getTableName(), key);
|
||||
Property keyProp = obj.getType().getProperty(keyProperty);
|
||||
if ( keyProp == null )
|
||||
throw new RuntimeException("Invalid foreign key column: " + key);
|
||||
if (fields.add(keyProp) == false) {
|
||||
throw new RuntimeException("Foreign key properties should not be set when the corresponding relationship has changed");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return fields;
|
||||
|
||||
}
|
||||
|
||||
private boolean hasState(TableWrapper tw, Relationship rel, DataObject changedObject) {
|
||||
|
||||
if (!rel.isMany()) {
|
||||
|
||||
RelationshipWrapper rw = new RelationshipWrapper(rel);
|
||||
if ((rel.getForeignKeyTable().equals(tw.getTableName()))
|
||||
&& (CollectionsUtil.disjoint(tw.getPrimaryKeyProperties(), rw.getForeignKeys()))) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,228 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.generator.impl;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.Column;
|
||||
import org.apache.tuscany.das.rdb.config.Table;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.RelationshipWrapper;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.TableWrapper;
|
||||
import org.apache.tuscany.das.rdb.impl.CollisionParameter;
|
||||
import org.apache.tuscany.das.rdb.impl.ManagedParameterImpl;
|
||||
import org.apache.tuscany.das.rdb.impl.OptimisticWriteCommandImpl;
|
||||
import org.apache.tuscany.das.rdb.impl.ParameterExtendedImpl;
|
||||
import org.apache.tuscany.das.rdb.impl.SDODataTypeHelper;
|
||||
import org.apache.tuscany.das.rdb.impl.UpdateCommandImpl;
|
||||
|
||||
import commonj.sdo.ChangeSummary;
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.Property;
|
||||
import commonj.sdo.Type;
|
||||
import commonj.sdo.ChangeSummary.Setting;
|
||||
|
||||
public final class UpdateGenerator extends BaseGenerator {
|
||||
|
||||
public static final UpdateGenerator INSTANCE = new UpdateGenerator();
|
||||
|
||||
private final Logger logger = Logger.getLogger(UpdateGenerator.class);
|
||||
|
||||
private UpdateGenerator() {
|
||||
super();
|
||||
}
|
||||
|
||||
public UpdateCommandImpl getUpdateCommand(MappingWrapper mapping, DataObject changedObject, Table table) {
|
||||
List parameters = new ArrayList();
|
||||
Type type = changedObject.getType();
|
||||
TableWrapper tableWrapper = new TableWrapper(table);
|
||||
StringBuffer statement = new StringBuffer("update ");
|
||||
if(mapping.getConfig().isDatabaseSchemaNameSupported()){
|
||||
statement.append(table.getSchemaName()+"."+table.getTableName());
|
||||
}
|
||||
else{
|
||||
statement.append(table.getTableName());
|
||||
}
|
||||
statement.append(" set ");
|
||||
|
||||
ChangeSummary summary = changedObject.getDataGraph().getChangeSummary();
|
||||
HashSet changedFields = getChangedFields(mapping, summary, changedObject, tableWrapper);
|
||||
Iterator i = changedFields.iterator();
|
||||
|
||||
int idx = 1;
|
||||
while (i.hasNext()) {
|
||||
Property property = (Property) i.next();
|
||||
Column c = tableWrapper.getColumnByPropertyName(property.getName());
|
||||
|
||||
if ((c == null) || !c.isCollision() || !c.isPrimaryKey()) {
|
||||
String columnName = c == null ? property.getName() : c.getColumnName();
|
||||
appendFieldSet(statement, idx > 1, columnName);
|
||||
parameters.add(createParameter(tableWrapper, property, idx++));
|
||||
}
|
||||
}
|
||||
|
||||
Column c = tableWrapper.getManagedColumn();
|
||||
if (c != null) {
|
||||
appendFieldSet(statement, idx > 1, c.getColumnName());
|
||||
String propertyName = c.getPropertyName() == null ? c.getColumnName() : c.getPropertyName();
|
||||
parameters.add(createManagedParameter(tableWrapper,
|
||||
changedObject.getInstanceProperty(propertyName), idx++));
|
||||
}
|
||||
|
||||
statement.append(" where ");
|
||||
|
||||
Iterator pkColumnNames = tableWrapper.getPrimaryKeyNames().iterator();
|
||||
Iterator pkPropertyNames = tableWrapper.getPrimaryKeyProperties().iterator();
|
||||
while (pkColumnNames.hasNext() && pkPropertyNames.hasNext()) {
|
||||
String columnName = (String) pkColumnNames.next();
|
||||
String propertyName = (String) pkPropertyNames.next();
|
||||
statement.append(columnName);
|
||||
statement.append(" = ?");
|
||||
if (pkColumnNames.hasNext() && pkPropertyNames.hasNext()) {
|
||||
statement.append(" and ");
|
||||
}
|
||||
parameters.add(createParameter(tableWrapper, type.getProperty(propertyName), idx++));
|
||||
}
|
||||
|
||||
if (tableWrapper.getCollisionColumn() == null) {
|
||||
Iterator iter = changedFields.iterator();
|
||||
while (iter.hasNext()) {
|
||||
statement.append(" and ");
|
||||
Property changedProperty = (Property) iter.next();
|
||||
Column column = tableWrapper.getColumnByPropertyName(changedProperty.getName());
|
||||
statement.append(column == null ? changedProperty.getName() : column.getColumnName());
|
||||
|
||||
Object value;
|
||||
Setting setting = summary.getOldValue(changedObject, changedProperty);
|
||||
// Setting is null if this is a relationship change
|
||||
if (setting == null) {
|
||||
value = changedObject.get(changedProperty);
|
||||
} else {
|
||||
value = setting.getValue();
|
||||
}
|
||||
|
||||
if (value == null) {
|
||||
statement.append(" is null");
|
||||
} else {
|
||||
ParameterExtendedImpl param = createCollisionParameter(tableWrapper, changedProperty, idx++);
|
||||
statement.append(" = ?");
|
||||
param.setValue(value);
|
||||
parameters.add(param);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
} else {
|
||||
statement.append(" and ");
|
||||
statement.append(tableWrapper.getCollisionColumn().getColumnName());
|
||||
statement.append(" = ?");
|
||||
parameters.add(createParameter(tableWrapper,
|
||||
type.getProperty(tableWrapper.getCollisionColumnPropertyName()), idx++));
|
||||
}
|
||||
|
||||
UpdateCommandImpl updateCommand = new OptimisticWriteCommandImpl(statement.toString());
|
||||
|
||||
Iterator params = parameters.iterator();
|
||||
while (params.hasNext()) {
|
||||
updateCommand.addParameter((ParameterExtendedImpl) params.next());
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug(statement.toString());
|
||||
}
|
||||
|
||||
return updateCommand;
|
||||
}
|
||||
|
||||
|
||||
|
||||
private void appendFieldSet(StringBuffer statement, boolean appendComma, String columnName) {
|
||||
if (appendComma) {
|
||||
statement.append(", ");
|
||||
}
|
||||
statement.append(columnName);
|
||||
statement.append(" = ?");
|
||||
}
|
||||
|
||||
|
||||
|
||||
private HashSet getChangedFields(MappingWrapper config, ChangeSummary summary, DataObject obj, TableWrapper tw) {
|
||||
HashSet changes = new HashSet();
|
||||
|
||||
Iterator i = summary.getOldValues(obj).iterator();
|
||||
while (i.hasNext()) {
|
||||
ChangeSummary.Setting setting = (ChangeSummary.Setting) i.next();
|
||||
|
||||
if (setting.getProperty().getType().isDataType()) {
|
||||
if ( changes.add(setting.getProperty()) == false ) {
|
||||
throw new RuntimeException("Foreign key properties should not be set when the corresponding relationship has changed");
|
||||
}
|
||||
} else {
|
||||
Property ref = setting.getProperty();
|
||||
if (!ref.isMany()) {
|
||||
RelationshipWrapper r = new RelationshipWrapper(config.getRelationshipByReference(ref));
|
||||
|
||||
Iterator keys = r.getForeignKeys().iterator();
|
||||
while (keys.hasNext()) {
|
||||
String key = (String) keys.next();
|
||||
String keyProperty = config.getColumnPropertyName(tw.getTableName(), key);
|
||||
Property keyProp = obj.getType().getProperty(keyProperty);
|
||||
if ( keyProp == null )
|
||||
throw new RuntimeException("Invalid foreign key column: " + key);
|
||||
if (changes.add(keyProp) == false) {
|
||||
throw new RuntimeException("Foreign key properties should not be set when the corresponding relationship has changed");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
return changes;
|
||||
}
|
||||
|
||||
private ParameterExtendedImpl fillExtendedParameter(ParameterExtendedImpl param, TableWrapper table, Property property, int idx) {
|
||||
param.setName(property.getName());
|
||||
param.setType(property.getType());
|
||||
param.setConverter(getConverter(table.getConverter(property.getName())));
|
||||
if (idx != -1) {
|
||||
param.setIndex(idx);
|
||||
}
|
||||
param.setColumnType(SDODataTypeHelper.columnTypeForSDOType(property.getType()));
|
||||
return param;
|
||||
}
|
||||
private ParameterExtendedImpl createCollisionParameter(TableWrapper tableWrapper, Property property, int i) {
|
||||
ParameterExtendedImpl param = new CollisionParameter();
|
||||
return fillExtendedParameter(param, tableWrapper, property, i);
|
||||
}
|
||||
|
||||
private ParameterExtendedImpl createManagedParameter(TableWrapper table, Property property, int idx) {
|
||||
ParameterExtendedImpl param = new ManagedParameterImpl();
|
||||
return fillExtendedParameter(param, table, property, idx);
|
||||
}
|
||||
|
||||
private ParameterExtendedImpl createParameter(TableWrapper table, Property property, int idx) {
|
||||
ParameterExtendedImpl param = new ParameterExtendedImpl();
|
||||
return fillExtendedParameter(param, table, property, idx);
|
||||
}
|
||||
}
|
|
@ -1,120 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.util.Iterator;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.Property;
|
||||
import commonj.sdo.Type;
|
||||
import commonj.sdo.helper.DataFactory;
|
||||
|
||||
public class DataObjectMaker {
|
||||
|
||||
private final DataObject rootObject;
|
||||
|
||||
private final Logger logger = Logger.getLogger(DataObjectMaker.class);
|
||||
|
||||
public DataObjectMaker(DataObject root) {
|
||||
this.rootObject = root;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param tableData
|
||||
* @return
|
||||
*/
|
||||
public DataObject createAndAddDataObject(TableData tableData, ResultMetadata resultMetadata) {
|
||||
// Get a Type from the package and create a standalone DataObject
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Looking for Type for " + tableData.getTableName());
|
||||
}
|
||||
|
||||
Type tableClass = findTableTypeByPropertyName(tableData.getTableName());
|
||||
|
||||
if (tableClass == null) {
|
||||
throw new RuntimeException("An SDO Type with name " + tableData.getTableName() + " was not found");
|
||||
}
|
||||
|
||||
DataObject obj = DataFactory.INSTANCE.create(tableClass);
|
||||
|
||||
// Now, check to see if the root data object has a containment reference
|
||||
// to this EClass. If so, add it to the graph. If not, it will be taken
|
||||
// care
|
||||
// of when we process relationships
|
||||
|
||||
Iterator i = this.rootObject.getType().getProperties().iterator();
|
||||
while (i.hasNext()) {
|
||||
Property p = (Property) i.next();
|
||||
|
||||
if (p.isContainment() && p.getType().equals(tableClass)) {
|
||||
if (p.isMany()) {
|
||||
rootObject.getList(p).add(obj);
|
||||
} else {
|
||||
this.rootObject.set(p, obj);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Iterator columnNames = resultMetadata.getPropertyNames(tableData.getTableName()).iterator();
|
||||
while (columnNames.hasNext()) {
|
||||
String propertyName = (String) columnNames.next();
|
||||
|
||||
Property p = findProperty(obj.getType(), propertyName);
|
||||
if (p == null) {
|
||||
throw new RuntimeException("Type " + obj.getType().getName()
|
||||
+ " does not contain a property named " + propertyName);
|
||||
}
|
||||
|
||||
Object value = tableData.getColumnData(propertyName);
|
||||
|
||||
obj.set(p, value);
|
||||
}
|
||||
|
||||
return obj;
|
||||
}
|
||||
|
||||
// temporary, ignoring case
|
||||
private Property findProperty(Type type, String columnName) {
|
||||
Iterator properties = type.getProperties().iterator();
|
||||
while (properties.hasNext()) {
|
||||
Property p = (Property) properties.next();
|
||||
if (columnName.equalsIgnoreCase(p.getName())) {
|
||||
return p;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
private Type findTableTypeByPropertyName(String tableName) {
|
||||
Iterator i = rootObject.getType().getProperties().iterator();
|
||||
while (i.hasNext()) {
|
||||
Property p = (Property) i.next();
|
||||
if (tableName.equals(p.getType().getName())) {
|
||||
return p.getType();
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,84 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.sql.Blob;
|
||||
import java.sql.SQLException;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Converter;
|
||||
|
||||
public class DefaultConverter implements Converter {
|
||||
|
||||
public DefaultConverter() {
|
||||
super();
|
||||
}
|
||||
|
||||
public Object getColumnValue(Object data) {
|
||||
return data;
|
||||
}
|
||||
|
||||
public Object getPropertyValue(Object data) {
|
||||
// if (type.isInstance(data))
|
||||
// return data;
|
||||
//
|
||||
// if ( data == null )
|
||||
// return null;
|
||||
//
|
||||
// String name = type.getInstanceClass().getName();
|
||||
// if (name == "java.lang.Byte" || name == "byte") {
|
||||
// return new Byte(data.toString());
|
||||
// }
|
||||
//
|
||||
// else if (name == "java.lang.Double" || name == "double") {
|
||||
// return new Double(data.toString());
|
||||
// }
|
||||
//
|
||||
// else if (name == "java.lang.Float" || name == "float") {
|
||||
// return new Float(data.toString());
|
||||
// }
|
||||
//
|
||||
// else if (name == "java.lang.Integer" || name == "int") {
|
||||
// return new Integer(data.toString());
|
||||
// }
|
||||
//
|
||||
// else if (name == "java.lang.Long" || name == "long") {
|
||||
// return new Long(data.toString());
|
||||
// }
|
||||
//
|
||||
// else if (name == "java.lang.Short" || name == "short") {
|
||||
// return new Short(data.toString());
|
||||
// }
|
||||
//
|
||||
// else if (name == "java.lang.String") {
|
||||
// return String.valueOf(data.toString());
|
||||
// }
|
||||
|
||||
if (data instanceof Blob) {
|
||||
Blob b = (Blob) data;
|
||||
try {
|
||||
return b.getBytes(1, (int) b.length());
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
return data;
|
||||
|
||||
}
|
||||
}
|
|
@ -1,279 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.sql.ResultSet;
|
||||
import java.sql.SQLException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.Relationship;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.impl.ResultSetShape;
|
||||
import org.apache.tuscany.sdo.api.SDOUtil;
|
||||
|
||||
import commonj.sdo.Property;
|
||||
import commonj.sdo.Type;
|
||||
import commonj.sdo.helper.HelperContext;
|
||||
import commonj.sdo.impl.HelperProvider;
|
||||
|
||||
/**
|
||||
*/
|
||||
public class GraphBuilderMetadata {
|
||||
|
||||
private final Logger logger = Logger.getLogger(GraphBuilderMetadata.class);
|
||||
|
||||
private MappingWrapper configWrapper;
|
||||
|
||||
private final Collection resultSets = new ArrayList();
|
||||
|
||||
private String typeURI;
|
||||
|
||||
private Type rootType;
|
||||
|
||||
private HelperContext defaultHelperContext = HelperProvider.getDefaultContext();
|
||||
private HelperContext helperContext = HelperProvider.getInstance().getDefaultContext();
|
||||
|
||||
|
||||
public GraphBuilderMetadata(Collection results, Config model, ResultSetShape shape) throws SQLException {
|
||||
this.configWrapper = new MappingWrapper(model);
|
||||
if (model != null) {
|
||||
this.typeURI = model.getDataObjectModel();
|
||||
}
|
||||
|
||||
Iterator i = results.iterator();
|
||||
while (i.hasNext()) {
|
||||
ResultSet rs = (ResultSet) i.next();
|
||||
ResultMetadata resultMetadata = new ResultMetadata(rs, configWrapper, shape);
|
||||
resultSets.add(resultMetadata);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the collection of ResultMetadata objects
|
||||
*/
|
||||
public Collection getResultMetadata() {
|
||||
return this.resultSets;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the set of defined relationships
|
||||
*/
|
||||
|
||||
public Collection getRelationships() {
|
||||
return configWrapper.getConfig().getRelationship();
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the root Type
|
||||
*/
|
||||
public Type getRootType() {
|
||||
if (this.rootType == null) {
|
||||
if (this.typeURI == null) {
|
||||
createDynamicTypes();
|
||||
} else {
|
||||
createDynamicRoot();
|
||||
}
|
||||
}
|
||||
|
||||
return this.rootType;
|
||||
}
|
||||
|
||||
public MappingWrapper getConfigWrapper() {
|
||||
return this.configWrapper;
|
||||
}
|
||||
|
||||
/**
|
||||
* Creates a set of SDO Types based on the query results and supplied config information
|
||||
*/
|
||||
|
||||
private void createDynamicTypes() {
|
||||
|
||||
Type root = SDOUtil.createType(helperContext, getDefaultURI(), "DataGraphRoot", false);
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("GBMD.createDynamicTypes():created Type for "+getDefaultURI());
|
||||
}
|
||||
|
||||
Iterator iter = getResultMetadata().iterator();
|
||||
while (iter.hasNext()) {
|
||||
|
||||
ResultMetadata resultMetadata = (ResultMetadata) iter.next();
|
||||
|
||||
// Create a Type for each Table represented in the ResultSet
|
||||
Iterator names = resultMetadata.getAllTablePropertyNames().iterator();
|
||||
while (names.hasNext()) {
|
||||
String tableName = (String) names.next();
|
||||
if (root.getProperty(tableName) == null) {
|
||||
Type tableType = SDOUtil.createType(helperContext, getDefaultURI(), tableName, false);
|
||||
Property property = SDOUtil.createProperty(root, tableName, tableType);
|
||||
SDOUtil.setMany(property, true);
|
||||
SDOUtil.setContainment(property, true);
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("GBMD.createDynamicTypes():CREATING NEW TABLE TYPE & PROPERTY :"+tableName);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// TODO tablePropertyMap is temporary until Tuscany-203 is fixed
|
||||
Map tablePropertyMap = new HashMap();
|
||||
|
||||
for (int i = 1; i <= resultMetadata.getResultSetSize(); i++) {
|
||||
|
||||
Property ref = root.getProperty(resultMetadata.getTablePropertyName(i));
|
||||
|
||||
if (ref == null) {
|
||||
throw new RuntimeException("Could not find table " + resultMetadata.getTablePropertyName(i)
|
||||
+ " in the SDO model");
|
||||
}
|
||||
|
||||
// TODO Temporary code to check to see if a property has already been added.
|
||||
// Replace when Tuscany-203 is fixed
|
||||
List addedProperties = (List) tablePropertyMap.get(ref.getName());
|
||||
if (addedProperties == null) {
|
||||
addedProperties = new ArrayList();
|
||||
tablePropertyMap.put(ref.getName(), addedProperties);
|
||||
}
|
||||
|
||||
|
||||
|
||||
String columnName = resultMetadata.getColumnPropertyName(i);
|
||||
|
||||
// TODO temporary check until Tuscany-203 is fixed
|
||||
if (!addedProperties.contains(columnName)) {
|
||||
addedProperties.add(columnName);
|
||||
Type atype = resultMetadata.getDataType(i);
|
||||
|
||||
SDOUtil.createProperty(ref.getType(), columnName, atype);
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
MappingWrapper wrapper = getConfigWrapper();
|
||||
Iterator i = getRelationships().iterator();
|
||||
while (i.hasNext()) {
|
||||
Relationship r = (Relationship) i.next();
|
||||
|
||||
String parentName = wrapper.getTableTypeName(r.getPrimaryKeyTable());
|
||||
String childName = wrapper.getTableTypeName(r.getForeignKeyTable());
|
||||
|
||||
if (parentName == null) {
|
||||
throw new RuntimeException("The parent table (" + r.getPrimaryKeyTable()
|
||||
+ ") in relationship " + r.getName()
|
||||
+ " was not found in the mapping information.");
|
||||
} else if (childName == null) {
|
||||
throw new RuntimeException("The child table (" + r.getForeignKeyTable()
|
||||
+ ") in relationship " + r.getName()
|
||||
+ " was not found in the mapping information.");
|
||||
}
|
||||
|
||||
Property parentProperty = root.getProperty(parentName);
|
||||
Property childProperty = root.getProperty(childName);
|
||||
|
||||
if (parentProperty == null) {
|
||||
throw new RuntimeException("The parent table (" + parentName + ") in relationship "
|
||||
+ r.getName() + " was not found.");
|
||||
} else if (childProperty == null) {
|
||||
throw new RuntimeException("The child table (" + childName + ") in relationship "
|
||||
+ r.getName() + " was not found.");
|
||||
}
|
||||
|
||||
Type parent = parentProperty.getType();
|
||||
Type child = childProperty.getType();
|
||||
|
||||
Property parentProp = SDOUtil.createProperty(parent, r.getName(), child);
|
||||
Property childProp = SDOUtil.createProperty(child, r.getName() + "_opposite", parent);
|
||||
SDOUtil.setOpposite(parentProp, childProp);
|
||||
SDOUtil.setOpposite(childProp, parentProp);
|
||||
SDOUtil.setMany(parentProp, r.isMany());
|
||||
}
|
||||
|
||||
this.rootType = root;
|
||||
}
|
||||
|
||||
private String getDefaultURI() {
|
||||
return "http:///org.apache.tuscany.das.rdb/das";
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a dynamic root Type to act as a container Type for a set of generated Types
|
||||
*
|
||||
*/
|
||||
private void createDynamicRoot() {
|
||||
Type root = SDOUtil.createType(helperContext, getDefaultURI() + "/DataGraphRoot", "DataGraphRoot", false);
|
||||
|
||||
List types = getDefinedTypes();
|
||||
|
||||
if (types == null) {
|
||||
throw new RuntimeException("SDO Types have not been registered for URI " + typeURI);
|
||||
}
|
||||
|
||||
Iterator i = types.iterator();
|
||||
while (i.hasNext()) {
|
||||
Type type = (Type) i.next();
|
||||
Property property = SDOUtil.createProperty(root, type.getName(), type);
|
||||
SDOUtil.setContainment(property, true);
|
||||
SDOUtil.setMany(property, true);
|
||||
}
|
||||
this.rootType = root;
|
||||
}
|
||||
|
||||
public List getDefinedTypes() {
|
||||
List types = null;
|
||||
List defaultTypes = null;
|
||||
if (this.typeURI == null) {
|
||||
types = SDOUtil.getTypes(helperContext, getDefaultURI());
|
||||
defaultTypes = SDOUtil.getTypes(defaultHelperContext, getDefaultURI());
|
||||
if(defaultTypes != null){
|
||||
if(types == null) {
|
||||
types = defaultTypes;
|
||||
}
|
||||
else {
|
||||
types.addAll(defaultTypes);
|
||||
}
|
||||
}
|
||||
return types;
|
||||
}
|
||||
|
||||
types = SDOUtil.getTypes(helperContext, typeURI);
|
||||
defaultTypes = SDOUtil.getTypes(defaultHelperContext, typeURI);
|
||||
if(defaultTypes != null){
|
||||
if(types == null) {
|
||||
types = defaultTypes;
|
||||
}
|
||||
else {
|
||||
types.addAll(defaultTypes);
|
||||
}
|
||||
}
|
||||
|
||||
if(rootType != null)
|
||||
types.add(rootType);
|
||||
return types;
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -1,104 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
/**
|
||||
*
|
||||
* Used to store and look up table objects based on primary key This could be a lot more
|
||||
* efficient if we could use LinkedHashMap from JDK 1.4
|
||||
*/
|
||||
public class MultiTableRegistry implements TableRegistry {
|
||||
private final Logger logger = Logger.getLogger(MultiTableRegistry.class);
|
||||
|
||||
private Map tableNameMap;
|
||||
|
||||
private Map tableValueMap;
|
||||
|
||||
public MultiTableRegistry() {
|
||||
tableNameMap = new HashMap();
|
||||
tableValueMap = new HashMap();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the table with the specified name and primary key
|
||||
*
|
||||
* @param tableName
|
||||
* @param primaryKey
|
||||
* @return EDataObject
|
||||
*/
|
||||
public DataObject get(String tableName, List primaryKey) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Looking for table " + tableName + " with PK " + primaryKey);
|
||||
this.logger.debug("\tReturning " + getPkMap(tableName).get(primaryKey));
|
||||
}
|
||||
return (DataObject) getPkMap(tableName).get(primaryKey);
|
||||
}
|
||||
|
||||
/**
|
||||
* Add the table with the specified name and primary key
|
||||
*
|
||||
* @param tableName
|
||||
* @param primaryKey
|
||||
* @param value
|
||||
*/
|
||||
public void put(String tableName, List primaryKey, DataObject value) {
|
||||
if (getPkMap(tableName).put(primaryKey, value) == null) {
|
||||
getCreateValueList(tableName).add(value);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the HashMap that contains the primary key to table object mappings.
|
||||
*
|
||||
* @param tableName
|
||||
* @return HashMap
|
||||
*/
|
||||
private Map getPkMap(String tableName) {
|
||||
Map pkMap = (HashMap) tableNameMap.get(tableName);
|
||||
if (pkMap == null) {
|
||||
pkMap = new HashMap();
|
||||
tableNameMap.put(tableName, pkMap);
|
||||
}
|
||||
return pkMap;
|
||||
}
|
||||
|
||||
private List getCreateValueList(String tableName) {
|
||||
List values = (List) tableValueMap.get(tableName);
|
||||
if (values == null) {
|
||||
values = new ArrayList();
|
||||
tableValueMap.put(tableName, values);
|
||||
}
|
||||
return values;
|
||||
}
|
||||
|
||||
public boolean contains(String tableName, List primaryKey) {
|
||||
return get(tableName, primaryKey) == null ? false : true;
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -1,401 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.sql.ResultSet;
|
||||
import java.sql.SQLException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.Collections;
|
||||
import java.util.HashMap;
|
||||
import java.util.HashSet;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Converter;
|
||||
import org.apache.tuscany.das.rdb.config.Column;
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.Table;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.TableWrapper;
|
||||
import org.apache.tuscany.das.rdb.impl.ResultSetShape;
|
||||
|
||||
import commonj.sdo.Type;
|
||||
|
||||
public class ResultMetadata {
|
||||
|
||||
private Map tableToPropertyMap = new HashMap();
|
||||
|
||||
private List typeNames = new ArrayList();
|
||||
|
||||
private List propertyNames = new ArrayList();
|
||||
|
||||
private final ResultSet resultSet;
|
||||
|
||||
private final ResultSetShape resultSetShape;
|
||||
|
||||
private final MappingWrapper configWrapper;
|
||||
|
||||
private Converter[] converters;
|
||||
|
||||
private Map tableToPrimaryKeysMap = new HashMap();
|
||||
|
||||
//JIRA-952
|
||||
public ResultMetadata(ResultSet rs, MappingWrapper cfgWrapper, ResultSetShape shape) throws SQLException {
|
||||
|
||||
this.resultSet = rs;
|
||||
this.configWrapper = cfgWrapper;
|
||||
|
||||
if (shape == null) {
|
||||
this.resultSetShape = new ResultSetShape(rs.getMetaData(), configWrapper.getConfig());
|
||||
} else {
|
||||
this.resultSetShape = shape;
|
||||
}
|
||||
|
||||
this.converters = new Converter[resultSetShape.getColumnCount()];
|
||||
|
||||
Map impliedRelationships = new HashMap();
|
||||
String schemaName = "";
|
||||
String idSpell = null;
|
||||
for (int i = 1; i <= resultSetShape.getColumnCount(); i++) {
|
||||
String tableName = resultSetShape.getTableName(i);
|
||||
schemaName = resultSetShape.getSchemaName(i);
|
||||
if (( tableName == null ) || ( tableName.equals(""))) {
|
||||
throw new RuntimeException("Unable to obtain table information from JDBC. DAS configuration must specify ResultDescriptors");
|
||||
}
|
||||
String typeName = null;
|
||||
|
||||
if(this.configWrapper.getConfig().isDatabaseSchemaNameSupported()){
|
||||
typeName = configWrapper.getTableTypeName(schemaName+"."+tableName);
|
||||
}
|
||||
else{
|
||||
typeName = configWrapper.getTableTypeName(tableName);
|
||||
}
|
||||
String columnName = resultSetShape.getColumnName(i);
|
||||
|
||||
String colName = "";
|
||||
if (columnName.regionMatches(true, columnName.length()-3, "_ID", 0, 3)) {
|
||||
idSpell = columnName.substring(columnName.length()-3, columnName.length());
|
||||
if(this.configWrapper.getConfig().isDatabaseSchemaNameSupported()){
|
||||
colName = schemaName+"."+columnName;
|
||||
impliedRelationships.put(colName, schemaName+"."+tableName);
|
||||
}
|
||||
else{
|
||||
colName = columnName;
|
||||
impliedRelationships.put(colName, tableName);
|
||||
}
|
||||
} else if (columnName.equalsIgnoreCase("ID")) {
|
||||
configWrapper.addImpliedPrimaryKey(schemaName, tableName, columnName);
|
||||
}
|
||||
|
||||
String propertyName = null;
|
||||
|
||||
if(this.configWrapper.getConfig().isDatabaseSchemaNameSupported()){
|
||||
propertyName = configWrapper.getColumnPropertyName(schemaName+"."+tableName, columnName);
|
||||
}
|
||||
else{
|
||||
propertyName = configWrapper.getColumnPropertyName(tableName, columnName);
|
||||
}
|
||||
String converterName = null;
|
||||
|
||||
if(this.configWrapper.getConfig().isDatabaseSchemaNameSupported()){
|
||||
converterName = configWrapper.getConverter(schemaName+"."+tableName, resultSetShape.getColumnName(i));
|
||||
}
|
||||
else{
|
||||
converterName = configWrapper.getConverter(tableName, resultSetShape.getColumnName(i));
|
||||
}
|
||||
|
||||
converters[i - 1] = loadConverter(converterName);
|
||||
|
||||
typeNames.add(typeName);
|
||||
propertyNames.add(propertyName);
|
||||
|
||||
Collection properties = (Collection) tableToPropertyMap.get(typeName);
|
||||
if (properties == null) {
|
||||
properties = new ArrayList();
|
||||
}
|
||||
properties.add(propertyName);
|
||||
tableToPropertyMap.put(typeName, properties);
|
||||
|
||||
}
|
||||
|
||||
//System.out.println("tableToPropertyMap "+tableToPropertyMap);
|
||||
fillTableToPrimaryKeysMap();
|
||||
|
||||
Iterator i = impliedRelationships.keySet().iterator();
|
||||
while (i.hasNext()) {
|
||||
String columnName = (String) i.next();
|
||||
String pkTableName = columnName.substring(0, columnName.indexOf(idSpell));//_id, _Id, _iD, _ID anything
|
||||
String fkTableName = (String) impliedRelationships.get(columnName);
|
||||
List pkTableProperties = (List) tableToPropertyMap.get(pkTableName);
|
||||
if ((pkTableProperties != null) && (pkTableProperties.contains("ID"))) {
|
||||
configWrapper.addImpliedRelationship(pkTableName, fkTableName, columnName);
|
||||
}
|
||||
}
|
||||
// Add any tables defined in the model but not included in the ResultSet
|
||||
// to the list of propertyNames
|
||||
Config model = configWrapper.getConfig();
|
||||
if (model != null) {
|
||||
Iterator tablesFromModel = model.getTable().iterator();
|
||||
while (tablesFromModel.hasNext()) {
|
||||
TableWrapper t = new TableWrapper((Table) tablesFromModel.next());
|
||||
if (tableToPropertyMap.get(t.getTypeName()) == null) {
|
||||
tableToPropertyMap.put(t.getTypeName(), Collections.EMPTY_LIST);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
//Now fill tableToPrimaryKeysMap.Complete for whichever tables are there in tableToPrimaryKeysMap,
|
||||
//Also case of implied PK and it is not there in SELECT, provide way to still fill it in
|
||||
//tableToPrimaryKeysMap - the column should be present in Config (though not defed as PK)
|
||||
//And consider the classic case, when we assume all columns to be PKs - when no info
|
||||
//in config for table or "all columns"
|
||||
private void fillTableToPrimaryKeysMap(){
|
||||
Iterator itr = tableToPropertyMap.keySet().iterator();
|
||||
while(itr.hasNext()){
|
||||
String curTableName = (String)itr.next();
|
||||
boolean treatAllPKs = false;//flag for, when all cols need to be treated as PKs
|
||||
|
||||
if(tableToPrimaryKeysMap.containsKey(curTableName)){
|
||||
continue;//don't keep refilling same hashset for each ResultMetadata constructor,
|
||||
}
|
||||
|
||||
List columnsForTable = null;
|
||||
if(configWrapper.getTableByTypeName(curTableName) != null) {
|
||||
columnsForTable = configWrapper.getTableByTypeName(curTableName).getColumn();
|
||||
}
|
||||
else if(configWrapper.getTable(curTableName) != null){
|
||||
columnsForTable = configWrapper.getTable(curTableName).getColumn();
|
||||
configWrapper.getTable(curTableName).setTypeName(curTableName);//keep configWrapper consistent with Type info
|
||||
}
|
||||
else{
|
||||
treatAllPKs = true;//can not find table/type, need to consider all columns as PKs
|
||||
}
|
||||
|
||||
if(columnsForTable != null){
|
||||
for(int ii=0; ii<columnsForTable.size(); ii++){
|
||||
Column curCol = (Column)columnsForTable.get(ii);
|
||||
|
||||
if(curCol.isPrimaryKey() || curCol.getColumnName().equalsIgnoreCase("ID")){//need to compare col name
|
||||
//with ID as that is the one from dbms metadata or resul set shape metadata
|
||||
//but when putting in map, need to put property and if not present then column
|
||||
Collection pks = (Collection) tableToPrimaryKeysMap.get(curTableName);
|
||||
if(pks == null){
|
||||
pks = new HashSet();
|
||||
}
|
||||
|
||||
if(curCol.getPropertyName() != null){
|
||||
pks.add(curCol.getPropertyName());
|
||||
}
|
||||
else{
|
||||
pks.add(curCol.getColumnName());
|
||||
curCol.setPropertyName(curCol.getColumnName());//make config consistent
|
||||
if(!((Collection)tableToPropertyMap.get(curTableName)).contains(curCol.getColumnName())){
|
||||
((Collection)tableToPropertyMap.get(curTableName)).add(curCol.getColumnName());
|
||||
}
|
||||
}
|
||||
tableToPrimaryKeysMap.put(curTableName, pks);
|
||||
}
|
||||
}
|
||||
}
|
||||
else{
|
||||
treatAllPKs = true;//table present in cfg , but no cols
|
||||
}
|
||||
|
||||
if(treatAllPKs){
|
||||
tableToPrimaryKeysMap.put(curTableName, null);//case when all columns are considered PKs
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private Converter loadConverter(String converterName) {
|
||||
if (converterName != null) {
|
||||
|
||||
try {
|
||||
Class converterClazz = Class.forName(converterName, true,
|
||||
Thread.currentThread().getContextClassLoader());
|
||||
if (null != converterClazz) {
|
||||
return (Converter) converterClazz.newInstance();
|
||||
}
|
||||
|
||||
converterClazz = Class.forName(converterName);
|
||||
if (converterClazz != null) {
|
||||
return (Converter) converterClazz.newInstance();
|
||||
}
|
||||
} catch (ClassNotFoundException ex) {
|
||||
throw new RuntimeException(ex);
|
||||
} catch (IllegalAccessException ex) {
|
||||
throw new RuntimeException(ex);
|
||||
} catch (InstantiationException ex) {
|
||||
throw new RuntimeException(ex);
|
||||
}
|
||||
}
|
||||
return new DefaultConverter();
|
||||
}
|
||||
|
||||
public String getColumnPropertyName(int i) {
|
||||
return (String) propertyNames.get(i - 1);
|
||||
}
|
||||
|
||||
public String getDatabaseColumnName(int i) {
|
||||
return resultSetShape.getColumnName(i);
|
||||
}
|
||||
|
||||
public String getTableName(String columnName) {
|
||||
return (String) typeNames.get(propertyNames.indexOf(columnName));
|
||||
}
|
||||
|
||||
public int getTableSize(String tableName) {
|
||||
return ((Collection) tableToPropertyMap.get(tableName)).size();
|
||||
}
|
||||
|
||||
public Type getDataType(String columnName) {
|
||||
return resultSetShape.getColumnType(propertyNames.indexOf(columnName));
|
||||
}
|
||||
|
||||
public String getTablePropertyName(int i) {
|
||||
return (String) typeNames.get(i - 1);
|
||||
}
|
||||
|
||||
public Collection getAllTablePropertyNames() {
|
||||
return tableToPropertyMap.keySet();
|
||||
}
|
||||
|
||||
public HashSet getAllPKsForTable(String tableName){
|
||||
if(tableToPrimaryKeysMap.containsKey(tableName))
|
||||
return (HashSet)tableToPrimaryKeysMap.get(tableName);
|
||||
else{
|
||||
HashSet tmpHashSet = new HashSet();
|
||||
tmpHashSet.add("");//case when there were cols in cfg but could not find any PK in it and no ID column in cfg/result set
|
||||
return tmpHashSet;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public String toString() {
|
||||
|
||||
StringBuffer result = new StringBuffer(super.toString());
|
||||
result.append(" (Table Names: ");
|
||||
Iterator i = typeNames.iterator();
|
||||
while (i.hasNext()) {
|
||||
String tableName = (String) i.next();
|
||||
result.append(' ');
|
||||
result.append(tableName);
|
||||
result.append(',');
|
||||
}
|
||||
|
||||
result.append(" columnNames: ");
|
||||
|
||||
i = propertyNames.iterator();
|
||||
while (i.hasNext()) {
|
||||
String columnName = (String) i.next();
|
||||
result.append(' ');
|
||||
result.append(columnName);
|
||||
result.append(',');
|
||||
}
|
||||
|
||||
result.append(" mappingModel: ");
|
||||
result.append(this.configWrapper.getConfig());
|
||||
|
||||
result.append(" resultSet: ");
|
||||
result.append(resultSet);
|
||||
|
||||
result.append(" resultSetSize: ");
|
||||
result.append(resultSetShape.getColumnCount());
|
||||
result.append(')');
|
||||
return result.toString();
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* @return
|
||||
*/
|
||||
public int getNumberOfTables() {
|
||||
return tableToPropertyMap.keySet().size();
|
||||
}
|
||||
|
||||
/**
|
||||
* Return whether the column at the given position is part of a primary key.
|
||||
* If we don't have this information, we assume every column is a primary
|
||||
* key. This results in uniqueness checks using all columns in a table.
|
||||
*
|
||||
* @param i
|
||||
* @return
|
||||
*/
|
||||
public boolean isPKColumn(int i) {
|
||||
|
||||
Table t = configWrapper.getTableByTypeName(getTablePropertyName(i));
|
||||
if (t == null) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// If no Columns have been defined, consider every column to be part of
|
||||
// the PK
|
||||
if (t.getColumn().isEmpty()) {
|
||||
return true;
|
||||
}
|
||||
|
||||
Column c = configWrapper.getColumn(t, getDatabaseColumnName(i));
|
||||
|
||||
if (c == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (c.isPrimaryKey()) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param i
|
||||
* @return Type
|
||||
*/
|
||||
public Type getDataType(int i) {
|
||||
return resultSetShape.getColumnType(i);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param tableName
|
||||
* @return Collection
|
||||
*/
|
||||
public Collection getPropertyNames(String tableName) {
|
||||
return (Collection) tableToPropertyMap.get(tableName);
|
||||
}
|
||||
|
||||
public ResultSet getResultSet() {
|
||||
return this.resultSet;
|
||||
}
|
||||
|
||||
public int getResultSetSize() {
|
||||
return resultSetShape.getColumnCount();
|
||||
}
|
||||
|
||||
public boolean isRecursive() {
|
||||
return configWrapper.hasRecursiveRelationships();
|
||||
}
|
||||
|
||||
public Converter getConverter(int i) {
|
||||
return converters[i - 1];
|
||||
}
|
||||
|
||||
}
|
|
@ -1,154 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.sql.ResultSet;
|
||||
import java.sql.SQLException;
|
||||
import java.util.Iterator;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
/**
|
||||
*
|
||||
* A ResultSetProcessor is used to transform the data in a ResultSet into a set of inter-related EDataObjects.
|
||||
*/
|
||||
public class ResultSetProcessor {
|
||||
private final Logger logger = Logger.getLogger(ResultSetProcessor.class);
|
||||
|
||||
private TableRegistry registry;
|
||||
|
||||
private GraphBuilderMetadata metadata;
|
||||
|
||||
private final DataObjectMaker doMaker;
|
||||
|
||||
public ResultSetProcessor(DataObject g, GraphBuilderMetadata gbmd) {
|
||||
|
||||
this.metadata = gbmd;
|
||||
if (metadata.getRelationships().size() == 0) {
|
||||
registry = new SingleTableRegistry();
|
||||
} else {
|
||||
registry = new MultiTableRegistry();
|
||||
}
|
||||
|
||||
doMaker = new DataObjectMaker(g);
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug(metadata);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Process the ResultSet. For each row in the ResultSet, a
|
||||
*
|
||||
* @link ResultSetRow object will be created to represent the row as a set of EDataObjects. Then,
|
||||
* the relevant relationships will be constructed
|
||||
* between each object in the
|
||||
* @link ResultSetRow.
|
||||
*
|
||||
* @param start
|
||||
* @param end
|
||||
*/
|
||||
public void processResults(int start, int end) throws SQLException {
|
||||
|
||||
Iterator i = metadata.getResultMetadata().iterator();
|
||||
while (i.hasNext()) {
|
||||
ResultMetadata resultMetadata = (ResultMetadata) i.next();
|
||||
ResultSet results = resultMetadata.getResultSet();
|
||||
|
||||
processResultSet(results, resultMetadata, start, end);
|
||||
|
||||
// TODO These statements HAVE to be closed or we will have major problems
|
||||
// results.getStatement().close();
|
||||
results.close();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private void processResultSet(ResultSet rs, ResultMetadata rsMetadata, int start, int end) throws SQLException {
|
||||
|
||||
if (rs.getType() == ResultSet.TYPE_FORWARD_ONLY) {
|
||||
while (rs.next() && start < end) {
|
||||
ResultSetRow rsr = new ResultSetRow(rs, rsMetadata);
|
||||
addRowToGraph(rsr, rsMetadata);
|
||||
++start;
|
||||
}
|
||||
} else {
|
||||
while (rs.absolute(start) && start < end) {
|
||||
ResultSetRow rsr = new ResultSetRow(rs, rsMetadata);
|
||||
addRowToGraph(rsr, rsMetadata);
|
||||
++start;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param row
|
||||
* @param resultMetadata
|
||||
*/
|
||||
private void addRowToGraph(ResultSetRow row, ResultMetadata resultMetadata) {
|
||||
RowObjects tableObjects = new RowObjects(metadata, registry);
|
||||
Iterator tables = row.getAllTableData().iterator();
|
||||
while (tables.hasNext()) {
|
||||
TableData rawDataFromRow = (TableData) tables.next();
|
||||
|
||||
if (!rawDataFromRow.hasValidPrimaryKey() ||
|
||||
(rawDataFromRow.hasNullPrimaryKey() && !rawDataFromRow.isTableEmpty())) {//some PK null , but other data present
|
||||
//continue; - need to throw exception as anyway the result will give a wrong impression
|
||||
//when any one table in result set misses PK column or has null value in PK column
|
||||
throw new RuntimeException("Table "+rawDataFromRow.getTableName()+" in query does not include Primary Key "+
|
||||
"column or has null value in it, can not proceed!");
|
||||
}
|
||||
|
||||
String tableName = rawDataFromRow.getTableName();
|
||||
DataObject tableObject = registry.get(tableName, rawDataFromRow.getPrimaryKeyValues());
|
||||
if (tableObject == null
|
||||
&& !rawDataFromRow.hasNullPrimaryKey()) {//2nd check for null data in PK,
|
||||
//as TableData.addData() - hasValidPrimaryKey=false is commented for a reason
|
||||
//with this, DataObjs with null PK will not be added to registry and tableObjects
|
||||
tableObject = doMaker.createAndAddDataObject(rawDataFromRow, resultMetadata);
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Putting table " + tableName + " with PK "
|
||||
+ rawDataFromRow.getPrimaryKeyValues() + " into registry");
|
||||
}
|
||||
|
||||
registry.put(tableName, rawDataFromRow.getPrimaryKeyValues(), tableObject);
|
||||
}
|
||||
else{
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Not Null tableObject or NULL PK");
|
||||
}
|
||||
}
|
||||
|
||||
if(tableObject != null){
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Do not allow any Null tableObject in tableObjects");
|
||||
}
|
||||
tableObjects.put(tableName, tableObject);
|
||||
}
|
||||
}
|
||||
|
||||
tableObjects.processRelationships();
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -1,264 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.sql.ResultSet;
|
||||
import java.sql.SQLException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.HashSet;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
/**
|
||||
*
|
||||
* A ResultSetRow is used to transform a single row of a ResultSet into a set of EDataObjects.
|
||||
*/
|
||||
public class ResultSetRow {
|
||||
private final Logger logger = Logger.getLogger(ResultSetRow.class);
|
||||
|
||||
private final ResultMetadata metadata;
|
||||
|
||||
private Map tableMap = new HashMap();
|
||||
|
||||
private List allTableData;
|
||||
|
||||
/**
|
||||
* Method ResultSetRow.
|
||||
*
|
||||
* @param rs
|
||||
* A ResultSet positioned on the desired row
|
||||
* @param ePackage
|
||||
* The package used to create EDataObjects
|
||||
*/
|
||||
public ResultSetRow(ResultSet rs, ResultMetadata m) throws SQLException {
|
||||
this.metadata = m;
|
||||
if (m.isRecursive()) {
|
||||
processRecursiveRow(rs);
|
||||
} else {
|
||||
processRow(rs);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Processes a single row in the ResultSet Method processRow.
|
||||
*
|
||||
* @param rs
|
||||
*/
|
||||
private void processRow(ResultSet rs) throws SQLException {
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("");
|
||||
}
|
||||
for (int i = 1; i <= metadata.getResultSetSize(); i++) {
|
||||
Object data = getObject(rs, i);
|
||||
|
||||
TableData table = getRawData(metadata.getTablePropertyName(i));
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Adding column: " + metadata.getColumnPropertyName(i) + "\tValue: "
|
||||
+ data + "\tTable: "
|
||||
+ metadata.getTablePropertyName(i));
|
||||
}
|
||||
table.addData(metadata.getColumnPropertyName(i), metadata.isPKColumn(i), data);
|
||||
}
|
||||
|
||||
checkResultSetMissesPK();
|
||||
}
|
||||
|
||||
//get all table names involved in current result set
|
||||
//can not use metadata.getAllTablePropertyNames()
|
||||
//as it gives table names for all tables from Config
|
||||
public Collection getAllTableNamesForRS(){
|
||||
Collection allTableNamesForRS = new HashSet();
|
||||
for (int i = 1; i <= metadata.getResultSetSize(); i++) {
|
||||
allTableNamesForRS.add(metadata.getTablePropertyName(i));
|
||||
}
|
||||
return allTableNamesForRS;
|
||||
}
|
||||
|
||||
//case when result set omits PK column, take care of compound PKs too
|
||||
public void checkResultSetMissesPK(){
|
||||
boolean tableRSHasPK;
|
||||
Collection allTableNames = getAllTableNamesForRS();
|
||||
Iterator itr = allTableNames.iterator();
|
||||
while(itr.hasNext()){
|
||||
tableRSHasPK = false;
|
||||
String currentTableName = (String)itr.next();
|
||||
HashSet pks = metadata.getAllPKsForTable(currentTableName);
|
||||
HashSet pksInRS = new HashSet();
|
||||
for(int j=1; j<=metadata.getResultSetSize(); j++){
|
||||
if(currentTableName.equals(metadata.getTablePropertyName(j)) &&
|
||||
metadata.isPKColumn(j) ){
|
||||
pksInRS.add(metadata.getColumnPropertyName(j));
|
||||
}
|
||||
}
|
||||
|
||||
//if pks null, means its classic case when all cols should be PKs
|
||||
if(pks == null){
|
||||
tableRSHasPK = true;
|
||||
}
|
||||
//case when there were cols in cfg but could not find any PK in it and no ID column in cfg
|
||||
else if(pks != null && pks.size()==1 && pks.contains("")){
|
||||
tableRSHasPK = false;
|
||||
}
|
||||
else if(pks != null && pksInRS.size() == pks.size()){
|
||||
Iterator itr1 = pks.iterator();
|
||||
int indx=0;
|
||||
while(itr1.hasNext()){
|
||||
if(!pksInRS.contains((String)itr1.next())){
|
||||
indx++;
|
||||
}
|
||||
}
|
||||
|
||||
if(indx == 0){
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("has PK TRUE - matched");
|
||||
}
|
||||
tableRSHasPK = true;
|
||||
}else{
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("has PK FALSE- mismatched");
|
||||
}
|
||||
tableRSHasPK = false;
|
||||
}
|
||||
}
|
||||
else{
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("has PK FALSE - rest all cases");
|
||||
}
|
||||
}
|
||||
|
||||
//Default is TRUE(from TableData), so consider only FALSE case
|
||||
if(!tableRSHasPK){
|
||||
TableData table = getRawData(currentTableName);
|
||||
table.setValidPrimaryKey(tableRSHasPK);
|
||||
}
|
||||
}
|
||||
|
||||
//for testing
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
for (int i = 1; i <= metadata.getResultSetSize(); i++) {
|
||||
TableData table = getRawData(metadata.getTablePropertyName(i));
|
||||
this.logger.debug("table "+table.getTableName()+" hasValidPK "+table.hasValidPrimaryKey());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void processRecursiveRow(ResultSet rs) throws SQLException {
|
||||
this.allTableData = new ArrayList();
|
||||
int i = 1;
|
||||
|
||||
while (i <= metadata.getResultSetSize()) {
|
||||
TableData table = new TableData(metadata.getTablePropertyName(i));
|
||||
this.allTableData.add(table);
|
||||
|
||||
while ((i <= metadata.getResultSetSize()) && (metadata.isPKColumn(i))) {
|
||||
Object data = getObject(rs, i);
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Adding column: " + metadata.getColumnPropertyName(i)
|
||||
+ "\tValue: " + data + "\tTable: "
|
||||
+ metadata.getTablePropertyName(i));
|
||||
}
|
||||
table.addData(metadata.getColumnPropertyName(i), true, data);
|
||||
i++;
|
||||
}
|
||||
|
||||
while ((i <= metadata.getResultSetSize()) && (!metadata.isPKColumn(i))) {
|
||||
Object data = getObject(rs, i);
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Adding column: " + metadata.getColumnPropertyName(i)
|
||||
+ "\tValue: " + data + "\tTable: "
|
||||
+ metadata.getTablePropertyName(i));
|
||||
}
|
||||
table.addData(metadata.getColumnPropertyName(i), false, data);
|
||||
i++;
|
||||
}
|
||||
}
|
||||
|
||||
checkResultSetMissesPK();
|
||||
}
|
||||
|
||||
/**
|
||||
* @param rs
|
||||
* @param metadata
|
||||
* @param i
|
||||
* @return
|
||||
*/
|
||||
private Object getObject(ResultSet rs, int i) throws SQLException {
|
||||
|
||||
Object data = rs.getObject(i);
|
||||
|
||||
if (rs.wasNull()) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return metadata.getConverter(i).getPropertyValue(data);
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a HashMap that holds data for the specified table
|
||||
*
|
||||
* @param tableName
|
||||
* The name of the table
|
||||
* @return HashMap
|
||||
*/
|
||||
public TableData getTable(String tableName) {
|
||||
return (TableData) tableMap.get(tableName);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a HashMap that holds data for the specified table If the HashMap
|
||||
* doesn't exist, it will be created. This is used internally to build
|
||||
* the ResultSetRow, whereas getTable is used externally to retrieve existing table data.
|
||||
*
|
||||
* @param tableName
|
||||
* The name of the table
|
||||
* @return HashMap
|
||||
*/
|
||||
private TableData getRawData(String tableName) {
|
||||
|
||||
TableData table = (TableData) tableMap.get(tableName);
|
||||
|
||||
if (table == null) {
|
||||
table = new TableData(tableName);
|
||||
tableMap.put(tableName, table);
|
||||
}
|
||||
|
||||
return table;
|
||||
}
|
||||
|
||||
public List getAllTableData() {
|
||||
if (this.allTableData == null) {
|
||||
this.allTableData = new ArrayList();
|
||||
this.allTableData.addAll(tableMap.values());
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug(allTableData);
|
||||
}
|
||||
|
||||
return this.allTableData;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,145 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.KeyPair;
|
||||
import org.apache.tuscany.das.rdb.config.Relationship;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.Property;
|
||||
|
||||
public class RowObjects {
|
||||
private final Logger logger = Logger.getLogger(RowObjects.class);
|
||||
|
||||
private Map objectsByTableName;
|
||||
|
||||
private List tableObjects;
|
||||
|
||||
private final GraphBuilderMetadata metadata;
|
||||
|
||||
private final TableRegistry registry;
|
||||
|
||||
public RowObjects(GraphBuilderMetadata metadata, TableRegistry registry) {
|
||||
objectsByTableName = new HashMap();
|
||||
tableObjects = new ArrayList();
|
||||
this.metadata = metadata;
|
||||
this.registry = registry;
|
||||
}
|
||||
|
||||
public void put(String key, DataObject value) {
|
||||
objectsByTableName.put(key, value);
|
||||
tableObjects.add(value);
|
||||
}
|
||||
|
||||
public DataObject get(String tablePropertyName) {
|
||||
return (DataObject) objectsByTableName.get(tablePropertyName);
|
||||
}
|
||||
|
||||
void processRelationships() {
|
||||
MappingWrapper wrapper = metadata.getConfigWrapper();
|
||||
if (wrapper.hasRecursiveRelationships()) {
|
||||
processRecursiveRelationships(wrapper);
|
||||
return;
|
||||
}
|
||||
|
||||
Iterator i = metadata.getRelationships().iterator();
|
||||
while (i.hasNext()) {
|
||||
Relationship r = (Relationship) i.next();
|
||||
|
||||
DataObject parentTable = get(wrapper.getTableTypeName(r.getPrimaryKeyTable()));
|
||||
DataObject childTable = get(wrapper.getTableTypeName(r.getForeignKeyTable()));
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Parent table: " + parentTable);
|
||||
this.logger.debug("Child table: " + childTable);
|
||||
}
|
||||
if ((parentTable == null) || (childTable == null)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
Property p = parentTable.getType().getProperty(r.getName());
|
||||
setOrAdd(parentTable, childTable, p);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
private void processRecursiveRelationships(MappingWrapper wrapper) {
|
||||
Iterator i = tableObjects.iterator();
|
||||
while (i.hasNext()) {
|
||||
DataObject table = (DataObject) i.next();
|
||||
|
||||
Iterator relationships = wrapper.getRelationshipsByChildTable(table.getType().getName()).iterator();
|
||||
while (relationships.hasNext()) {
|
||||
Relationship r = (Relationship) relationships.next();
|
||||
|
||||
DataObject parentTable = findParentTable(table, r, wrapper);
|
||||
|
||||
if (parentTable == null) {
|
||||
continue;
|
||||
}
|
||||
|
||||
Property p = parentTable.getType().getProperty(r.getName());
|
||||
setOrAdd(parentTable, table, p);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
private void setOrAdd(DataObject parent, DataObject child, Property p) {
|
||||
if (p.isMany()) {
|
||||
parent.getList(p).add(child);
|
||||
} else {
|
||||
parent.set(p, child);
|
||||
}
|
||||
}
|
||||
|
||||
private DataObject findParentTable(DataObject childTable, Relationship r, MappingWrapper wrapper) {
|
||||
|
||||
List fkValue = new ArrayList();
|
||||
Iterator keyPairs = r.getKeyPair().iterator();
|
||||
while (keyPairs.hasNext()) {
|
||||
KeyPair pair = (KeyPair) keyPairs.next();
|
||||
String childProperty = wrapper.getColumnPropertyName(r.getPrimaryKeyTable(), pair.getForeignKeyColumn());
|
||||
|
||||
Property p = childTable.getType().getProperty(childProperty);
|
||||
fkValue.add(childTable.get(p));
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Trying to find parent of " + r.getForeignKeyTable() + " with FK " + fkValue);
|
||||
}
|
||||
|
||||
DataObject parentTable = registry.get(r.getPrimaryKeyTable(), fkValue);
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Parent table from registry: " + parentTable);
|
||||
}
|
||||
|
||||
return parentTable;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,46 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class SingleTableRegistry implements TableRegistry {
|
||||
|
||||
|
||||
public SingleTableRegistry() {
|
||||
// Empty Constructor
|
||||
}
|
||||
|
||||
public DataObject get(String tableName, List primaryKey) {
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
public void put(String tableName, List primaryKey, DataObject value) {
|
||||
// do nothing
|
||||
|
||||
}
|
||||
|
||||
public boolean contains(String name, List list) {
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,102 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
public class TableData {
|
||||
private final Logger logger = Logger.getLogger(TableData.class);
|
||||
|
||||
private Map columnData = new HashMap();
|
||||
|
||||
private List primaryKey = new ArrayList();
|
||||
|
||||
private final String name;
|
||||
|
||||
private boolean hasValidPrimaryKey = true;
|
||||
|
||||
private boolean hasNullPrimaryKey = false;
|
||||
|
||||
public TableData(String tableName) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Creating TableData for table " + tableName);
|
||||
}
|
||||
|
||||
this.name = tableName;
|
||||
}
|
||||
|
||||
public void addData(String columnName, boolean isPrimaryKeyColumn, Object data) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Adding column " + columnName + " with value " + data);
|
||||
}
|
||||
|
||||
if(data != null)
|
||||
columnData.put(columnName, data);
|
||||
if (isPrimaryKeyColumn) {
|
||||
if (data == null) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Column " + columnName + " is a primary key column and is null");
|
||||
}
|
||||
//hasValidPrimaryKey = false; - if uncommented and JIRA-1464, RecursiveTests.testReadEngineParts() will fail
|
||||
}
|
||||
if(data != null){
|
||||
primaryKey.add(data);
|
||||
}
|
||||
else{
|
||||
hasNullPrimaryKey = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public Object getColumnData(String columnName) {
|
||||
return columnData.get(columnName);
|
||||
}
|
||||
|
||||
public String getTableName() {
|
||||
return this.name;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return
|
||||
*/
|
||||
public List getPrimaryKeyValues() {
|
||||
return primaryKey;
|
||||
}
|
||||
|
||||
public boolean hasValidPrimaryKey() {
|
||||
return hasValidPrimaryKey;
|
||||
}
|
||||
|
||||
public void setValidPrimaryKey(boolean hasValidPK){
|
||||
this.hasValidPrimaryKey = hasValidPK;
|
||||
}
|
||||
|
||||
public boolean isTableEmpty(){
|
||||
return columnData.keySet().isEmpty();
|
||||
}
|
||||
|
||||
public boolean hasNullPrimaryKey(){
|
||||
return this.hasNullPrimaryKey;
|
||||
}
|
||||
}
|
|
@ -1,45 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.impl;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public interface TableRegistry {
|
||||
/**
|
||||
* Get the table with the specified name and primary key
|
||||
*
|
||||
* @param tableName
|
||||
* @param primaryKey
|
||||
* @return DataObject
|
||||
*/
|
||||
DataObject get(String tableName, List primaryKey);
|
||||
|
||||
/**
|
||||
* Add the table with the specified name and primary key
|
||||
*
|
||||
* @param tableName
|
||||
* @param primaryKey
|
||||
* @param value
|
||||
*/
|
||||
void put(String tableName, List primaryKey, DataObject value);
|
||||
|
||||
boolean contains(String name, List list);
|
||||
}
|
|
@ -1,137 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.graphbuilder.schema;
|
||||
|
||||
import java.sql.Types;
|
||||
|
||||
import org.apache.tuscany.sdo.SDOPackage;
|
||||
|
||||
import commonj.sdo.Type;
|
||||
import commonj.sdo.helper.TypeHelper;
|
||||
|
||||
/**
|
||||
*/
|
||||
public class ResultSetTypeMap {
|
||||
|
||||
public static final ResultSetTypeMap INSTANCE = new ResultSetTypeMap();
|
||||
|
||||
/**
|
||||
* Constructor for ResultSetTypeMap.
|
||||
*/
|
||||
protected ResultSetTypeMap() {
|
||||
// Empty Constructor
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
* @param type
|
||||
* @param isNullable
|
||||
* @return
|
||||
*/
|
||||
public Type getEDataType(int type, boolean isNullable) {
|
||||
|
||||
TypeHelper helper = TypeHelper.INSTANCE;
|
||||
SDOPackage.eINSTANCE.eClass();
|
||||
switch (type) {
|
||||
|
||||
case Types.CHAR:
|
||||
case Types.VARCHAR:
|
||||
case Types.LONGVARCHAR:
|
||||
return helper.getType("commonj.sdo", "String");
|
||||
|
||||
case Types.NUMERIC:
|
||||
case Types.DECIMAL:
|
||||
return helper.getType("commonj.sdo", "Decimal");
|
||||
|
||||
case Types.BIT:
|
||||
case Types.BOOLEAN:
|
||||
if (isNullable) {
|
||||
return helper.getType("commonj.sdo", "Boolean");
|
||||
}
|
||||
return helper.getType("commonj.sdo", "boolean");
|
||||
|
||||
|
||||
case Types.TINYINT:
|
||||
case Types.SMALLINT:
|
||||
case Types.INTEGER:
|
||||
if (isNullable) {
|
||||
return helper.getType("commonj.sdo", "IntObject");
|
||||
}
|
||||
|
||||
return helper.getType("commonj.sdo", "Int");
|
||||
|
||||
|
||||
case Types.BIGINT:
|
||||
if (isNullable) {
|
||||
return helper.getType("commonj.sdo", "Long");
|
||||
}
|
||||
return helper.getType("commonj.sdo", "long");
|
||||
|
||||
case Types.REAL:
|
||||
if (isNullable) {
|
||||
return helper.getType("commonj.sdo", "Float");
|
||||
}
|
||||
return helper.getType("commonj.sdo", "float");
|
||||
|
||||
|
||||
case Types.FLOAT:
|
||||
case Types.DOUBLE:
|
||||
if (isNullable) {
|
||||
return helper.getType("commonj.sdo", "Double");
|
||||
}
|
||||
return helper.getType("commonj.sdo", "double");
|
||||
|
||||
|
||||
case Types.BINARY:
|
||||
case Types.VARBINARY:
|
||||
case Types.LONGVARBINARY:
|
||||
return helper.getType("commonj.sdo", "Bytes");
|
||||
|
||||
case Types.DATE:
|
||||
case Types.TIME:
|
||||
case Types.TIMESTAMP:
|
||||
return helper.getType("commonj.sdo", "Date");
|
||||
|
||||
case Types.CLOB:
|
||||
return helper.getType("commonj.sdo", "Object");
|
||||
|
||||
case Types.BLOB:
|
||||
return helper.getType("commonj.sdo", "Bytes");
|
||||
|
||||
case Types.ARRAY:
|
||||
return helper.getType("commonj.sdo", "Object");
|
||||
|
||||
case Types.DISTINCT:
|
||||
case Types.STRUCT:
|
||||
case Types.REF:
|
||||
case Types.DATALINK:
|
||||
case Types.JAVA_OBJECT:
|
||||
return helper.getType("commonj.sdo", "Object");
|
||||
|
||||
default:
|
||||
return helper.getType("commonj.sdo", "Object");
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public Type getType(int columnType, boolean b) {
|
||||
return getEDataType(columnType, b);
|
||||
}
|
||||
|
||||
}
|
|
@ -1,79 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.sql.Connection;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
public class ApplyChangesCommandImpl extends BaseCommandImpl {
|
||||
|
||||
private final Logger logger = Logger.getLogger(ApplyChangesCommandImpl.class);
|
||||
|
||||
private ChangeSummarizer summarizer = new ChangeSummarizer();
|
||||
|
||||
public ApplyChangesCommandImpl(MappingWrapper config, Connection connection) {
|
||||
this.configWrapper = config;
|
||||
if (connection != null) {
|
||||
setConnection(connection, config.getConfig());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public void setConnection(ConnectionImpl connection) {
|
||||
summarizer.setConnection(connection);
|
||||
}
|
||||
|
||||
public void execute(DataObject root) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Executing ApplyChangesCmd");
|
||||
}
|
||||
|
||||
if (summarizer.getConnection() == null) {
|
||||
throw new RuntimeException("A connection must be provided");
|
||||
}
|
||||
|
||||
if (!root.equals(root.getDataGraph().getRootObject())) {
|
||||
throw new RuntimeException("'root' argument must be the root of the datagraph");
|
||||
}
|
||||
|
||||
summarizer.setMapping(configWrapper);
|
||||
|
||||
Changes changes = summarizer.loadChanges(root);
|
||||
|
||||
boolean success = false;
|
||||
try {
|
||||
changes.execute();
|
||||
success = true;
|
||||
} finally {
|
||||
if (success) {
|
||||
summarizer.getConnection().cleanUp();
|
||||
} else {
|
||||
summarizer.getConnection().errorCleanUp();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -1,62 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.sql.Connection;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
|
||||
public abstract class BaseCommandImpl {
|
||||
protected MappingWrapper configWrapper = new MappingWrapper();
|
||||
|
||||
//when no config in method params, useGetGeneratedKeys will default to True
|
||||
//as DBMS metadata method is not reliable in all cases
|
||||
public void setConnection(Connection connection) {
|
||||
setConnection(new ConnectionImpl(connection));
|
||||
}
|
||||
|
||||
public void setConnection(Connection connection, Config config) {
|
||||
boolean managed = true;
|
||||
String generatedKeysSupported = null;
|
||||
|
||||
if (config != null){
|
||||
if(config.getConnectionInfo() != null) {
|
||||
managed = config.getConnectionInfo().isManagedtx();
|
||||
}
|
||||
|
||||
generatedKeysSupported = config.getGeneratedKeysSupported();
|
||||
|
||||
setConnection(connection, managed, generatedKeysSupported);
|
||||
}
|
||||
else{
|
||||
setConnection(connection);
|
||||
}
|
||||
}
|
||||
|
||||
public void setConnection(Connection connection, boolean manageTransaction, String generatedKeysSupported) {
|
||||
ConnectionImpl c = new ConnectionImpl(connection);
|
||||
c.setManageTransactions(manageTransaction);
|
||||
c.setGeneratedKeysSupported(generatedKeysSupported);
|
||||
setConnection(c);
|
||||
}
|
||||
|
||||
public abstract void setConnection(ConnectionImpl c);
|
||||
|
||||
}
|
|
@ -1,177 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.Create;
|
||||
import org.apache.tuscany.das.rdb.config.Delete;
|
||||
import org.apache.tuscany.das.rdb.config.Table;
|
||||
import org.apache.tuscany.das.rdb.config.Update;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.TableWrapper;
|
||||
import org.apache.tuscany.das.rdb.generator.impl.DeleteGenerator;
|
||||
import org.apache.tuscany.das.rdb.generator.impl.InsertGenerator;
|
||||
import org.apache.tuscany.das.rdb.generator.impl.UpdateGenerator;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class ChangeFactory {
|
||||
private final Logger logger = Logger.getLogger(ChangeFactory.class);
|
||||
|
||||
private InsertCommandImpl createCommand;
|
||||
|
||||
private UpdateCommandImpl updateCommand;
|
||||
|
||||
private DeleteCommandImpl deleteCommand;
|
||||
|
||||
private final MappingWrapper mapping;
|
||||
|
||||
private final ConnectionImpl connection;
|
||||
|
||||
public ChangeFactory(MappingWrapper mapping, ConnectionImpl connection) {
|
||||
this.mapping = mapping;
|
||||
this.connection = connection;
|
||||
}
|
||||
|
||||
public void setCreateCommand(InsertCommandImpl cmd) {
|
||||
createCommand = cmd;
|
||||
}
|
||||
|
||||
public void setUpdateCommand(UpdateCommandImpl cmd) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Setting Update Command to " + cmd);
|
||||
}
|
||||
|
||||
updateCommand = cmd;
|
||||
}
|
||||
|
||||
public void setDeleteCommand(DeleteCommandImpl cmd) {
|
||||
deleteCommand = cmd;
|
||||
}
|
||||
|
||||
ChangeOperation createUpdateOperation(DataObject changedObject, String propagatedID) {
|
||||
return new UpdateOperation(getUpdateCommand(changedObject), changedObject, propagatedID);
|
||||
}
|
||||
|
||||
ChangeOperation createUpdateOperation(DataObject changedObject) {
|
||||
return createUpdateOperation(changedObject, null);
|
||||
}
|
||||
|
||||
ChangeOperation createDeleteOperation(DataObject changedObject) {
|
||||
return new DeleteOperation(getDeleteCommand(changedObject), changedObject);
|
||||
}
|
||||
|
||||
ChangeOperation createInsertOperation(DataObject changedObject, String propagatedID) {
|
||||
return new CreateOperation(getCreateCommand(changedObject), changedObject, propagatedID);
|
||||
}
|
||||
|
||||
private InsertCommandImpl getCreateCommand(DataObject changedObject) {
|
||||
|
||||
if (createCommand == null) {
|
||||
Table table = mapping.getTableByTypeName(changedObject.getType().getName());
|
||||
if (table == null) {
|
||||
if (changedObject.getType().getProperty("ID") != null) {
|
||||
// If the table is not defined in the config, assume it has a primary key of "ID"
|
||||
mapping.addPrimaryKey(changedObject.getType().getName() + ".ID");
|
||||
table = mapping.getTableByTypeName(changedObject.getType().getName());
|
||||
} else {
|
||||
throw new RuntimeException("Table " + changedObject.getType().getName()
|
||||
+ " was changed in the DataGraph but is not present in the Config");
|
||||
}
|
||||
}
|
||||
|
||||
Create create = table.getCreate();
|
||||
|
||||
if (create == null) {
|
||||
createCommand = InsertGenerator.INSTANCE.getInsertCommand(mapping, changedObject, table);
|
||||
} else {
|
||||
createCommand = new InsertCommandImpl(create);
|
||||
}
|
||||
createCommand.setConnection(connection);
|
||||
createCommand.configWrapper = mapping;
|
||||
}
|
||||
return createCommand;
|
||||
}
|
||||
|
||||
private DeleteCommandImpl getDeleteCommand(DataObject changedObject) {
|
||||
|
||||
if (deleteCommand == null) {
|
||||
Table table = mapping.getTableByTypeName(changedObject.getType().getName());
|
||||
if (table == null) {
|
||||
if (changedObject.getType().getProperty("ID") != null) {
|
||||
// If the table is not defined in the config, assume it has a primary key of "ID"
|
||||
mapping.addPrimaryKey(changedObject.getType().getName() + ".ID");
|
||||
table = mapping.getTableByTypeName(changedObject.getType().getName());
|
||||
} else {
|
||||
throw new RuntimeException("Table " + changedObject.getType().getName()
|
||||
+ " was changed in the DataGraph but is not present in the Config");
|
||||
}
|
||||
}
|
||||
|
||||
Delete delete = table.getDelete();
|
||||
|
||||
if (delete == null) {
|
||||
deleteCommand = DeleteGenerator.INSTANCE.getDeleteCommand(mapping, table);//JIRA-952
|
||||
} else {
|
||||
deleteCommand = new DeleteCommandImpl(delete);
|
||||
}
|
||||
deleteCommand.setConnection(connection);
|
||||
deleteCommand.configWrapper = mapping;
|
||||
}
|
||||
return deleteCommand;
|
||||
}
|
||||
|
||||
private UpdateCommandImpl getUpdateCommand(DataObject changedObject) {
|
||||
|
||||
Table table = mapping.getTableByTypeName(changedObject.getType().getName());
|
||||
if (table == null) {
|
||||
if (changedObject.getType().getProperty("ID") != null) {
|
||||
mapping.addPrimaryKey(changedObject.getType().getName() + ".ID");
|
||||
table = mapping.getTableByTypeName(changedObject.getType().getName());
|
||||
} else {
|
||||
throw new RuntimeException("Table " + changedObject.getType().getName()
|
||||
+ " was changed in the DataGraph but is not present in the Config");
|
||||
}
|
||||
}
|
||||
Update update = table.getUpdate();
|
||||
if (update == null) {
|
||||
updateCommand = UpdateGenerator.INSTANCE.getUpdateCommand(mapping, changedObject, table);
|
||||
} else {
|
||||
TableWrapper t = new TableWrapper(table);
|
||||
if (t.getCollisionColumn() != null) {
|
||||
updateCommand = new OptimisticWriteCommandImpl(update);
|
||||
} else {
|
||||
updateCommand = new UpdateCommandImpl(update);
|
||||
}
|
||||
}
|
||||
updateCommand.setConnection(connection);
|
||||
updateCommand.configWrapper = mapping;
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Returning updateCommand: " + updateCommand);
|
||||
}
|
||||
|
||||
return updateCommand;
|
||||
}
|
||||
|
||||
public MappingWrapper getConfig() {
|
||||
return this.mapping;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,87 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.util.Iterator;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
/**
|
||||
*/
|
||||
public abstract class ChangeOperation {
|
||||
protected DatabaseObject dObject;
|
||||
|
||||
protected String propagatedID;
|
||||
|
||||
private final Logger logger = Logger.getLogger(ChangeOperation.class);
|
||||
|
||||
private final WriteCommandImpl writeCommand;
|
||||
|
||||
private boolean isInsert;
|
||||
|
||||
|
||||
public ChangeOperation(DeleteCommandImpl command) {
|
||||
writeCommand = command;
|
||||
}
|
||||
|
||||
public ChangeOperation(InsertCommandImpl command, DataObject changedObject) {
|
||||
writeCommand = command;
|
||||
dObject = new DatabaseObject(command.getMappingModel(), changedObject);
|
||||
this.isInsert = true;
|
||||
}
|
||||
|
||||
public ChangeOperation(UpdateCommandImpl command, DataObject changedObject) {
|
||||
writeCommand = command;
|
||||
dObject = new DatabaseObject(command.getMappingModel(), changedObject);
|
||||
}
|
||||
|
||||
public void execute() {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Executing change operation");
|
||||
}
|
||||
|
||||
Iterator i = writeCommand.getParameters().iterator();
|
||||
while (i.hasNext()) {
|
||||
ParameterExtendedImpl parm = (ParameterExtendedImpl) i.next();
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("setting " + parm.getName() + " to " + dObject.get(parm.getName()));
|
||||
}
|
||||
|
||||
parm.setValue(dObject.get(parm.getName()));
|
||||
}
|
||||
|
||||
writeCommand.basicExecute();
|
||||
|
||||
if (isInsert && (propagatedID != null)) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Propagating key " + propagatedID);
|
||||
}
|
||||
int id = writeCommand.getGeneratedKey();
|
||||
dObject.setPropagatedID(propagatedID, id);
|
||||
}
|
||||
}
|
||||
|
||||
public String getTableName() {
|
||||
return dObject.getTableName();
|
||||
}
|
||||
|
||||
}
|
|
@ -1,241 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.config.Column;
|
||||
import org.apache.tuscany.das.rdb.config.Relationship;
|
||||
import org.apache.tuscany.das.rdb.config.Table;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.RelationshipWrapper;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.TableWrapper;
|
||||
import org.apache.tuscany.das.rdb.util.CollectionsUtil;
|
||||
import org.apache.tuscany.sdo.impl.ChangeSummaryImpl;
|
||||
|
||||
import commonj.sdo.ChangeSummary;
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.Property;
|
||||
import commonj.sdo.Type;
|
||||
|
||||
public class ChangeSummarizer {
|
||||
|
||||
private final Logger logger = Logger.getLogger(ChangeSummarizer.class);
|
||||
|
||||
private Changes changes = new Changes();
|
||||
|
||||
private FactoryRegistry registry;
|
||||
|
||||
private MappingWrapper mapping = new MappingWrapper();
|
||||
|
||||
private ConnectionImpl connection;
|
||||
|
||||
private Map generatedKeys = new HashMap();
|
||||
|
||||
public ChangeSummarizer() {
|
||||
// Empty Constructor
|
||||
}
|
||||
|
||||
public Changes loadChanges(DataObject root) {
|
||||
ChangeSummary changeSummary = root.getDataGraph().getChangeSummary();
|
||||
if (changeSummary.isLogging()) {
|
||||
((ChangeSummaryImpl) changeSummary).summarize();
|
||||
}
|
||||
|
||||
List changedObjects = changeSummary.getChangedDataObjects();
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("List of changed objects contains " + changedObjects.size() + " object(s)");
|
||||
}
|
||||
|
||||
changes.setInsertOrder(mapping.getInsertOrder());
|
||||
changes.setDeleteOrder(mapping.getDeleteOrder());
|
||||
|
||||
Iterator i = changedObjects.iterator();
|
||||
while (i.hasNext()) {
|
||||
DataObject o = (DataObject) i.next();
|
||||
|
||||
if (!(o.equals(root))) {
|
||||
createChange(changeSummary, o);
|
||||
}
|
||||
}
|
||||
|
||||
return changes;
|
||||
}
|
||||
|
||||
public void createChange(ChangeSummary changeSummary, DataObject changedObject) {
|
||||
|
||||
if (changeSummary.isCreated(changedObject)) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Change is a create");
|
||||
}
|
||||
if (!changeSummary.isDeleted(changedObject)) {
|
||||
ChangeFactory factory = getRegistry().getFactory(changedObject.getType());
|
||||
String propagatedID = (String) generatedKeys.get(changedObject.getType().getName());
|
||||
changes.addInsert(factory.createInsertOperation(changedObject, propagatedID));
|
||||
}
|
||||
} else if (changeSummary.isDeleted(changedObject)) {
|
||||
ChangeFactory factory = getRegistry().getFactory(changedObject.getType());
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Change is a delete");
|
||||
}
|
||||
changes.addDelete(factory.createDeleteOperation(changedObject));
|
||||
} else {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Change is a modify");
|
||||
}
|
||||
List attrList = changeSummary.getOldValues(changedObject);
|
||||
if (hasAttributeChange(attrList)) {
|
||||
ChangeFactory factory = getRegistry().getFactory(changedObject.getType());
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Attribute Change for " + changedObject.getType().getName());
|
||||
}
|
||||
String propagatedID = (String) generatedKeys.get(changedObject.getType().getName());
|
||||
changes.addUpdate(factory.createUpdateOperation(changedObject, propagatedID));
|
||||
} else {
|
||||
List values = changeSummary.getOldValues(changedObject);
|
||||
Iterator i = values.iterator();
|
||||
while (i.hasNext()) {
|
||||
ChangeSummary.Setting setting = (ChangeSummary.Setting) i.next();
|
||||
if (!setting.getProperty().getType().isDataType()) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Reference change for " + changedObject.getType().getName());
|
||||
}
|
||||
Property ref = setting.getProperty();
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug(ref.getName());
|
||||
}
|
||||
if (hasState(ref, changedObject)) {
|
||||
ChangeFactory factory = getRegistry().getFactory(changedObject.getType());
|
||||
changes.addUpdate(factory.createUpdateOperation(changedObject));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private boolean hasState(Property ref, DataObject changedObject) {
|
||||
if (ref.getOpposite().isMany()) {
|
||||
return true;
|
||||
}
|
||||
|
||||
MappingWrapper mw = this.mapping;
|
||||
if (mw.getConfig() == null) {
|
||||
mw = registry.getFactory(changedObject.getType()).getConfig();
|
||||
}
|
||||
if (mw.getConfig() == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
Relationship rel = mw.getRelationshipByReference(ref);
|
||||
|
||||
if (!rel.isMany()) {
|
||||
if (rel.isKeyRestricted()) {
|
||||
throw new RuntimeException("Can not modify a one to one relationship that is key restricted");
|
||||
}
|
||||
// This is a one-one relationship
|
||||
Table t = mapping.getTableByTypeName(changedObject.getType().getName());
|
||||
TableWrapper tw = new TableWrapper(t);
|
||||
RelationshipWrapper rw = new RelationshipWrapper(rel);
|
||||
if ((rel.getForeignKeyTable().equals(t.getTableName()))
|
||||
&& (CollectionsUtil.disjoint(tw.getPrimaryKeyProperties(), rw.getForeignKeys()))) {
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
private boolean hasAttributeChange(List theChanges) {
|
||||
Iterator i = theChanges.iterator();
|
||||
while (i.hasNext()) {
|
||||
ChangeSummary.Setting setting = (ChangeSummary.Setting) i.next();
|
||||
if (setting.getProperty().getType().isDataType()) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public void addCreateCommand(Type type, Command cmd) {
|
||||
ChangeFactory cf = getRegistry().getFactory(type);
|
||||
cf.setCreateCommand((InsertCommandImpl) cmd);
|
||||
((CommandImpl) cmd).setConnection(connection);
|
||||
}
|
||||
|
||||
public void addUpdateCommand(Type type, Command cmd) {
|
||||
ChangeFactory cf = getRegistry().getFactory(type);
|
||||
cf.setUpdateCommand((UpdateCommandImpl) cmd);
|
||||
((CommandImpl) cmd).setConnection(connection);
|
||||
}
|
||||
|
||||
public void addDeleteCommand(Type type, Command cmd) {
|
||||
ChangeFactory cf = getRegistry().getFactory(type);
|
||||
cf.setDeleteCommand((DeleteCommandImpl) cmd);
|
||||
((CommandImpl) cmd).setConnection(connection);
|
||||
|
||||
}
|
||||
|
||||
private FactoryRegistry getRegistry() {
|
||||
if (this.registry == null) {
|
||||
this.registry = new FactoryRegistry(mapping, connection);
|
||||
}
|
||||
return this.registry;
|
||||
}
|
||||
|
||||
public void setConnection(ConnectionImpl connection) {
|
||||
this.connection = connection;
|
||||
}
|
||||
|
||||
public void setMapping(MappingWrapper map) {
|
||||
this.mapping = map;
|
||||
|
||||
if (mapping.getConfig() == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
Iterator i = mapping.getConfig().getTable().iterator();
|
||||
while (i.hasNext()) {
|
||||
Table t = (Table) i.next();
|
||||
Iterator columns = t.getColumn().iterator();
|
||||
while (columns.hasNext()) {
|
||||
Column c = (Column) columns.next();
|
||||
if (c.isPrimaryKey() && c.isGenerated()) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("adding generated key " + t.getTableName() + "." + c.getColumnName());
|
||||
}
|
||||
|
||||
generatedKeys.put(t.getTableName(), c.getColumnName());
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public ConnectionImpl getConnection() {
|
||||
return this.connection;
|
||||
}
|
||||
}
|
|
@ -1,82 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Manages a set of graph-change operations. This simple implementaiton can be
|
||||
* replaced with a version that provides R/I sorting
|
||||
*
|
||||
*/
|
||||
public class Changes {
|
||||
|
||||
private InsertList inserts = new InsertList();
|
||||
|
||||
private UpdateList updates = new UpdateList();
|
||||
|
||||
private DeleteList deletes = new DeleteList();
|
||||
|
||||
public void addInsert(ChangeOperation c) {
|
||||
inserts.add(c);
|
||||
}
|
||||
|
||||
public void addUpdate(ChangeOperation c) {
|
||||
updates.add(c);
|
||||
}
|
||||
|
||||
public void addDelete(ChangeOperation c) {
|
||||
deletes.add(c);
|
||||
}
|
||||
|
||||
/**
|
||||
* Execute all my change
|
||||
*/
|
||||
public void execute() {
|
||||
|
||||
Iterator i = inserts.getSortedList().iterator();
|
||||
while (i.hasNext()) {
|
||||
ChangeOperation c = (ChangeOperation) i.next();
|
||||
c.execute();
|
||||
}
|
||||
|
||||
i = updates.getSortedList().iterator();
|
||||
while (i.hasNext()) {
|
||||
ChangeOperation c = (ChangeOperation) i.next();
|
||||
c.execute();
|
||||
}
|
||||
|
||||
i = deletes.getSortedList().iterator();
|
||||
while (i.hasNext()) {
|
||||
ChangeOperation c = (ChangeOperation) i.next();
|
||||
c.execute();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public void setInsertOrder(List insertOrder) {
|
||||
inserts.setOrder(insertOrder);
|
||||
}
|
||||
|
||||
public void setDeleteOrder(List deleteOrder) {
|
||||
deletes.setOrder(deleteOrder);
|
||||
}
|
||||
|
||||
}
|
|
@ -1,31 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
public class CollisionParameter extends ParameterExtendedImpl {
|
||||
|
||||
private boolean isSet;
|
||||
|
||||
public void setValue(Object value) {
|
||||
if (!isSet) {
|
||||
this.value = value;
|
||||
isSet = true;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,178 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.net.URL;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.helper.XSDHelper;
|
||||
|
||||
public abstract class CommandImpl extends BaseCommandImpl implements Command {
|
||||
|
||||
protected Statement statement;
|
||||
|
||||
protected ParametersExtendedImpl parameters = new ParametersExtendedImpl();
|
||||
|
||||
protected ResultSetShape resultSetShape;
|
||||
|
||||
public CommandImpl(String sqlString) {
|
||||
statement = new Statement(sqlString);
|
||||
|
||||
try {
|
||||
URL url = getClass().getResource("/xml/sdoJava.xsd");
|
||||
if (url == null) {
|
||||
throw new RuntimeException("Could not find resource: xml/sdoJava.xsd");
|
||||
}
|
||||
|
||||
InputStream inputStream = url.openStream();
|
||||
XSDHelper.INSTANCE.define(inputStream, url.toString());
|
||||
inputStream.close();
|
||||
} catch (IOException ex) {
|
||||
throw new RuntimeException(ex);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public CommandImpl(org.apache.tuscany.das.rdb.config.Command command) {
|
||||
this(command.getSQL());
|
||||
|
||||
if(command.getParameter() != null && command.getParameter().size() > 0) {
|
||||
Iterator itr = command.getParameter().iterator();
|
||||
int index = 1;
|
||||
while(itr.hasNext()){
|
||||
org.apache.tuscany.das.rdb.config.impl.ParameterImpl param = (org.apache.tuscany.das.rdb.config.impl.ParameterImpl)itr.next();
|
||||
if(param.getIndex() <= 0){
|
||||
param.setIndex(index);
|
||||
index++;
|
||||
}
|
||||
ParameterExtendedImpl paramExt = new ParameterExtendedImpl(param);
|
||||
addToParameters(paramExt);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void addToParameters(ParameterExtendedImpl paramExt) {
|
||||
this.parameters.getParameter().add(paramExt);
|
||||
if(paramExt.getDirection().equals(ParameterExtendedImpl.IN)){
|
||||
parameters.getInParameters().add(paramExt);
|
||||
}
|
||||
else{
|
||||
parameters.getOutParameters().add(paramExt);
|
||||
}
|
||||
}
|
||||
|
||||
public abstract void execute();
|
||||
|
||||
public abstract DataObject executeQuery();
|
||||
|
||||
public void setParameter(int index, Object value) {
|
||||
ParameterExtendedImpl param = parameters.getParameter(index);
|
||||
if(param != null){
|
||||
param.setValue(value);
|
||||
return;
|
||||
}
|
||||
|
||||
param = new ParameterExtendedImpl();
|
||||
param.setIndex(index);
|
||||
param.setValue(value);
|
||||
param.setDirection(ParameterExtendedImpl.IN);
|
||||
parameters.getParameter().add(param);
|
||||
parameters.getInParameters().add(param);
|
||||
}
|
||||
|
||||
public void addParameter(ParameterExtendedImpl param) {
|
||||
//eliminate/replace duplicate params, index is filled, so can check it for duplicate
|
||||
ParameterExtendedImpl paramExt = parameters.getParameter(param.getIndex());
|
||||
if(paramExt != null)
|
||||
paramExt = new ParameterExtendedImpl(param);
|
||||
|
||||
paramExt = parameters.getParameter(param.getIndex(), param.getDirection());
|
||||
if(paramExt != null){
|
||||
paramExt = new ParameterExtendedImpl(param);
|
||||
return;
|
||||
}
|
||||
|
||||
addToParameters(param);
|
||||
}
|
||||
|
||||
public List getParameters() {
|
||||
return parameters.getParameter();
|
||||
}
|
||||
|
||||
public Object getParameter(int index) {
|
||||
return parameters.getParameter(index).getValue();
|
||||
}
|
||||
|
||||
public void setConnection(ConnectionImpl connection) {
|
||||
statement.setConnection(connection);
|
||||
}
|
||||
|
||||
protected ConnectionImpl getConnection() {
|
||||
return statement.getConnection();
|
||||
}
|
||||
|
||||
/*
|
||||
* The default impl is to throw an exception. This is overridden by InsertCommandImpl
|
||||
*/
|
||||
public int getGeneratedKey() {
|
||||
|
||||
throw new RuntimeException("This method is only valid for insert commands");
|
||||
}
|
||||
|
||||
public void close() {
|
||||
statement.close();
|
||||
}
|
||||
|
||||
//default direction IN assumed
|
||||
public void setParameter(String name, Object value) {
|
||||
ParameterExtendedImpl param = parameters.getParameter(name);
|
||||
if(param != null){
|
||||
param.setValue(value);
|
||||
return;
|
||||
}
|
||||
|
||||
param = new ParameterExtendedImpl();
|
||||
param.setIndex(parameters.getParameter().size()+1);
|
||||
param.setName(name);
|
||||
param.setValue(value);
|
||||
param.setDirection(ParameterExtendedImpl.IN);
|
||||
parameters.getParameter().add(param);
|
||||
parameters.getInParameters().add(param);
|
||||
}
|
||||
|
||||
//default direction IN assumed
|
||||
public Object getParameter(String name) {
|
||||
Iterator itr = this.parameters.getInParameters().iterator();
|
||||
while(itr.hasNext()){
|
||||
ParameterExtendedImpl param = ((ParameterExtendedImpl)itr.next());
|
||||
|
||||
if(param.getName() != null && param.getName().equalsIgnoreCase(name)){
|
||||
return param.value;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,154 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.sql.CallableStatement;
|
||||
import java.sql.Connection;
|
||||
import java.sql.DatabaseMetaData;
|
||||
import java.sql.PreparedStatement;
|
||||
import java.sql.ResultSet;
|
||||
import java.sql.SQLException;
|
||||
import java.sql.Statement;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
public class ConnectionImpl {
|
||||
|
||||
private final Logger logger = Logger.getLogger(ConnectionImpl.class);
|
||||
|
||||
private Connection connection;
|
||||
|
||||
private boolean managingTransaction = true;
|
||||
|
||||
private String generatedKeysSupported = null;
|
||||
|
||||
public ConnectionImpl(Connection connection) {
|
||||
this.connection = connection;
|
||||
|
||||
try {
|
||||
if (connection.getAutoCommit()) {
|
||||
throw new RuntimeException("AutoCommit must be off");
|
||||
}
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public Connection getJDBCConnection() {
|
||||
return connection;
|
||||
}
|
||||
|
||||
public String getGeneratedKeysSupported() {
|
||||
return this.generatedKeysSupported;
|
||||
}
|
||||
|
||||
public void setGeneratedKeysSupported(String useGetGeneratedKeys){
|
||||
this.generatedKeysSupported = useGetGeneratedKeys;
|
||||
}
|
||||
|
||||
public boolean isGeneratedKeysSupported() {
|
||||
try{
|
||||
if(this.generatedKeysSupported == null){
|
||||
DatabaseMetaData dbmsMetadata = this.connection.getMetaData();
|
||||
boolean supportsGetGeneratedKeys = dbmsMetadata.supportsGetGeneratedKeys();
|
||||
if(supportsGetGeneratedKeys){
|
||||
this.generatedKeysSupported = "true";
|
||||
}
|
||||
//currently DERBY partially supports this feature and thus returns FALSE,
|
||||
//this hardcoding is needed as the partial support is enough for DAS
|
||||
//we can remove this later, when DERBY change the behaviour of it's "supportsGetGeneratedKeys"
|
||||
else if(dbmsMetadata.getDatabaseProductName().indexOf("Derby") > 0){
|
||||
this.generatedKeysSupported = "true";
|
||||
}
|
||||
else{
|
||||
this.generatedKeysSupported = "false";
|
||||
}
|
||||
}
|
||||
}catch(Exception e){//can be from supportsGetGeneratedKeys or due to absense of supportsGetGeneratedKeys
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("exception setiing useGetGeneratedKeys false");
|
||||
}
|
||||
this.generatedKeysSupported = "false";
|
||||
}
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("returning useGetGeneratedKeys():"+ this.generatedKeysSupported);
|
||||
}
|
||||
return Boolean.parseBoolean(this.generatedKeysSupported);
|
||||
}
|
||||
|
||||
public void cleanUp() {
|
||||
try {
|
||||
if (managingTransaction) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Committing Transaction");
|
||||
}
|
||||
connection.commit();
|
||||
}
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
public void errorCleanUp() {
|
||||
try {
|
||||
if (managingTransaction) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Rolling back Transaction");
|
||||
}
|
||||
connection.rollback();
|
||||
}
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
public PreparedStatement prepareStatement(String queryString, String[] returnKeys) throws SQLException {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Preparing Statement: " + queryString);
|
||||
this.logger.debug("Boolean value for use gen key: " + this.generatedKeysSupported);
|
||||
}
|
||||
|
||||
if (isGeneratedKeysSupported()) {
|
||||
return connection.prepareStatement(queryString, Statement.RETURN_GENERATED_KEYS);
|
||||
} else if (returnKeys.length > 0) {
|
||||
return connection.prepareStatement(queryString, returnKeys);
|
||||
}
|
||||
|
||||
return connection.prepareStatement(queryString);
|
||||
}
|
||||
|
||||
public PreparedStatement preparePagedStatement(String queryString) throws SQLException {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Preparing Statement: " + queryString);
|
||||
}
|
||||
|
||||
return connection.prepareStatement(queryString, ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
|
||||
}
|
||||
|
||||
public void setManageTransactions(boolean manageTransactions) {
|
||||
managingTransaction = manageTransactions;
|
||||
|
||||
}
|
||||
|
||||
public CallableStatement prepareCall(String queryString) throws SQLException {
|
||||
return connection.prepareCall(queryString);
|
||||
}
|
||||
}
|
|
@ -1,30 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class CreateOperation extends ChangeOperation {
|
||||
|
||||
public CreateOperation(InsertCommandImpl command, DataObject changedObject, String id) {
|
||||
super(command, changedObject);
|
||||
this.propagatedID = id;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,50 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.io.InputStream;
|
||||
import java.sql.Connection;
|
||||
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.DASFactory;
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
|
||||
public class DASFactoryImpl implements DASFactory {
|
||||
|
||||
public DAS createDAS(InputStream configStream) {
|
||||
return new DASImpl(configStream);
|
||||
}
|
||||
|
||||
public DAS createDAS(Config config) {
|
||||
return new DASImpl(config);
|
||||
}
|
||||
|
||||
public DAS createDAS(InputStream configStream, Connection connection) {
|
||||
return new DASImpl(configStream, connection);
|
||||
}
|
||||
|
||||
public DAS createDAS(Config config, Connection connection) {
|
||||
return new DASImpl(config, connection);
|
||||
}
|
||||
|
||||
public DAS createDAS(Connection connection) {
|
||||
return new DASImpl(connection);
|
||||
}
|
||||
|
||||
}
|
|
@ -1,313 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.io.InputStream;
|
||||
import java.sql.Connection;
|
||||
import java.sql.DriverManager;
|
||||
import java.sql.SQLException;
|
||||
import java.util.Collections;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.Map;
|
||||
|
||||
import javax.naming.InitialContext;
|
||||
import javax.naming.NamingException;
|
||||
import javax.sql.DataSource;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.ConfigFactory;
|
||||
import org.apache.tuscany.das.rdb.config.ConnectionInfo;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.exception.DataSourceInitializationException;
|
||||
import org.apache.tuscany.das.rdb.util.ConfigUtil;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
/**
|
||||
* An ConfiguredCommandFactory produces instances of Command and ApplyChangesCommand. This
|
||||
* factory is initialized with a configuration that defines
|
||||
* the commands it produces.
|
||||
*
|
||||
*/
|
||||
public class DASImpl implements DAS {
|
||||
|
||||
private MappingWrapper configWrapper;
|
||||
|
||||
private Connection connection;
|
||||
|
||||
private Map commands = new HashMap();
|
||||
|
||||
public DASImpl(InputStream stream) {
|
||||
this(ConfigUtil.loadConfig(stream));
|
||||
|
||||
}
|
||||
|
||||
public DASImpl(Config inConfig) {
|
||||
Config cfg = inConfig;
|
||||
if (cfg == null) {
|
||||
cfg = ConfigFactory.INSTANCE.createConfig();
|
||||
}
|
||||
this.configWrapper = new MappingWrapper(cfg);
|
||||
|
||||
Iterator i = configWrapper.getConfig().getCommand().iterator();
|
||||
while (i.hasNext()) {
|
||||
org.apache.tuscany.das.rdb.config.Command commandConfig =
|
||||
(org.apache.tuscany.das.rdb.config.Command) i.next();
|
||||
String kind = commandConfig.getKind();
|
||||
if (kind.equalsIgnoreCase("select")) {
|
||||
commands.put(commandConfig.getName(), new ReadCommandImpl(commandConfig, configWrapper, commandConfig.getResultDescriptor()));
|
||||
} else if (kind.equalsIgnoreCase("update")) {
|
||||
commands.put(commandConfig.getName(), new UpdateCommandImpl(commandConfig));
|
||||
} else if (kind.equalsIgnoreCase("insert")) {
|
||||
commands.put(commandConfig.getName(), new InsertCommandImpl(commandConfig, new String[0]));
|
||||
} else if (kind.equalsIgnoreCase("delete")) {
|
||||
commands.put(commandConfig.getName(), new DeleteCommandImpl(commandConfig));
|
||||
} else if (kind.equalsIgnoreCase("procedure")) {
|
||||
commands.put(commandConfig.getName(), new SPCommandImpl(commandConfig.getSQL(), configWrapper, commandConfig.getParameter()));
|
||||
} else {
|
||||
throw new RuntimeException("Invalid kind of command: " + kind);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public DASImpl(Config inConfig, Connection inConnection) {
|
||||
this(inConfig);
|
||||
setConnection(inConnection);
|
||||
}
|
||||
|
||||
public DASImpl(InputStream configStream, Connection inConnection) {
|
||||
this(ConfigUtil.loadConfig(configStream), inConnection);
|
||||
}
|
||||
|
||||
public DASImpl(Connection inConnection) {
|
||||
this(ConfigFactory.INSTANCE.createConfig());
|
||||
setConnection(inConnection);
|
||||
}
|
||||
|
||||
/*
|
||||
* (non-Javadoc)
|
||||
*
|
||||
* @see org.apache.tuscany.das.rdb.CommandGroup#getApplyChangesCommand()
|
||||
*/
|
||||
public ApplyChangesCommandImpl getApplyChangesCommand() {
|
||||
ApplyChangesCommandImpl cmd = new ApplyChangesCommandImpl(configWrapper, getConnection());
|
||||
return cmd;
|
||||
}
|
||||
|
||||
/*
|
||||
* (non-Javadoc)
|
||||
*
|
||||
* @see org.apache.tuscany.das.rdb.CommandGroup#getCommand(java.lang.String)
|
||||
*/
|
||||
public Command getCommand(String name) {
|
||||
if (!commands.containsKey(name)) {
|
||||
throw new RuntimeException("CommandGroup has no command named: " + name);
|
||||
}
|
||||
CommandImpl cmd = (CommandImpl) commands.get(name);
|
||||
cmd.setConnection(getConnection(), configWrapper.getConfig());
|
||||
return cmd;
|
||||
}
|
||||
|
||||
public void setConnection(Connection connection) {
|
||||
this.connection = connection;
|
||||
}
|
||||
|
||||
public Connection getConnection() {
|
||||
if (connection == null) {
|
||||
initializeConnection();
|
||||
}
|
||||
return connection;
|
||||
}
|
||||
|
||||
private void initializeConnection() {
|
||||
Config config = configWrapper.getConfig();
|
||||
if (config == null || config.getConnectionInfo() == null ||
|
||||
(config.getConnectionInfo().getDataSource() == null && config.getConnectionInfo().getConnectionProperties() == null)) {
|
||||
throw new RuntimeException("No connection has been provided and no data source has been specified");
|
||||
}
|
||||
|
||||
if(config.getConnectionInfo().getDataSource() != null && config.getConnectionInfo().getConnectionProperties() != null){
|
||||
throw new RuntimeException("Use either dataSource or ConnectionProperties. Can't use both !");
|
||||
}
|
||||
|
||||
ConnectionInfo connectionInfo = configWrapper.getConfig().getConnectionInfo();
|
||||
if(config.getConnectionInfo().getConnectionProperties() != null){
|
||||
initializeDriverManagerConnection(connectionInfo);
|
||||
}else{
|
||||
initializeDatasourceConnection(connectionInfo);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Initializes a DB connection on a managed environmet (e.g inside Tomcat)
|
||||
*/
|
||||
private void initializeDatasourceConnection(ConnectionInfo connectionInfo){
|
||||
Connection connection = null;
|
||||
|
||||
InitialContext ctx;
|
||||
try {
|
||||
ctx = new InitialContext();
|
||||
} catch (NamingException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
try {
|
||||
DataSource ds = (DataSource) ctx.lookup(connectionInfo.getDataSource());
|
||||
try {
|
||||
connection = ds.getConnection();
|
||||
if (connection == null) {
|
||||
throw new RuntimeException("Could not obtain a Connection from DataSource");
|
||||
}
|
||||
connection.setAutoCommit(false);
|
||||
setConnection(connection);
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
} catch (NamingException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Initialize a DB connection on a J2SE environment
|
||||
* For more info, see http://java.sun.com/j2se/1.3/docs/guide/jdbc/getstart/drivermanager.html
|
||||
*/
|
||||
private void initializeDriverManagerConnection(ConnectionInfo connectionInfo) {
|
||||
|
||||
Connection connection = null;
|
||||
|
||||
if (connectionInfo.getConnectionProperties() == null) {
|
||||
throw new DataSourceInitializationException("No existing context and no connection properties");
|
||||
}
|
||||
|
||||
if (connectionInfo.getConnectionProperties().getDriverClass() == null) {
|
||||
throw new DataSourceInitializationException("No jdbc driver class specified!");
|
||||
}
|
||||
|
||||
try {
|
||||
//initialize driver and register it with DriverManager
|
||||
Class.forName(connectionInfo.getConnectionProperties().getDriverClass());
|
||||
|
||||
//prepare to initialize connection
|
||||
String databaseUrl = connectionInfo.getConnectionProperties().getDatabaseURL();
|
||||
String userName = connectionInfo.getConnectionProperties().getUserName();
|
||||
String userPassword = connectionInfo.getConnectionProperties().getPassword();
|
||||
int loginTimeout = connectionInfo.getConnectionProperties().getLoginTimeout();
|
||||
|
||||
DriverManager.setLoginTimeout(loginTimeout);
|
||||
if( (userName == null || userName.length() ==0) && (userPassword == null || userPassword.length()==0) ){
|
||||
//no username or password suplied
|
||||
connection = DriverManager.getConnection(databaseUrl);
|
||||
}else{
|
||||
connection = DriverManager.getConnection(databaseUrl, userName, userPassword);
|
||||
}
|
||||
|
||||
if(connection == null){
|
||||
throw new DataSourceInitializationException("Error initializing connection : null");
|
||||
}
|
||||
|
||||
connection.setAutoCommit(false);
|
||||
setConnection(connection);
|
||||
|
||||
|
||||
}catch(ClassNotFoundException cnf){
|
||||
throw new DataSourceInitializationException("JDBC Driver '" + connectionInfo.getConnectionProperties().getDriverClass() + "' not found", cnf);
|
||||
}catch(SQLException sqle){
|
||||
throw new DataSourceInitializationException(sqle.getMessage(), sqle);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public void releaseResources() {
|
||||
|
||||
if (managingConnections()) {
|
||||
closeConnection();
|
||||
}
|
||||
}
|
||||
|
||||
private void closeConnection() {
|
||||
if (connection != null) {
|
||||
try {
|
||||
connection.close();
|
||||
connection = null;
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* If the config has connection properties then we are "managing" the connection via DataSource
|
||||
*/
|
||||
private boolean managingConnections() {
|
||||
|
||||
if (configWrapper.getConfig().getConnectionInfo().getDataSource() == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
|
||||
}
|
||||
|
||||
public Command createCommand(String sql) {
|
||||
return baseCreateCommand(sql, this.configWrapper);
|
||||
}
|
||||
|
||||
public Command createCommand(String sql, Config config) {
|
||||
return baseCreateCommand(sql, new MappingWrapper(config));
|
||||
}
|
||||
|
||||
private Command baseCreateCommand(String inSql, MappingWrapper config) {
|
||||
CommandImpl returnCmd = null;
|
||||
String sql = inSql.trim(); // Remove leading white space
|
||||
char firstChar = Character.toUpperCase(sql.charAt(0));
|
||||
switch (firstChar) {
|
||||
case 'S':
|
||||
returnCmd = new ReadCommandImpl(sql, config, null);
|
||||
break;
|
||||
case 'I':
|
||||
returnCmd = new InsertCommandImpl(sql, new String[0]);
|
||||
break;
|
||||
case 'U':
|
||||
returnCmd = new UpdateCommandImpl(sql);
|
||||
break;
|
||||
case 'D':
|
||||
returnCmd = new DeleteCommandImpl(sql);
|
||||
break;
|
||||
case '{':
|
||||
returnCmd = new SPCommandImpl(sql, config, Collections.EMPTY_LIST);
|
||||
break;
|
||||
default:
|
||||
throw new RuntimeException("SQL => " + sql + " is not valid");
|
||||
}
|
||||
|
||||
returnCmd.setConnection(getConnection(), config.getConfig());
|
||||
return returnCmd;
|
||||
}
|
||||
|
||||
public void applyChanges(DataObject root) {
|
||||
getApplyChangesCommand().execute(root);
|
||||
}
|
||||
|
||||
}
|
|
@ -1,202 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.Column;
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.KeyPair;
|
||||
import org.apache.tuscany.das.rdb.config.Relationship;
|
||||
import org.apache.tuscany.das.rdb.config.Table;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.TableWrapper;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.Property;
|
||||
|
||||
/**
|
||||
* DatabaseObject wraps DataObject. If a field is an FK field, it will return the value from the parent.
|
||||
*
|
||||
*
|
||||
*/
|
||||
public class DatabaseObject {
|
||||
|
||||
private final Logger logger = Logger.getLogger(DatabaseObject.class);
|
||||
|
||||
private final MappingWrapper mappingWrapper;
|
||||
|
||||
private final DataObject dataObject;
|
||||
|
||||
private Property parentReference;
|
||||
|
||||
private Map keyMappings = new HashMap();
|
||||
|
||||
public DatabaseObject(Config model, DataObject changedObject) {
|
||||
this.mappingWrapper = new MappingWrapper(model);
|
||||
this.dataObject = changedObject;
|
||||
initialize();
|
||||
}
|
||||
|
||||
// Initialize Key Mappings
|
||||
private void initialize() {
|
||||
if (mappingWrapper.getConfig() != null) {
|
||||
List relationships = mappingWrapper.getConfig().getRelationship();
|
||||
Iterator i = relationships.iterator();
|
||||
while (i.hasNext()) {
|
||||
Relationship r = (Relationship) i.next();
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Initializing relationship: " + r.getName());
|
||||
this.logger.debug("r.getForeignKeyTable():"+r.getForeignKeyTable());
|
||||
this.logger.debug("getTypeName():"+getTypeName());
|
||||
}
|
||||
|
||||
if (r.getForeignKeyTable().equals(getTypeName())) {
|
||||
List pairs = r.getKeyPair();
|
||||
Iterator iter = pairs.iterator();
|
||||
while (iter.hasNext()) {
|
||||
KeyPair pair = (KeyPair) iter.next();
|
||||
keyMappings.put(pair.getForeignKeyColumn(), r);
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Putting key pair: " + pair.getPrimaryKeyColumn()+","+pair.getForeignKeyColumn());
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public Object get(String parameter) {
|
||||
if (isPartOfPrimaryKey(parameter)) {
|
||||
return dataObject.get(parameter);
|
||||
}
|
||||
|
||||
Relationship r = (Relationship) keyMappings.get(parameter);
|
||||
if (r == null) {
|
||||
return dataObject.get(parameter);
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
Table tbl = this.mappingWrapper.getTable(r.getPrimaryKeyTable());
|
||||
Property parentRef = null;
|
||||
if(tbl == null){
|
||||
//this is case when config file is not present and
|
||||
//ConfigHelper helper = new ConfigHelper(); is used
|
||||
parentRef = getParentReference(r.getPrimaryKeyTable());
|
||||
}
|
||||
else{
|
||||
//other cases, its better to use typeName as r.getPrimaryKeyTable()
|
||||
//gives tableName and tableName and typeName can be different
|
||||
//and SDO looks for typeName and not tableName.
|
||||
parentRef = getParentReference((new TableWrapper(tbl)).getTypeName());
|
||||
}
|
||||
|
||||
DataObject parent = dataObject.getDataObject(parentRef);
|
||||
|
||||
if (parent == null) {
|
||||
return null;
|
||||
}
|
||||
String parentKey = getParentKey(r, parameter);
|
||||
return parent.get(parentKey);
|
||||
|
||||
}
|
||||
|
||||
private String getParentKey(Relationship r, String parameter) {
|
||||
List keyPairs = r.getKeyPair();
|
||||
Iterator i = keyPairs.iterator();
|
||||
while (i.hasNext()) {
|
||||
KeyPair pair = (KeyPair) i.next();
|
||||
if (pair.getForeignKeyColumn().equals(parameter)) {
|
||||
return pair.getPrimaryKeyColumn();
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public Property getParentReference(String parentName) {
|
||||
if (this.parentReference == null) {
|
||||
Iterator i = dataObject.getType().getProperties().iterator();
|
||||
while (i.hasNext()) {
|
||||
Property ref = (Property) i.next();
|
||||
if ((!ref.getType().isDataType()) && (ref.getType().getName().equals(parentName))) {
|
||||
this.parentReference = ref;
|
||||
}
|
||||
}
|
||||
}
|
||||
return this.parentReference;
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
public String getTableName() {
|
||||
if (mappingWrapper.getConfig() != null) {
|
||||
|
||||
if(mappingWrapper.getConfig().isDatabaseSchemaNameSupported()){
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("DatabaseObject.getTableName:(schemaName.tableName) " +
|
||||
mappingWrapper.getTableByTypeName(getTypeName()).getSchemaName()+"."+
|
||||
mappingWrapper.getTableByTypeName(getTypeName()).getTableName());
|
||||
}
|
||||
|
||||
return (mappingWrapper.getTableByTypeName(getTypeName()).getSchemaName()+"."+
|
||||
mappingWrapper.getTableByTypeName(getTypeName()).getTableName());
|
||||
}
|
||||
else{
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("DatabaseObject.getTableName: " + mappingWrapper.getTableByTypeName(getTypeName()).getTableName());
|
||||
}
|
||||
|
||||
return mappingWrapper.getTableByTypeName(getTypeName()).getTableName();
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public String getTypeName() {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("DatabaseObject.getTypeName: " + dataObject.getType().getName());
|
||||
}
|
||||
return dataObject.getType().getName();
|
||||
}
|
||||
|
||||
public void setPropagatedID(String propagatedID, int id) {
|
||||
dataObject.setInt(propagatedID, id);
|
||||
}
|
||||
|
||||
private boolean isPartOfPrimaryKey(String parameter) {
|
||||
if (mappingWrapper.getConfig() == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
Table t = mappingWrapper.getTable(getTableName());
|
||||
if (t == null) {
|
||||
return false;
|
||||
}
|
||||
Column c = mappingWrapper.getColumnByPropertyName(t, parameter);
|
||||
if (c == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return c.isPrimaryKey();
|
||||
}
|
||||
|
||||
}
|
|
@ -1,37 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Delete;
|
||||
|
||||
public class DeleteCommandImpl extends WriteCommandImpl {
|
||||
public DeleteCommandImpl(org.apache.tuscany.das.rdb.config.Command command) {
|
||||
super(command);
|
||||
}
|
||||
|
||||
public DeleteCommandImpl(String sqlString) {
|
||||
super(sqlString);
|
||||
}
|
||||
|
||||
public DeleteCommandImpl(Delete delete) {
|
||||
super(delete.getSql());
|
||||
this.addParameters(delete.getParameters());
|
||||
}
|
||||
|
||||
}
|
|
@ -1,77 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* DeleteList will sort delete operations so that child objects are deleted before their parents
|
||||
*
|
||||
*
|
||||
*/
|
||||
public class DeleteList {
|
||||
|
||||
private Map opsByTableName = new HashMap();
|
||||
|
||||
private List order;
|
||||
|
||||
private List deleteOperations = new ArrayList();
|
||||
|
||||
public DeleteList() {
|
||||
super();
|
||||
}
|
||||
|
||||
public void add(ChangeOperation op) {
|
||||
if ((order.size() == 0) || (op.getTableName() == null)) {
|
||||
deleteOperations.add(op);
|
||||
} else {
|
||||
String name = op.getTableName();
|
||||
List ops = (List) opsByTableName.get(name);
|
||||
if (ops == null) {
|
||||
ops = new ArrayList();
|
||||
}
|
||||
ops.add(op);
|
||||
opsByTableName.put(name, ops);
|
||||
}
|
||||
}
|
||||
|
||||
public Collection getSortedList() {
|
||||
if ((order.size() > 0) && (opsByTableName.keySet().size() > 0)) {
|
||||
Iterator i = this.order.iterator();
|
||||
while (i.hasNext()) {
|
||||
String name = (String) i.next();
|
||||
if (opsByTableName.get(name) != null) {
|
||||
deleteOperations.addAll((Collection) opsByTableName.get(name));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return deleteOperations;
|
||||
}
|
||||
|
||||
public void setOrder(List deleteOrder) {
|
||||
this.order = deleteOrder;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,38 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import org.apache.tuscany.das.rdb.util.DataObjectUtil;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class DeleteOperation extends ChangeOperation {
|
||||
|
||||
/**
|
||||
* @param command
|
||||
* @param changedObject
|
||||
* Objects deleted from the graph have lost their "settings" and must be restored
|
||||
*/
|
||||
public DeleteOperation(DeleteCommandImpl command, DataObject changedObject) {
|
||||
super(command);
|
||||
this.dObject = new DatabaseObject(command.getMappingModel(), DataObjectUtil.getRestoredCopy(changedObject));
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -1,57 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
|
||||
import commonj.sdo.Type;
|
||||
|
||||
public class FactoryRegistry {
|
||||
|
||||
private final Logger logger = Logger.getLogger(FactoryRegistry.class);
|
||||
|
||||
private Map registry = new HashMap();
|
||||
|
||||
private final MappingWrapper mapping;
|
||||
|
||||
private final ConnectionImpl connection;
|
||||
|
||||
public FactoryRegistry(MappingWrapper mapping, ConnectionImpl connection) {
|
||||
this.mapping = mapping;
|
||||
this.connection = connection;
|
||||
}
|
||||
|
||||
public ChangeFactory getFactory(Type type) {
|
||||
ChangeFactory factory = (ChangeFactory) registry.get(type);
|
||||
if (factory == null) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Creating new ChangeFactory for type " + type.getName());
|
||||
}
|
||||
|
||||
factory = new ChangeFactory(mapping, connection);
|
||||
registry.put(type, factory);
|
||||
}
|
||||
return factory;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,75 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.sql.SQLException;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Create;
|
||||
|
||||
public class InsertCommandImpl extends WriteCommandImpl {
|
||||
|
||||
private String[] keys;
|
||||
|
||||
public InsertCommandImpl(org.apache.tuscany.das.rdb.config.Command command, String[] generatedKeys) {
|
||||
super(command);
|
||||
keys = generatedKeys;
|
||||
}
|
||||
|
||||
public InsertCommandImpl(String sqlString, String[] generatedKeys) {
|
||||
super(sqlString);
|
||||
keys = generatedKeys;
|
||||
}
|
||||
|
||||
public InsertCommandImpl(Create create) {
|
||||
super(create.getSql());
|
||||
this.addParameters(create.getParameters());
|
||||
this.keys = new String[0];
|
||||
}
|
||||
|
||||
public void execute() {
|
||||
|
||||
boolean success = false;
|
||||
try {
|
||||
statement.executeUpdate(parameters, keys);
|
||||
success = true;
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
} finally {
|
||||
if (success) {
|
||||
statement.getConnection().cleanUp();
|
||||
} else {
|
||||
statement.getConnection().errorCleanUp();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public int getGeneratedKey() {
|
||||
try {
|
||||
Integer key = statement.getGeneratedKey();
|
||||
if(key != null)
|
||||
return key.intValue();
|
||||
else
|
||||
throw new RuntimeException("Could not obtain generated key!");
|
||||
} catch (SQLException ex) {
|
||||
throw new RuntimeException(ex);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -1,95 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
/**
|
||||
* InsertList will sort ChangeOperation objects so that parents are inserted before children
|
||||
*
|
||||
*
|
||||
*/
|
||||
public class InsertList {
|
||||
private final Logger logger = Logger.getLogger(InsertList.class);
|
||||
|
||||
private Map opsByTableName = new HashMap();
|
||||
|
||||
private List insertOperations = new ArrayList();
|
||||
|
||||
private List order;
|
||||
|
||||
public void add(ChangeOperation op) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Adding insert operation ");
|
||||
}
|
||||
|
||||
// If nothing has been added yet, or this is no ordering, simply
|
||||
// add the operation to the list
|
||||
if ((order.size() == 0) || (op.getTableName() == null)) {
|
||||
insertOperations.add(op);
|
||||
} else {
|
||||
String name = op.getTableName();
|
||||
List ops = (List) opsByTableName.get(name);
|
||||
if (ops == null) {
|
||||
ops = new ArrayList();
|
||||
}
|
||||
|
||||
ops.add(op);
|
||||
opsByTableName.put(name, ops);
|
||||
}
|
||||
}
|
||||
|
||||
public Collection getSortedList() {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Getting sorted insert list");
|
||||
}
|
||||
|
||||
if ((order.size() > 0) && opsByTableName.keySet().size() > 0) {
|
||||
Iterator i = this.order.iterator();
|
||||
while (i.hasNext()) {
|
||||
String name = (String) i.next();
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Adding operations for table " + name);
|
||||
}
|
||||
|
||||
// A null here means a table is in the config but hasn't been changed here
|
||||
if (opsByTableName.get(name) != null) {
|
||||
insertOperations.addAll((Collection) opsByTableName.get(name));
|
||||
}
|
||||
}
|
||||
}
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Returning " + insertOperations.size() + " insert operations");
|
||||
}
|
||||
|
||||
return insertOperations;
|
||||
}
|
||||
|
||||
public void setOrder(List insertOrder) {
|
||||
this.order = insertOrder;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,39 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
public class ManagedParameterImpl extends ParameterExtendedImpl {
|
||||
|
||||
public void setValue(Object oldValue) {
|
||||
this.value = updateValue(oldValue);
|
||||
}
|
||||
|
||||
private Object updateValue(Object oldValue) {
|
||||
if (oldValue instanceof Integer) {
|
||||
return new Integer(((Integer) oldValue).intValue() + 1);
|
||||
} else if (oldValue instanceof BigDecimal) {
|
||||
return ((BigDecimal) oldValue).add(new BigDecimal(1));
|
||||
} else {
|
||||
throw new RuntimeException("Unsupported type for managed column: " + oldValue.getClass().getName());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -1,48 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.sql.SQLException;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Update;
|
||||
import org.apache.tuscany.das.rdb.exception.OptimisticConcurrencyException;
|
||||
|
||||
public class OptimisticWriteCommandImpl extends UpdateCommandImpl {
|
||||
|
||||
public OptimisticWriteCommandImpl(String sqlString) {
|
||||
super(sqlString);
|
||||
}
|
||||
|
||||
public OptimisticWriteCommandImpl(Update update) {
|
||||
super(update);
|
||||
addParameters(update.getParameters());
|
||||
}
|
||||
|
||||
public void basicExecute() {
|
||||
try {
|
||||
int rowsAffected = statement.executeUpdate(parameters);
|
||||
if (rowsAffected == 0) {
|
||||
throw new OptimisticConcurrencyException("An update collision occurred");
|
||||
}
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -1,69 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.Pager;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class PagerImpl implements Pager {
|
||||
|
||||
private final ReadCommandImpl command;
|
||||
|
||||
private final int size;
|
||||
|
||||
private int idx = 1;
|
||||
|
||||
public PagerImpl(Command command, int size) {
|
||||
this.command = (ReadCommandImpl) command;
|
||||
this.command.enablePaging();
|
||||
this.size = size;
|
||||
}
|
||||
|
||||
public DataObject next() {
|
||||
int start = idx;
|
||||
int end = idx + size;
|
||||
idx += size;
|
||||
command.setStartRow(start);
|
||||
command.setEndRow(end);
|
||||
return command.executeQuery();
|
||||
}
|
||||
|
||||
public DataObject getPage(int page) {
|
||||
int end = (page * size) + 1;
|
||||
int start = end - size;
|
||||
idx = end;
|
||||
command.setStartRow(start);
|
||||
command.setEndRow(end);
|
||||
return command.executeQuery();
|
||||
}
|
||||
|
||||
public DataObject previous() {
|
||||
int start = idx - (2 * size);
|
||||
if (start < 1) {
|
||||
start = 1;
|
||||
}
|
||||
int end = start + size;
|
||||
idx = end;
|
||||
command.setStartRow(start);
|
||||
command.setEndRow(end);
|
||||
return command.executeQuery();
|
||||
}
|
||||
}
|
|
@ -1,98 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Converter;
|
||||
import org.apache.tuscany.das.rdb.config.impl.ParameterImpl;
|
||||
import commonj.sdo.Type;
|
||||
|
||||
public class ParameterExtendedImpl extends ParameterImpl{
|
||||
/**
|
||||
* Value for "Direction" that indicates that a parameter is soley for input.
|
||||
*/
|
||||
static final String IN = "IN";
|
||||
|
||||
/**
|
||||
* Value for "Direction" that indicates that a parameter is soley for output.
|
||||
* Out parameters only apply to Stored Procedures
|
||||
*/
|
||||
static final String OUT = "OUT";
|
||||
|
||||
/**
|
||||
* Value for "Direction" that indicates that a parameter is for both input and output.
|
||||
* In-out parameters only apply to stored procedures
|
||||
*/
|
||||
static final String IN_OUT = "IN_OUT";
|
||||
|
||||
private Type type;
|
||||
|
||||
protected Object value;
|
||||
|
||||
private Converter converter;
|
||||
|
||||
public ParameterExtendedImpl() {
|
||||
super();
|
||||
this.direction = IN;
|
||||
}
|
||||
|
||||
public ParameterExtendedImpl(org.apache.tuscany.das.rdb.config.impl.ParameterImpl parameterImpl) {
|
||||
this.columnType = parameterImpl.getColumnType();
|
||||
this.direction = parameterImpl.getDirection();
|
||||
this.index = parameterImpl.getIndex();
|
||||
this.name = parameterImpl.getName();
|
||||
}
|
||||
|
||||
public void setType(Type type) {
|
||||
this.type = type;
|
||||
}
|
||||
|
||||
public Type getType() {
|
||||
return this.type;
|
||||
}
|
||||
|
||||
public void setColumnType(String newColumnType) {
|
||||
super.setColumnType(newColumnType);
|
||||
if(newColumnType != null){
|
||||
String arg0 = newColumnType.substring(0, newColumnType.lastIndexOf("."));
|
||||
String arg1 = newColumnType.substring(newColumnType.lastIndexOf(".")+1);
|
||||
this.type = SDODataTypes.TYPE_HELPER.getType(arg0, arg1);
|
||||
}
|
||||
}
|
||||
|
||||
public void setValue(Object value) {
|
||||
this.value = value;
|
||||
}
|
||||
|
||||
public Object getValue() {
|
||||
if (getConverter() != null) {
|
||||
return getConverter().getColumnValue(this.value);
|
||||
}
|
||||
|
||||
return this.value;
|
||||
}
|
||||
|
||||
public void setConverter(Converter converter) {
|
||||
this.converter = converter;
|
||||
}
|
||||
|
||||
public Converter getConverter() {
|
||||
return this.converter;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,120 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Converter;
|
||||
|
||||
import commonj.sdo.Type;
|
||||
|
||||
public class ParameterImpl {
|
||||
|
||||
/**
|
||||
* Value for "Direction" that indicates that a parameter is soley for input.
|
||||
*/
|
||||
static final int IN = 1;
|
||||
|
||||
/**
|
||||
* Value for "Direction" that indicates that a parameter is soley for output.
|
||||
* Out parameters only apply to Stored Procedures
|
||||
*/
|
||||
static final int OUT = 2;
|
||||
|
||||
/**
|
||||
* Value for "Direction" that indicates that a parameter is for both input and output.
|
||||
* In-out parameters only apply to stored procedures
|
||||
*/
|
||||
static final int IN_OUT = 3;
|
||||
|
||||
protected Object value;
|
||||
|
||||
private int index;
|
||||
|
||||
private Type type;
|
||||
|
||||
private String name;
|
||||
|
||||
private int direction = IN;
|
||||
|
||||
private Converter converter;
|
||||
|
||||
|
||||
public ParameterImpl() {
|
||||
super();
|
||||
}
|
||||
|
||||
public ParameterImpl(int index) {
|
||||
this.index = index;
|
||||
}
|
||||
|
||||
public void setType(Type type) {
|
||||
this.type = type;
|
||||
}
|
||||
|
||||
public void setIndex(int index) {
|
||||
if (index == 0) {
|
||||
throw new RuntimeException("Index of zero not allowed");
|
||||
}
|
||||
this.index = index;
|
||||
}
|
||||
|
||||
public void setName(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public void setValue(Object value) {
|
||||
this.value = value;
|
||||
}
|
||||
|
||||
public void setDirection(int direction) {
|
||||
this.direction = direction;
|
||||
}
|
||||
|
||||
public Type getType() {
|
||||
return this.type;
|
||||
}
|
||||
|
||||
public int getIndex() {
|
||||
return this.index;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return this.name;
|
||||
}
|
||||
|
||||
public Object getValue() {
|
||||
if (getConverter() != null) {
|
||||
return getConverter().getColumnValue(this.value);
|
||||
}
|
||||
|
||||
return this.value;
|
||||
}
|
||||
|
||||
public int getDirection() {
|
||||
return this.direction;
|
||||
}
|
||||
|
||||
public void setConverter(Converter converter) {
|
||||
this.converter = converter;
|
||||
}
|
||||
|
||||
public Converter getConverter() {
|
||||
return this.converter;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,113 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
import commonj.sdo.Type;
|
||||
|
||||
public class Parameters {
|
||||
private final Logger logger = Logger.getLogger(Parameters.class);
|
||||
|
||||
private List parameters = new ArrayList();
|
||||
|
||||
private List inParams = new ArrayList();
|
||||
|
||||
private List outParams = new ArrayList();
|
||||
|
||||
public Parameters() {
|
||||
super();
|
||||
}
|
||||
|
||||
public ParameterImpl get(int index) {
|
||||
return (ParameterImpl) parameters.get(index);
|
||||
}
|
||||
|
||||
public List outParams() {
|
||||
return outParams;
|
||||
}
|
||||
|
||||
public List inParams() {
|
||||
return inParams;
|
||||
}
|
||||
|
||||
private void addParameter(ParameterImpl param) {
|
||||
if (param.getDirection() == ParameterImpl.IN) {
|
||||
inParams.add(param);
|
||||
} else if ((param.getDirection() == ParameterImpl.OUT) || (param.getDirection() == ParameterImpl.IN_OUT)) {
|
||||
outParams.add(param);
|
||||
}
|
||||
|
||||
this.parameters.add(param);
|
||||
}
|
||||
|
||||
public void add(ParameterImpl param) {
|
||||
addParameter(param);
|
||||
}
|
||||
|
||||
public ParameterImpl findOrCreateParameterWithIndex(int index, int direction, Type sdoType) {
|
||||
Iterator i = parameters.iterator();
|
||||
while (i.hasNext()) {
|
||||
ParameterImpl param = (ParameterImpl) i.next();
|
||||
|
||||
if (param.getIndex() == index) {
|
||||
return param;
|
||||
}
|
||||
}
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Creating new parameter with index " + index);
|
||||
}
|
||||
|
||||
ParameterImpl newParam = new ParameterImpl(index);
|
||||
newParam.setDirection(direction);
|
||||
newParam.setType(sdoType);
|
||||
addParameter(newParam);
|
||||
return newParam;
|
||||
}
|
||||
|
||||
public List parameterList() {
|
||||
return parameters;
|
||||
}
|
||||
|
||||
public ParameterImpl findOrCreateParameterWithIndex(int index) {
|
||||
return findOrCreateParameterWithIndex(index, ParameterImpl.IN, null);
|
||||
}
|
||||
|
||||
public void setParameter(int index, Object value) {
|
||||
ParameterImpl param = findOrCreateParameterWithIndex(index);
|
||||
param.setValue(value);
|
||||
}
|
||||
|
||||
public ParameterImpl parameterWithIndex(int index) {
|
||||
Iterator i = parameters.iterator();
|
||||
while (i.hasNext()) {
|
||||
ParameterImpl param = (ParameterImpl) i.next();
|
||||
|
||||
if (param.getIndex() == index) {
|
||||
return param;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,189 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.StringTokenizer;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.Parameters;
|
||||
import org.apache.tuscany.das.rdb.config.impl.ParameterImpl;
|
||||
import org.apache.tuscany.das.rdb.config.impl.ParametersImpl;
|
||||
|
||||
import commonj.sdo.Type;
|
||||
|
||||
public class ParametersExtendedImpl extends ParametersImpl{
|
||||
private final Logger logger = Logger.getLogger(ParametersExtendedImpl.class);
|
||||
private List inParams = new ArrayList();
|
||||
|
||||
private List outParams = new ArrayList();
|
||||
|
||||
public ParametersExtendedImpl(){
|
||||
|
||||
}
|
||||
|
||||
public ParametersExtendedImpl(List paramsList) {
|
||||
if(this.parameter == null){
|
||||
this.parameter = new ArrayList();
|
||||
}
|
||||
if(paramsList != null){
|
||||
for(int i=0; i<paramsList.size(); i++){
|
||||
ParameterImpl paramImpl = (ParameterImpl)paramsList.get(i);
|
||||
ParameterExtendedImpl paramExtImpl = new ParameterExtendedImpl();
|
||||
paramExtImpl.setColumnType(paramImpl.getColumnType());
|
||||
paramExtImpl.setIndex(paramImpl.getIndex());
|
||||
paramExtImpl.setName(paramImpl.getName());
|
||||
paramExtImpl.setDirection(paramImpl.getDirection());
|
||||
this.parameter.add(paramExtImpl);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public ParametersExtendedImpl(Parameters params) {
|
||||
this(params.getParameter());
|
||||
}
|
||||
|
||||
public List getOutParameters() {
|
||||
return outParams;
|
||||
}
|
||||
|
||||
public List getInParameters() {
|
||||
return inParams;
|
||||
}
|
||||
|
||||
public ParameterExtendedImpl getParameter(int index) {
|
||||
if(this.getParameter() == null || this.getParameter().isEmpty())
|
||||
return null;
|
||||
|
||||
Iterator itr = this.getParameter().iterator();
|
||||
while(itr.hasNext()){
|
||||
ParameterExtendedImpl curParam = (ParameterExtendedImpl)itr.next();
|
||||
if(curParam.getIndex() == index){
|
||||
return curParam;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public ParameterExtendedImpl getParameter(int index, String direction) {
|
||||
if(direction.equals(ParameterExtendedImpl.IN)) {
|
||||
Iterator itr = this.inParams.iterator();
|
||||
while(itr.hasNext()){
|
||||
ParameterExtendedImpl curParam = (ParameterExtendedImpl)itr.next();
|
||||
if(curParam.getIndex() == index){
|
||||
return curParam;
|
||||
}
|
||||
}
|
||||
}
|
||||
else {
|
||||
Iterator itr = this.outParams.iterator();
|
||||
while(itr.hasNext()){
|
||||
ParameterExtendedImpl curParam = (ParameterExtendedImpl)itr.next();
|
||||
if(curParam.getIndex() == index){
|
||||
return curParam;
|
||||
}
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
private ParameterExtendedImpl getNamedParameter(List params, String name){
|
||||
if(params == null)
|
||||
return null;
|
||||
for(int i=0; i<params.size(); i++){
|
||||
if( ((ParameterExtendedImpl)params.get(i)).getName().equals(name)){
|
||||
return (ParameterExtendedImpl)params.get(i);
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public ParameterExtendedImpl getParameter(String name) {
|
||||
return getNamedParameter(this.getParameter(), name);
|
||||
}
|
||||
|
||||
public ParameterExtendedImpl getParameter(String name, String direction) {
|
||||
if(direction.equals(ParameterExtendedImpl.IN))
|
||||
return getNamedParameter(this.inParams, name);
|
||||
else
|
||||
return getNamedParameter(this.outParams, name);
|
||||
}
|
||||
|
||||
public ParameterExtendedImpl findOrCreateParameterWithIndex(int index, String direction, Type sdoType) {
|
||||
if(this.parameter == null){
|
||||
this.parameter = new ArrayList();
|
||||
}
|
||||
Iterator i = this.parameter.iterator();
|
||||
while (i.hasNext()) {
|
||||
ParameterExtendedImpl param = (ParameterExtendedImpl) i.next();
|
||||
|
||||
if (param.getIndex() == index) {
|
||||
return param;
|
||||
}
|
||||
}
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Creating new parameter with index " + index);
|
||||
}
|
||||
|
||||
ParameterExtendedImpl newParam = new ParameterExtendedImpl();
|
||||
newParam.setIndex(index);
|
||||
newParam.setDirection(direction);
|
||||
newParam.setType(sdoType);
|
||||
newParam.setColumnType(SDODataTypeHelper.columnTypeForSDOType(sdoType));
|
||||
this.getParameter().add(newParam);
|
||||
if(!direction.equals(ParameterExtendedImpl.IN)){
|
||||
this.getOutParameters().add(newParam);
|
||||
}
|
||||
else{
|
||||
this.getInParameters().add(newParam);
|
||||
}
|
||||
return newParam;
|
||||
}
|
||||
|
||||
/**maintain compatibility with parameters="name1 name2 " from config
|
||||
*
|
||||
* @param parameters
|
||||
*/
|
||||
public static ArrayList getParameters(String parameters) {
|
||||
StringTokenizer tokenizer = new StringTokenizer(parameters);
|
||||
ArrayList paramExtList = new ArrayList();
|
||||
for (int idx = 1; tokenizer.hasMoreTokens(); idx++) {
|
||||
ParameterExtendedImpl p = new ParameterExtendedImpl();
|
||||
p.setName(tokenizer.nextToken());
|
||||
p.setIndex(idx);
|
||||
p.setDirection(ParameterExtendedImpl.IN);
|
||||
paramExtList.add(p);
|
||||
}
|
||||
return paramExtList;
|
||||
}
|
||||
|
||||
public void addParameters(List paramExtList){
|
||||
for(int i=0; i<paramExtList.size(); i++){
|
||||
ParameterExtendedImpl curParam = (ParameterExtendedImpl)paramExtList.get(i);
|
||||
this.getParameter().add(curParam);
|
||||
if(curParam.getDirection().equals(ParameterExtendedImpl.IN))
|
||||
this.getInParameters().add(paramExtList.get(i));
|
||||
else
|
||||
this.getOutParameters().add(paramExtList.get(i));
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -1,338 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.io.OutputStream;
|
||||
import java.sql.SQLException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Iterator;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.ResultDescriptor;
|
||||
import org.apache.tuscany.das.rdb.config.impl.ResultDescriptorImpl;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
import org.apache.tuscany.das.rdb.graphbuilder.impl.GraphBuilderMetadata;
|
||||
import org.apache.tuscany.das.rdb.graphbuilder.impl.ResultSetProcessor;
|
||||
import org.apache.tuscany.sdo.api.SDOUtil;
|
||||
|
||||
import commonj.sdo.ChangeSummary;
|
||||
import commonj.sdo.DataGraph;
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class ReadCommandImpl extends CommandImpl {
|
||||
|
||||
private int startRow = 1;
|
||||
|
||||
private int endRow = Integer.MAX_VALUE;
|
||||
|
||||
private List resultDescriptors = null;
|
||||
|
||||
public ReadCommandImpl(org.apache.tuscany.das.rdb.config.Command command, MappingWrapper mapping, List resultDescriptor) {
|
||||
super(command);
|
||||
this.configWrapper = mapping;
|
||||
|
||||
if (resultDescriptor != null && !resultDescriptor.isEmpty()) {
|
||||
this.resultSetShape = new ResultSetShape(resultDescriptor, configWrapper.getConfig());//JIRA-952
|
||||
}
|
||||
}
|
||||
|
||||
public ReadCommandImpl(String sqlString, MappingWrapper mapping, List resultDescriptor) {
|
||||
super(sqlString);
|
||||
this.configWrapper = mapping;
|
||||
|
||||
if (resultDescriptor != null && !resultDescriptor.isEmpty()) {
|
||||
this.resultSetShape = new ResultSetShape(resultDescriptor, configWrapper.getConfig());//JIRA-952
|
||||
}
|
||||
}
|
||||
|
||||
private void refreshResultSetShape(){
|
||||
//sort descriptor and use in ResultSetShape
|
||||
sortResultDescriptors();
|
||||
this.resultSetShape = new ResultSetShape(this.resultDescriptors, configWrapper.getConfig());
|
||||
}
|
||||
|
||||
private void sortResultDescriptors(){
|
||||
if(this.resultDescriptors == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
if( this.resultDescriptors.size()==0) {
|
||||
return;
|
||||
}
|
||||
|
||||
//when any index is found not set, do not sort
|
||||
for(Iterator it = this.resultDescriptors.iterator() ; it.hasNext();){
|
||||
ResultDescriptor resultDescriptor = (ResultDescriptor) it.next();
|
||||
if(resultDescriptor.getColumnIndex() <= -1){
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
//now is time to sort
|
||||
Object[] resultDescAry = this.resultDescriptors.toArray();
|
||||
for(int i=0; i<resultDescAry.length; i++){
|
||||
for(int j=i+1; j<resultDescAry.length; j++){
|
||||
if( ((ResultDescriptor)resultDescAry[j]).getColumnIndex()
|
||||
< ((ResultDescriptor)resultDescAry[i]).getColumnIndex()){
|
||||
ResultDescriptor tmpResDesc = (ResultDescriptor)resultDescAry[i];
|
||||
resultDescAry[i] = resultDescAry[j];
|
||||
resultDescAry[j] = tmpResDesc;
|
||||
}
|
||||
|
||||
if( ((ResultDescriptor)resultDescAry[j]).getColumnIndex()
|
||||
== ((ResultDescriptor)resultDescAry[i]).getColumnIndex()){
|
||||
throw new RuntimeException("Two columns in Result Descriptor can not have same index");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
this.resultDescriptors.clear();
|
||||
for(int i=0; i<resultDescAry.length; i++){
|
||||
this.resultDescriptors.add(resultDescAry[i]);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
private ResultDescriptor deepCopyResultDescriptor(ResultDescriptor inObj){
|
||||
ResultDescriptorImpl outObj = new ResultDescriptorImpl();
|
||||
outObj.setColumnIndex(inObj.getColumnIndex());
|
||||
outObj.setColumnName(inObj.getColumnName());
|
||||
outObj.setColumnType(inObj.getColumnType());
|
||||
outObj.setTableName(inObj.getTableName());
|
||||
outObj.setSchemaName(inObj.getSchemaName());
|
||||
return outObj;
|
||||
}
|
||||
|
||||
private List deepCopyResultDescriptors(List resultDescriptors){
|
||||
if(resultDescriptors == null || resultDescriptors.size() == 0)
|
||||
return null;
|
||||
|
||||
ArrayList copyList = new ArrayList();
|
||||
|
||||
for(Iterator it = resultDescriptors.iterator() ; it.hasNext();){
|
||||
copyList.add( deepCopyResultDescriptor( (ResultDescriptorImpl) it.next()));
|
||||
}
|
||||
return copyList;
|
||||
}
|
||||
|
||||
/**
|
||||
* When any columnIndex == -ve, sorting will not happen in ResultShapeSorter (old way)
|
||||
* When null is passed, set this.resultSetShape to null, this will later trigger, dbms metadata
|
||||
* based shaping of result
|
||||
*/
|
||||
public void setResultDescriptors(List resultDescriptors){
|
||||
this.resultDescriptors = deepCopyResultDescriptors(resultDescriptors);
|
||||
if(this.resultDescriptors == null || this.resultDescriptors.size()==0){
|
||||
this.resultSetShape = null;
|
||||
}
|
||||
else{
|
||||
//below will go away with List<> JDK5
|
||||
for(Iterator it = this.resultDescriptors.iterator() ; it.hasNext();){
|
||||
|
||||
if(!(it.next() instanceof ResultDescriptor)){
|
||||
throw new RuntimeException("Elements in List not of type ResultDescriptor!");
|
||||
}
|
||||
|
||||
}
|
||||
refreshResultSetShape();
|
||||
}
|
||||
}
|
||||
|
||||
public List getResultDescriptors(){
|
||||
return this.resultDescriptors;
|
||||
}
|
||||
|
||||
public void addResultDescriptor(ResultDescriptor resultDescriptor){
|
||||
//if >= 0 columnIndex, add/replace for given index
|
||||
//if < 0 columnIndex, add at end of current list
|
||||
if(resultDescriptor == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
if(this.resultDescriptors == null){
|
||||
this.resultDescriptors = new ArrayList();
|
||||
}
|
||||
|
||||
if(resultDescriptor.getColumnIndex() <0){
|
||||
this.resultDescriptors.add(deepCopyResultDescriptor(resultDescriptor));//dont care about columnIndex,add at end, old way
|
||||
}
|
||||
else{
|
||||
ResultDescriptor existing = getResultDescriptor(resultDescriptor.getColumnIndex());
|
||||
if(existing != null){
|
||||
removeResultDescriptor(resultDescriptor.getColumnIndex());
|
||||
}
|
||||
this.resultDescriptors.add(deepCopyResultDescriptor(resultDescriptor));//add at end, sorting will happen below
|
||||
}
|
||||
|
||||
refreshResultSetShape();
|
||||
}
|
||||
|
||||
|
||||
public ResultDescriptor removeResultDescriptor(int columnIndex){
|
||||
//if < 0 index return null
|
||||
//if >=0 index and available at given index, remove and return same
|
||||
//if >=0 index and not available at given index, return null
|
||||
ResultDescriptor existing = null;
|
||||
if(columnIndex >=0 && ((existing = getResultDescriptor(columnIndex)) != null) ){
|
||||
this.resultDescriptors.remove(existing);
|
||||
refreshResultSetShape();
|
||||
return existing;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public ResultDescriptor removeResultDescriptor(ResultDescriptor resultDescriptor){
|
||||
//remove and return only if matched for index, name, type, table name, schema name
|
||||
//else return null
|
||||
if(resultDescriptor != null){
|
||||
ResultDescriptor existing = getResultDescriptor(resultDescriptor.getColumnIndex());
|
||||
if(existing != null &&
|
||||
existing.getColumnName().equals(resultDescriptor.getColumnName()) &&
|
||||
existing.getColumnType().equals(resultDescriptor.getColumnType()) &&
|
||||
existing.getTableName().equals(resultDescriptor.getTableName()) ) {
|
||||
if(this.configWrapper.getConfig().isDatabaseSchemaNameSupported()){//multi schema support
|
||||
if(resultDescriptor.getSchemaName() != null && existing.getSchemaName() != null
|
||||
&& resultDescriptor.getSchemaName().equals(existing.getSchemaName())){
|
||||
this.resultDescriptors.remove(existing);
|
||||
refreshResultSetShape();
|
||||
return existing;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
else{
|
||||
this.resultDescriptors.remove(existing);
|
||||
refreshResultSetShape();
|
||||
return existing;
|
||||
}
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public ResultDescriptor getResultDescriptor(int columnIndex){
|
||||
//if <0 index return null
|
||||
//if >=0 index and available at given index, return same
|
||||
//if >=0 index and not available at given index, return null
|
||||
if(columnIndex >=0 && this.resultDescriptors != null){
|
||||
|
||||
for(Iterator it = this.resultDescriptors.iterator() ; it.hasNext();){
|
||||
ResultDescriptor rs = (ResultDescriptor) it.next();
|
||||
|
||||
if( rs.getColumnIndex() == columnIndex){
|
||||
return rs;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
//Utility method
|
||||
public void printResultDescriptors(OutputStream ostrm) throws IOException{
|
||||
if(this.resultDescriptors != null && this.resultDescriptors.size() != 0){
|
||||
|
||||
for(Iterator it = this.resultDescriptors.iterator() ; it.hasNext();){
|
||||
ostrm.write( it.next().toString().getBytes() );
|
||||
ostrm.write('\n');
|
||||
|
||||
}
|
||||
ostrm.flush();
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
public void execute() {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
public DataObject executeQuery() {
|
||||
|
||||
if (statement.getConnection() == null) {
|
||||
throw new RuntimeException("A DASConnection object must be specified before executing the query.");
|
||||
}
|
||||
|
||||
boolean success = false;
|
||||
try {
|
||||
List results = statement.executeQuery(parameters);
|
||||
success = true;
|
||||
return buildGraph(results);
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
} finally {
|
||||
if (success) {
|
||||
statement.getConnection().cleanUp();
|
||||
} else {
|
||||
statement.getConnection().errorCleanUp();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
protected DataObject buildGraph(List results) throws SQLException {
|
||||
|
||||
// Before we use the mappingModel, do some checking/updating. If
|
||||
// inferrable information
|
||||
// isn't specified, add it in.
|
||||
|
||||
GraphBuilderMetadata gbmd = new GraphBuilderMetadata(results, configWrapper.getConfig(),
|
||||
resultSetShape);
|
||||
|
||||
// Create the DataGraph
|
||||
DataGraph g = SDOUtil.createDataGraph();
|
||||
|
||||
// Create the root object
|
||||
g.createRootObject(gbmd.getRootType());
|
||||
|
||||
SDOUtil.registerDataGraphTypes(g, gbmd.getDefinedTypes());
|
||||
|
||||
ChangeSummary summary = g.getChangeSummary();
|
||||
|
||||
ResultSetProcessor rsp = new ResultSetProcessor(g.getRootObject(), gbmd);
|
||||
rsp.processResults(getStartRow(), getEndRow());
|
||||
|
||||
summary.beginLogging();
|
||||
|
||||
return g.getRootObject();
|
||||
}
|
||||
|
||||
|
||||
protected int getStartRow() {
|
||||
return startRow;
|
||||
}
|
||||
|
||||
protected int getEndRow() {
|
||||
return endRow;
|
||||
}
|
||||
|
||||
protected void setStartRow(int startRow) {
|
||||
this.startRow = startRow;
|
||||
}
|
||||
|
||||
protected void setEndRow(int endRow) {
|
||||
this.endRow = endRow;
|
||||
}
|
||||
|
||||
|
||||
protected void enablePaging() {
|
||||
statement.enablePaging();
|
||||
}
|
||||
|
||||
}
|
|
@ -1,161 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.sql.ResultSetMetaData;
|
||||
import java.sql.SQLException;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.ResultDescriptor;
|
||||
import org.apache.tuscany.das.rdb.graphbuilder.schema.ResultSetTypeMap;
|
||||
|
||||
import commonj.sdo.Type;
|
||||
import commonj.sdo.helper.TypeHelper;
|
||||
|
||||
/**
|
||||
* Describes the structure of the result set returned from
|
||||
* execution of a SELECT statement. This description is typcially
|
||||
* not required since the shape can be retreived from the JDBC
|
||||
* ResultSetMetadata. However, some platforms such as Oracle do not
|
||||
* support fully suport ResultSetMedata.
|
||||
* <p>
|
||||
* There may also be a performance boost when using this interface.
|
||||
*
|
||||
*
|
||||
*/
|
||||
public class ResultSetShape {
|
||||
|
||||
private final String[] columns;
|
||||
|
||||
private final String[] tables;
|
||||
|
||||
private final Type[] types;
|
||||
|
||||
private final String[] schema;//JIRA-952
|
||||
//JIRA-952
|
||||
public ResultSetShape(ResultSetMetaData metadata, Config model) throws SQLException {
|
||||
columns = new String[metadata.getColumnCount()];
|
||||
tables = new String[metadata.getColumnCount()];
|
||||
types = new Type[metadata.getColumnCount()];
|
||||
schema = new String[metadata.getColumnCount()];
|
||||
|
||||
ResultSetTypeMap typeMap = ResultSetTypeMap.INSTANCE;
|
||||
for (int i = 1; i <= metadata.getColumnCount(); i++) {
|
||||
if(model.isDatabaseSchemaNameSupported()){
|
||||
if(metadata.getSchemaName(i) != null && !metadata.getSchemaName(i).equals("")){
|
||||
//tables[i - 1] = metadata.getSchemaName(i)+"."+metadata.getTableName(i);
|
||||
tables[i - 1] = metadata.getTableName(i);
|
||||
schema[i - 1] = metadata.getSchemaName(i);
|
||||
}
|
||||
else{
|
||||
tables[i - 1] = metadata.getTableName(i);
|
||||
schema[i - 1] = "";
|
||||
}
|
||||
}
|
||||
else{
|
||||
tables[i - 1] = metadata.getTableName(i);
|
||||
schema[i - 1] = "";
|
||||
}
|
||||
columns[i - 1] = metadata.getColumnName(i);
|
||||
types[i - 1] = typeMap.getType(metadata.getColumnType(i), true);
|
||||
}
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
protected ResultSetShape(List resultDescriptor, Config model) {
|
||||
TypeHelper helper = TypeHelper.INSTANCE;
|
||||
int size = resultDescriptor.size();
|
||||
columns = new String[size];
|
||||
tables = new String[size];
|
||||
types = new Type[size];
|
||||
schema = new String[size];
|
||||
|
||||
for (int i = 0; i < size; i++) {
|
||||
ResultDescriptor desc = (ResultDescriptor) resultDescriptor.get(i);
|
||||
if(model.isDatabaseSchemaNameSupported()){
|
||||
if(desc.getSchemaName() != null && !desc.getSchemaName().equals("")){
|
||||
tables[i] = desc.getTableName();
|
||||
schema[i] = desc.getSchemaName();
|
||||
}else{
|
||||
tables[i] = desc.getTableName();
|
||||
schema[i] = "";
|
||||
}
|
||||
|
||||
}else{
|
||||
tables[i] = desc.getTableName();
|
||||
schema[i] = "";
|
||||
}
|
||||
columns[i] = desc.getColumnName();
|
||||
|
||||
int idx = desc.getColumnType().lastIndexOf('.');
|
||||
String uri = desc.getColumnType().substring(0, idx);
|
||||
String typeName = desc.getColumnType().substring(idx + 1);
|
||||
|
||||
types[i] = helper.getType(uri, typeName);
|
||||
if (types[i] == null) {
|
||||
throw new RuntimeException("Could not find type " + desc.getColumnType()
|
||||
+ " for column " + desc.getColumnName());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public int getColumnCount() {
|
||||
return columns.length;
|
||||
}
|
||||
|
||||
public String getTableName(int i) {
|
||||
return tables[i - 1];
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
public String getSchemaName(int i) {
|
||||
return schema[i - 1];
|
||||
}
|
||||
public String getColumnName(int i) {
|
||||
return columns[i - 1];
|
||||
}
|
||||
|
||||
public Type getColumnType(int i) {
|
||||
return types[i - 1];
|
||||
}
|
||||
|
||||
public String toString() {
|
||||
StringBuffer result = new StringBuffer();
|
||||
result.append(" column/table/schema/type: ");
|
||||
for (int i = 0; i < columns.length; i++) {
|
||||
result.append(columns[i]);
|
||||
result.append('\t');
|
||||
result.append(tables[i]);
|
||||
result.append('\t');
|
||||
result.append(schema[i]);
|
||||
result.append('\t');
|
||||
if (types[i] == null) {
|
||||
result.append("null");
|
||||
} else {
|
||||
result.append(types[i].getName());
|
||||
}
|
||||
result.append('\n');
|
||||
}
|
||||
|
||||
return result.toString();
|
||||
}
|
||||
|
||||
}
|
|
@ -1,187 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.sql.Types;
|
||||
|
||||
import commonj.sdo.Type;
|
||||
|
||||
public final class SDODataTypeHelper {
|
||||
|
||||
private SDODataTypeHelper() {
|
||||
|
||||
}
|
||||
|
||||
public static String columnTypeForSDOType(Type sdoType){
|
||||
if(sdoType == null){
|
||||
return null;
|
||||
}
|
||||
|
||||
if (sdoType == SDODataTypes.BOOLEAN) {
|
||||
return SDODataTypes.BOOLEAN_STR;
|
||||
} else if (sdoType == SDODataTypes.STRING) {
|
||||
return SDODataTypes.STRING_STR;
|
||||
} else if (sdoType == SDODataTypes.BYTE) {
|
||||
return SDODataTypes.BYTE_STR;
|
||||
} else if (sdoType == SDODataTypes.BYTES) {
|
||||
return SDODataTypes.BYTES_STR;
|
||||
} else if (sdoType == SDODataTypes.CHARACTER) {
|
||||
return SDODataTypes.CHARACTER_STR;
|
||||
} else if (sdoType == SDODataTypes.DATE) {
|
||||
return SDODataTypes.DATE_STR;
|
||||
} else if (sdoType == SDODataTypes.DATETIME) {
|
||||
return SDODataTypes.DATETIME_STR;
|
||||
} else if (sdoType == SDODataTypes.DAY) {
|
||||
return SDODataTypes.DAY_STR;
|
||||
} else if (sdoType == SDODataTypes.DECIMAL) {
|
||||
return SDODataTypes.DECIMAL_STR;
|
||||
} else if (sdoType == SDODataTypes.DOUBLE) {
|
||||
return SDODataTypes.DOUBLE_STR;
|
||||
} else if (sdoType == SDODataTypes.DURATION) {
|
||||
return SDODataTypes.DURATION_STR;
|
||||
} else if (sdoType == SDODataTypes.FLOAT) {
|
||||
return SDODataTypes.FLOAT_STR;
|
||||
} else if (sdoType == SDODataTypes.INT) {
|
||||
return SDODataTypes.INT_STR;
|
||||
} else if (sdoType == SDODataTypes.INTEGER) {
|
||||
return SDODataTypes.INTEGER_STR;
|
||||
} else if (sdoType == SDODataTypes.LONG) {
|
||||
return SDODataTypes.LONG_STR;
|
||||
} else if (sdoType == SDODataTypes.MONTH) {
|
||||
return SDODataTypes.MONTH_STR;
|
||||
} else if (sdoType == SDODataTypes.MONTHDAY) {
|
||||
return SDODataTypes.MONTHDAY_STR;
|
||||
} else if (sdoType == SDODataTypes.OBJECT) {
|
||||
return SDODataTypes.OBJECT_STR;
|
||||
} else if (sdoType == SDODataTypes.SHORT) {
|
||||
return SDODataTypes.SHORT_STR;
|
||||
} else if (sdoType == SDODataTypes.STRING) {
|
||||
return SDODataTypes.STRING_STR;
|
||||
} else if (sdoType == SDODataTypes.STRINGS) {
|
||||
return SDODataTypes.STRINGS_STR;
|
||||
} else if (sdoType == SDODataTypes.TIME) {
|
||||
return SDODataTypes.TIME_STR;
|
||||
} else if (sdoType == SDODataTypes.URI) {
|
||||
return SDODataTypes.URI_STR;
|
||||
} else if (sdoType == SDODataTypes.YEAR) {
|
||||
return SDODataTypes.YEAR_STR;
|
||||
} else if (sdoType == SDODataTypes.YEARMONTH) {
|
||||
return SDODataTypes.YEARMONTH_STR;
|
||||
} else if (sdoType == SDODataTypes.YEARMONTHDAY) {
|
||||
return SDODataTypes.YEARMONTHDAY_STR;
|
||||
} else if (sdoType == SDODataTypes.BOOLEANOBJECT) {
|
||||
return SDODataTypes.BOOLEANOBJECT_STR;
|
||||
} else if (sdoType == SDODataTypes.BYTEOBJECT) {
|
||||
return SDODataTypes.BYTEOBJECT_STR;
|
||||
} else if (sdoType == SDODataTypes.CHARACTEROBJECT) {
|
||||
return SDODataTypes.CHARACTEROBJECT_STR;
|
||||
} else if (sdoType == SDODataTypes.DOUBLEOBJECT) {
|
||||
return SDODataTypes.DOUBLEOBJECT_STR;
|
||||
} else if (sdoType == SDODataTypes.FLOATOBJECT) {
|
||||
return SDODataTypes.FLOATOBJECT_STR;
|
||||
} else if (sdoType == SDODataTypes.INTEGEROBJECT) {
|
||||
return SDODataTypes.INTEGEROBJECT_STR;
|
||||
} else if (sdoType == SDODataTypes.LONGOBJECT) {
|
||||
return SDODataTypes.LONGOBJECT_STR;
|
||||
} else if (sdoType == SDODataTypes.SHORTOBJECT) {
|
||||
return SDODataTypes.SHORTOBJECT_STR;
|
||||
} else {
|
||||
throw new RuntimeException("Not a valid SDO Type " + sdoType);
|
||||
}
|
||||
}
|
||||
|
||||
public static int sqlTypeFor(Type sdoType) {
|
||||
if (sdoType == null) {
|
||||
return Types.OTHER;
|
||||
}
|
||||
|
||||
if (sdoType == SDODataTypes.BOOLEAN) {
|
||||
return Types.BOOLEAN;
|
||||
} else if (sdoType == SDODataTypes.STRING) {
|
||||
return Types.VARCHAR;
|
||||
} else if (sdoType == SDODataTypes.BYTE) {
|
||||
return Types.TINYINT;
|
||||
} else if (sdoType == SDODataTypes.BYTES) {
|
||||
return Types.BINARY;
|
||||
} else if (sdoType == SDODataTypes.CHARACTER) {
|
||||
return Types.CHAR;
|
||||
} else if (sdoType == SDODataTypes.DATE) {
|
||||
return Types.DATE;
|
||||
} else if (sdoType == SDODataTypes.DATETIME) {
|
||||
return Types.DATE;
|
||||
} else if (sdoType == SDODataTypes.DAY) {
|
||||
return java.sql.Types.BINARY;
|
||||
} else if (sdoType == SDODataTypes.DECIMAL) {
|
||||
return java.sql.Types.DECIMAL;
|
||||
} else if (sdoType == SDODataTypes.DOUBLE) {
|
||||
return java.sql.Types.DOUBLE;
|
||||
} else if (sdoType == SDODataTypes.DURATION) {
|
||||
return java.sql.Types.VARCHAR;
|
||||
} else if (sdoType == SDODataTypes.FLOAT) {
|
||||
return java.sql.Types.REAL;
|
||||
} else if (sdoType == SDODataTypes.INT) {
|
||||
return java.sql.Types.INTEGER;
|
||||
} else if (sdoType == SDODataTypes.INTEGER) {
|
||||
return java.sql.Types.INTEGER;
|
||||
} else if (sdoType == SDODataTypes.LONG) {
|
||||
return java.sql.Types.BIGINT;
|
||||
} else if (sdoType == SDODataTypes.MONTH) {
|
||||
return java.sql.Types.VARCHAR;
|
||||
} else if (sdoType == SDODataTypes.MONTHDAY) {
|
||||
return java.sql.Types.VARCHAR;
|
||||
} else if (sdoType == SDODataTypes.OBJECT) {
|
||||
return java.sql.Types.JAVA_OBJECT;
|
||||
} else if (sdoType == SDODataTypes.SHORT) {
|
||||
return java.sql.Types.SMALLINT;
|
||||
} else if (sdoType == SDODataTypes.STRING) {
|
||||
return java.sql.Types.VARCHAR;
|
||||
} else if (sdoType == SDODataTypes.STRINGS) {
|
||||
return java.sql.Types.OTHER;
|
||||
} else if (sdoType == SDODataTypes.TIME) {
|
||||
return java.sql.Types.VARCHAR;
|
||||
} else if (sdoType == SDODataTypes.URI) {
|
||||
return java.sql.Types.VARCHAR;
|
||||
} else if (sdoType == SDODataTypes.YEAR) {
|
||||
return java.sql.Types.VARCHAR;
|
||||
} else if (sdoType == SDODataTypes.YEARMONTH) {
|
||||
return java.sql.Types.VARCHAR;
|
||||
} else if (sdoType == SDODataTypes.YEARMONTHDAY) {
|
||||
return java.sql.Types.VARCHAR;
|
||||
} else if (sdoType == SDODataTypes.BOOLEANOBJECT) {
|
||||
return java.sql.Types.BOOLEAN;
|
||||
} else if (sdoType == SDODataTypes.BYTEOBJECT) {
|
||||
return java.sql.Types.TINYINT;
|
||||
} else if (sdoType == SDODataTypes.CHARACTEROBJECT) {
|
||||
return java.sql.Types.CHAR;
|
||||
} else if (sdoType == SDODataTypes.DOUBLEOBJECT) {
|
||||
return java.sql.Types.DOUBLE;
|
||||
} else if (sdoType == SDODataTypes.FLOATOBJECT) {
|
||||
return java.sql.Types.REAL;
|
||||
} else if (sdoType == SDODataTypes.INTEGEROBJECT) {
|
||||
return java.sql.Types.INTEGER;
|
||||
} else if (sdoType == SDODataTypes.LONGOBJECT) {
|
||||
return java.sql.Types.BIGINT;
|
||||
} else if (sdoType == SDODataTypes.SHORTOBJECT) {
|
||||
return java.sql.Types.SMALLINT;
|
||||
} else {
|
||||
throw new RuntimeException("Not a valid SDO Type " + sdoType);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
|
@ -1,131 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import commonj.sdo.Type;
|
||||
import commonj.sdo.helper.TypeHelper;
|
||||
|
||||
/**
|
||||
* Defines SDO data types. This is used primalirly to type stored procedure OUT parameters.
|
||||
*
|
||||
*/
|
||||
public class SDODataTypes {
|
||||
|
||||
public static final TypeHelper TYPE_HELPER = TypeHelper.INSTANCE;
|
||||
|
||||
public static final Type BOOLEAN = TYPE_HELPER.getType("commonj.sdo", "Boolean");
|
||||
public static final String BOOLEAN_STR = "commonj.sdo.Boolean";
|
||||
|
||||
public static final Type BYTE = TYPE_HELPER.getType("commonj.sdo", "Byte");
|
||||
public static final String BYTE_STR = "commonj.sdo.Byte";
|
||||
|
||||
public static final Type BYTES = TYPE_HELPER.getType("commonj.sdo", "Bytes");
|
||||
public static final String BYTES_STR = "commonj.sdo.Bytes";
|
||||
|
||||
public static final Type CHARACTER = TYPE_HELPER.getType("commonj.sdo", "Character");
|
||||
public static final String CHARACTER_STR = "commonj.sdo.Character";
|
||||
|
||||
public static final Type DATE = TYPE_HELPER.getType("commonj.sdo", "Date");
|
||||
public static final String DATE_STR = "commonj.sdo.Date";
|
||||
|
||||
public static final Type DATETIME = TYPE_HELPER.getType("commonj.sdo", "Date");
|
||||
public static final String DATETIME_STR = "commonj.sdo.Date";
|
||||
|
||||
public static final Type DAY = TYPE_HELPER.getType("commonj.sdo", "Date");
|
||||
public static final String DAY_STR = "commonj.sdo.Day";
|
||||
|
||||
public static final Type DECIMAL = TYPE_HELPER.getType("commonj.sdo", "Float");
|
||||
public static final String DECIMAL_STR = "commonj.sdo.Float";
|
||||
|
||||
public static final Type DOUBLE = TYPE_HELPER.getType("commonj.sdo", "Double");
|
||||
public static final String DOUBLE_STR = "commonj.sdo.Double";
|
||||
|
||||
public static final Type DURATION = TYPE_HELPER.getType("commonj.sdo", "Date");
|
||||
public static final String DURATION_STR = "commonj.sdo.Date";
|
||||
|
||||
public static final Type FLOAT = TYPE_HELPER.getType("commonj.sdo", "Float");
|
||||
public static final String FLOAT_STR = "commonj.sdo.Float";
|
||||
|
||||
public static final Type INT = TYPE_HELPER.getType("commonj.sdo", "Int");
|
||||
public static final String INT_STR = "commonj.sdo.Int";
|
||||
|
||||
public static final Type INTEGER = TYPE_HELPER.getType("commonj.sdo", "Integer");
|
||||
public static final String INTEGER_STR = "commonj.sdo.Integer";
|
||||
|
||||
public static final Type LONG = TYPE_HELPER.getType("commonj.sdo", "Long");
|
||||
public static final String LONG_STR = "commonj.sdo.Long";
|
||||
|
||||
public static final Type MONTH = TYPE_HELPER.getType("commonj.sdo", "Date");
|
||||
public static final String MONTH_STR = "commonj.sdo.Date";
|
||||
|
||||
public static final Type MONTHDAY = TYPE_HELPER.getType("commonj.sdo", "Date");
|
||||
public static final String MONTHDAY_STR = "commonj.sdo.Date";
|
||||
|
||||
public static final Type OBJECT = TYPE_HELPER.getType("commonj.sdo", "Object");
|
||||
public static final String OBJECT_STR = "commonj.sdo.Object";
|
||||
|
||||
public static final Type SHORT = TYPE_HELPER.getType("commonj.sdo", "Short");
|
||||
public static final String SHORT_STR = "commonj.sdo.Short";
|
||||
|
||||
public static final Type STRING = TYPE_HELPER.getType("commonj.sdo", "String");
|
||||
public static final String STRING_STR = "commonj.sdo.String";
|
||||
|
||||
public static final Type STRINGS = TYPE_HELPER.getType("commonj.sdo", "String");
|
||||
public static final String STRINGS_STR = "commonj.sdo.String";
|
||||
|
||||
public static final Type TIME = TYPE_HELPER.getType("commonj.sdo", "Date");
|
||||
public static final String TIME_STR = "commonj.sdo.Date";
|
||||
|
||||
public static final Type URI = TYPE_HELPER.getType("commonj.sdo", "String");
|
||||
public static final String URI_STR = "commonj.sdo.String";
|
||||
|
||||
public static final Type YEAR = TYPE_HELPER.getType("commonj.sdo", "Date");
|
||||
public static final String YEAR_STR = "commonj.sdo.Date";
|
||||
|
||||
public static final Type YEARMONTH = TYPE_HELPER.getType("commonj.sdo", "Date");
|
||||
public static final String YEARMONTH_STR = "commonj.sdo.Date";
|
||||
|
||||
public static final Type YEARMONTHDAY = TYPE_HELPER.getType("commonj.sdo", "Date");
|
||||
public static final String YEARMONTHDAY_STR = "commonj.sdo.Date";
|
||||
|
||||
public static final Type BOOLEANOBJECT = TYPE_HELPER.getType("commonj.sdo", "BooleanObject");
|
||||
public static final String BOOLEANOBJECT_STR = "commonj.sdo.BooleanObject";
|
||||
|
||||
public static final Type BYTEOBJECT = TYPE_HELPER.getType("commonj.sdo", "ByteObject");
|
||||
public static final String BYTEOBJECT_STR = "commonj.sdo.ByteObject";
|
||||
|
||||
public static final Type CHARACTEROBJECT = TYPE_HELPER.getType("commonj.sdo", "CharacterObject");
|
||||
public static final String CHARACTEROBJECT_STR = "commonj.sdo.CharacterObject";
|
||||
|
||||
public static final Type DOUBLEOBJECT = TYPE_HELPER.getType("commonj.sdo", "DoubleObject");
|
||||
public static final String DOUBLEOBJECT_STR = "commonj.sdo.DoubleObject";
|
||||
|
||||
public static final Type FLOATOBJECT = TYPE_HELPER.getType("commonj.sdo", "FloatObject");
|
||||
public static final String FLOATOBJECT_STR = "commonj.sdo.FloatObject";
|
||||
|
||||
public static final Type INTEGEROBJECT = TYPE_HELPER.getType("commonj.sdo", "IntObject");
|
||||
public static final String INTEGEROBJECT_STR = "commonj.sdo.IntObject";
|
||||
|
||||
public static final Type LONGOBJECT = TYPE_HELPER.getType("commonj.sdo", "LongObject");
|
||||
public static final String LONGOBJECT_STR = "commonj.sdo.LongObject";
|
||||
|
||||
public static final Type SHORTOBJECT = TYPE_HELPER.getType("commonj.sdo", "ShortObject");
|
||||
public static final String SHORTOBJECT_STR = "commonj.sdo.ShortObject";
|
||||
|
||||
}
|
|
@ -1,100 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.sql.SQLException;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
import org.apache.tuscany.das.rdb.config.Parameter;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.MappingWrapper;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.Type;
|
||||
import commonj.sdo.helper.TypeHelper;
|
||||
|
||||
public class SPCommandImpl extends ReadCommandImpl {
|
||||
private final Logger logger = Logger.getLogger(SPCommandImpl.class);
|
||||
|
||||
public SPCommandImpl(String sqlString, MappingWrapper config, List params) {
|
||||
super(sqlString, config, null);
|
||||
Iterator i = params.iterator();
|
||||
while (i.hasNext()) {
|
||||
Parameter p = (Parameter) i.next();
|
||||
|
||||
int index = p.getColumnType().lastIndexOf('.');
|
||||
String pkg = p.getColumnType().substring(0, index);
|
||||
String typeName = p.getColumnType().substring(index + 1);
|
||||
|
||||
Type sdoType = TypeHelper.INSTANCE.getType(pkg, typeName);
|
||||
|
||||
String direction = ParameterExtendedImpl.IN;
|
||||
if (ParameterExtendedImpl.OUT.equalsIgnoreCase(p.getDirection())) {
|
||||
direction = ParameterExtendedImpl.OUT;
|
||||
} else if (ParameterExtendedImpl.IN_OUT.equalsIgnoreCase(p.getDirection())) {
|
||||
direction = ParameterExtendedImpl.IN_OUT;
|
||||
}
|
||||
parameters.findOrCreateParameterWithIndex(p.getIndex(), direction, sdoType);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public DataObject executeQuery() {
|
||||
|
||||
boolean success = false;
|
||||
try {
|
||||
List results = statement.executeCall(parameters);
|
||||
success = true;
|
||||
|
||||
return buildGraph(results);
|
||||
} catch (SQLException e) {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug(e);
|
||||
}
|
||||
|
||||
throw new RuntimeException(e);
|
||||
} finally {
|
||||
if (success) {
|
||||
statement.getConnection().cleanUp();
|
||||
} else {
|
||||
statement.getConnection().errorCleanUp();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void execute() {
|
||||
|
||||
boolean success = false;
|
||||
try {
|
||||
statement.executeUpdateCall(parameters);
|
||||
success = true;
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
} finally {
|
||||
if (success) {
|
||||
statement.getConnection().cleanUp();
|
||||
} else {
|
||||
statement.getConnection().errorCleanUp();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -1,233 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.sql.CallableStatement;
|
||||
import java.sql.ParameterMetaData;
|
||||
import java.sql.PreparedStatement;
|
||||
import java.sql.ResultSet;
|
||||
import java.sql.SQLException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
// TODO - Can use some refactoring. Much code is duplicated in "execute" methods
|
||||
public class Statement {
|
||||
|
||||
protected final String queryString;
|
||||
|
||||
protected ConnectionImpl jdbcConnection;
|
||||
|
||||
private final Logger logger = Logger.getLogger(Statement.class);
|
||||
|
||||
private PreparedStatement preparedStatement;
|
||||
|
||||
private boolean isPaging;
|
||||
|
||||
public Statement(String sqlString) {
|
||||
this.queryString = sqlString;
|
||||
}
|
||||
|
||||
public List executeQuery(ParametersExtendedImpl parameters) throws SQLException {
|
||||
|
||||
PreparedStatement ps = getPreparedStatement(new String[0]);
|
||||
ps = setParameters(ps, parameters);
|
||||
ResultSet rs = ps.executeQuery();
|
||||
|
||||
return Collections.singletonList(rs);
|
||||
}
|
||||
|
||||
public List executeCall(ParametersExtendedImpl parameters) throws SQLException {
|
||||
|
||||
CallableStatement cs = jdbcConnection.prepareCall(queryString);
|
||||
|
||||
Iterator inParams = parameters.getInParameters().iterator();
|
||||
while (inParams.hasNext()) {
|
||||
ParameterExtendedImpl param = (ParameterExtendedImpl) inParams.next();
|
||||
cs.setObject(param.getIndex(), param.getValue());
|
||||
}
|
||||
|
||||
// register out parameters
|
||||
Iterator outParams = parameters.getOutParameters().iterator();
|
||||
while (outParams.hasNext()) {
|
||||
ParameterExtendedImpl param = (ParameterExtendedImpl) outParams.next();
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Registering parameter " + param.getName());
|
||||
}
|
||||
|
||||
cs.registerOutParameter(param.getIndex(), SDODataTypeHelper.sqlTypeFor(param.getType()));
|
||||
}
|
||||
|
||||
// Using execute because Derby does not currenlty support
|
||||
// executeQuery
|
||||
// for SP
|
||||
cs.execute();
|
||||
List results = new ArrayList();
|
||||
results.add(cs.getResultSet());
|
||||
while (cs.getMoreResults(java.sql.Statement.KEEP_CURRENT_RESULT)) {
|
||||
results.add(cs.getResultSet());
|
||||
}
|
||||
|
||||
Iterator i = parameters.getOutParameters().iterator();
|
||||
while (i.hasNext()) {
|
||||
ParameterExtendedImpl param = (ParameterExtendedImpl) i.next();
|
||||
param.setValue(cs.getObject(param.getIndex()));
|
||||
}
|
||||
|
||||
return results;
|
||||
|
||||
}
|
||||
|
||||
public void executeUpdateCall(ParametersExtendedImpl parameters) throws SQLException {
|
||||
CallableStatement cs = jdbcConnection.prepareCall(queryString);
|
||||
|
||||
Iterator inParams = parameters.getInParameters().iterator();
|
||||
while (inParams.hasNext()) {
|
||||
ParameterExtendedImpl param = (ParameterExtendedImpl) inParams.next();
|
||||
cs.setObject(param.getIndex(), param.getValue());
|
||||
}
|
||||
|
||||
// register out parameters
|
||||
Iterator outParams = parameters.getOutParameters().iterator();
|
||||
while (outParams.hasNext()) {
|
||||
ParameterExtendedImpl param = (ParameterExtendedImpl) outParams.next();
|
||||
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Registering parameter " + param.getName());
|
||||
}
|
||||
|
||||
cs.registerOutParameter(param.getIndex(), SDODataTypeHelper.sqlTypeFor(param.getType()));
|
||||
}
|
||||
|
||||
cs.execute();
|
||||
|
||||
Iterator out = parameters.getOutParameters().iterator();
|
||||
while (out.hasNext()) {
|
||||
ParameterExtendedImpl param = (ParameterExtendedImpl) out.next();
|
||||
param.setValue(cs.getObject(param.getIndex()));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public int executeUpdate(ParametersExtendedImpl parameters, String[] generatedKeys) throws SQLException {
|
||||
return executeUpdate(getPreparedStatement(generatedKeys), parameters);
|
||||
}
|
||||
|
||||
public int executeUpdate(ParametersExtendedImpl parameters) throws SQLException {
|
||||
return executeUpdate(parameters, new String[0]);
|
||||
}
|
||||
|
||||
/**
|
||||
* TODO - We need to look at using specific ps.setXXX methods when a type
|
||||
* has been specified and try setObject otherwise.
|
||||
*/
|
||||
private int executeUpdate(PreparedStatement ps, ParametersExtendedImpl parameters) throws SQLException {
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Executing statement " + queryString);
|
||||
}
|
||||
|
||||
Iterator i = parameters.getInParameters().iterator();
|
||||
while (i.hasNext()) {
|
||||
ParameterExtendedImpl param = (ParameterExtendedImpl) i.next();
|
||||
|
||||
Object value = param.getValue();
|
||||
if (this.logger.isDebugEnabled()) {
|
||||
this.logger.debug("Setting parameter " + param.getIndex() + " to " + value);
|
||||
}
|
||||
|
||||
if (value == null) {
|
||||
if (param.getType() == null) {
|
||||
try {
|
||||
ParameterMetaData pmd = ps.getParameterMetaData();
|
||||
ps.setNull(param.getIndex(), pmd.getParameterType(param.getIndex()));
|
||||
} catch (SQLException ex) {
|
||||
ps.setNull(param.getIndex(), SDODataTypeHelper.sqlTypeFor(null));
|
||||
}
|
||||
} else {
|
||||
ps.setNull(param.getIndex(), SDODataTypeHelper.sqlTypeFor(param.getType()));
|
||||
}
|
||||
} else {
|
||||
ps.setObject(param.getIndex(), value);
|
||||
}
|
||||
}
|
||||
return ps.executeUpdate();
|
||||
}
|
||||
|
||||
protected PreparedStatement setParameters(PreparedStatement ps, ParametersExtendedImpl parameters) throws SQLException {
|
||||
Iterator i = parameters.getInParameters().iterator();
|
||||
while (i.hasNext()) {
|
||||
ParameterExtendedImpl param = (ParameterExtendedImpl) i.next();
|
||||
ps.setObject(param.getIndex(), param.getValue());
|
||||
}
|
||||
return ps;
|
||||
}
|
||||
|
||||
public void setConnection(ConnectionImpl jdbcConnection) {
|
||||
this.jdbcConnection = jdbcConnection;
|
||||
}
|
||||
|
||||
public ConnectionImpl getConnection() {
|
||||
return this.jdbcConnection;
|
||||
}
|
||||
|
||||
private PreparedStatement getPreparedStatement(String[] returnKeys) throws SQLException {
|
||||
|
||||
if (preparedStatement == null) {
|
||||
if (isPaging) {
|
||||
preparedStatement = jdbcConnection.preparePagedStatement(queryString);
|
||||
} else {
|
||||
preparedStatement = jdbcConnection.prepareStatement(queryString, returnKeys);
|
||||
}
|
||||
}
|
||||
|
||||
return preparedStatement;
|
||||
}
|
||||
|
||||
public Integer getGeneratedKey() throws SQLException {
|
||||
|
||||
if (getConnection().isGeneratedKeysSupported()) {
|
||||
ResultSet rs = preparedStatement.getGeneratedKeys();
|
||||
if (rs.next()) {
|
||||
return new Integer(rs.getInt(1));
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
protected void enablePaging() {
|
||||
isPaging = true;
|
||||
}
|
||||
|
||||
public void close() {
|
||||
|
||||
if (this.preparedStatement != null) {
|
||||
try {
|
||||
preparedStatement.close();
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -1,37 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Update;
|
||||
|
||||
public class UpdateCommandImpl extends WriteCommandImpl {
|
||||
public UpdateCommandImpl(org.apache.tuscany.das.rdb.config.Command command) {
|
||||
super(command);
|
||||
}
|
||||
|
||||
public UpdateCommandImpl(String sqlString) {
|
||||
super(sqlString);
|
||||
}
|
||||
|
||||
public UpdateCommandImpl(Update update) {
|
||||
super(update.getSql());
|
||||
this.addParameters(update.getParameters());
|
||||
}
|
||||
|
||||
}
|
|
@ -1,45 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Updates don't have to be sorted, so this class is a simple wrapper of ArrayList.
|
||||
*
|
||||
*/
|
||||
public class UpdateList {
|
||||
|
||||
private List updates = new ArrayList();
|
||||
|
||||
public UpdateList() {
|
||||
super();
|
||||
}
|
||||
|
||||
public void add(ChangeOperation c) {
|
||||
updates.add(c);
|
||||
}
|
||||
|
||||
public Collection getSortedList() {
|
||||
return updates;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,32 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
|
||||
public class UpdateOperation extends ChangeOperation {
|
||||
|
||||
public UpdateOperation(UpdateCommandImpl command, DataObject changedObject, String id) {
|
||||
super(command, changedObject);
|
||||
this.propagatedID = id;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,165 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.impl;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.io.OutputStream;
|
||||
import java.sql.SQLException;
|
||||
import java.util.List;
|
||||
import java.util.TreeMap;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.ResultDescriptor;
|
||||
import org.apache.tuscany.das.rdb.config.impl.ParameterImpl;
|
||||
import org.apache.tuscany.das.rdb.config.Parameters;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public abstract class WriteCommandImpl extends CommandImpl {
|
||||
|
||||
public WriteCommandImpl(org.apache.tuscany.das.rdb.config.Command command) {
|
||||
super(command);
|
||||
}
|
||||
|
||||
public WriteCommandImpl(String sqlString) {
|
||||
super(sqlString);
|
||||
}
|
||||
|
||||
public void setResultDescriptors(List resultDescriptorList){
|
||||
//ignore , applicable for ReadCommand only
|
||||
}
|
||||
|
||||
public List getResultDescriptors(){
|
||||
//ignore, applicable for ReadCommand only
|
||||
return null;
|
||||
}
|
||||
|
||||
public void addResultDescriptor(ResultDescriptor resultDescriptor){
|
||||
//ignore
|
||||
}
|
||||
|
||||
|
||||
public ResultDescriptor removeResultDescriptor(int index){
|
||||
return null;
|
||||
}
|
||||
|
||||
public ResultDescriptor removeResultDescriptor(ResultDescriptor resultDescriptor){
|
||||
return null;
|
||||
}
|
||||
|
||||
public ResultDescriptor getResultDescriptor(int index){
|
||||
return null;
|
||||
}
|
||||
|
||||
public void printResultDescriptors(OutputStream ostrm) throws IOException{
|
||||
//ignore
|
||||
}
|
||||
|
||||
public void execute() {
|
||||
|
||||
boolean success = false;
|
||||
try {
|
||||
basicExecute();
|
||||
success = true;
|
||||
} finally {
|
||||
if (success) {
|
||||
statement.getConnection().cleanUp();
|
||||
} else {
|
||||
statement.getConnection().errorCleanUp();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public void basicExecute() {
|
||||
try {
|
||||
statement.executeUpdate(parameters);
|
||||
} catch (SQLException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
public DataObject executeQuery() {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
public Config getMappingModel() {
|
||||
return configWrapper.getConfig();
|
||||
}
|
||||
|
||||
public String toString() {
|
||||
|
||||
StringBuffer buffer = new StringBuffer();
|
||||
buffer.append("\nSQL: " + statement.queryString);
|
||||
|
||||
return buffer.toString();
|
||||
}
|
||||
|
||||
public int getGeneratedKey() {
|
||||
throw new RuntimeException("No generated key is available");
|
||||
}
|
||||
|
||||
//it is acceptable if params having index set by caller are listed in any order in Parameters
|
||||
//but, if index is not set by caller, the order of parameters in Parameters should be in sync
|
||||
//with the Command string parameters
|
||||
protected void addParameters(Parameters parameters) {
|
||||
List params = parameters.getParameter();
|
||||
if(params == null)
|
||||
return;
|
||||
|
||||
boolean paramsIndexed = true;
|
||||
TreeMap sortedParams = null;
|
||||
for(int i=0; i<params.size(); i++){
|
||||
if(((ParameterImpl)params.get(i)).getIndex() <= 0){
|
||||
paramsIndexed=false; //any index not set, ignore all externally set indexes and do auto indexing
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
//auto-indexing
|
||||
if(!paramsIndexed) {
|
||||
for(int i=0; i<params.size(); i++){
|
||||
ParameterExtendedImpl param = new ParameterExtendedImpl((ParameterImpl)params.get(i));
|
||||
param.setIndex(i+1);
|
||||
this.addParameter(param);
|
||||
}
|
||||
return;
|
||||
}
|
||||
else {//dont allow duplicates and check indexing with +1 increment from 1st to last param
|
||||
sortedParams = new TreeMap();
|
||||
for(int i=0; i<params.size(); i++){
|
||||
ParameterImpl existingParam = (ParameterImpl)sortedParams.put( new Integer(((ParameterImpl)params.get(i)).getIndex()), ((ParameterImpl)params.get(i)));
|
||||
if(existingParam != null) {
|
||||
throw new RuntimeException("Parameters with duplicate indexes!");
|
||||
}
|
||||
}
|
||||
|
||||
if( ((Integer)sortedParams.firstKey()).intValue() + sortedParams.size() -1 !=
|
||||
((Integer)sortedParams.lastKey()).intValue()) {
|
||||
throw new RuntimeException("Parameters with improper indexes!");
|
||||
}
|
||||
}
|
||||
|
||||
for(int i=0; i<params.size(); i++) {
|
||||
ParameterExtendedImpl param = new ParameterExtendedImpl((ParameterImpl)params.get(i));
|
||||
param.setIndex(((ParameterImpl)params.get(i)).getIndex());
|
||||
this.addParameter(param);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,228 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.merge.impl;
|
||||
|
||||
import java.util.Collections;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.wrapper.QualifiedColumn;
|
||||
import org.apache.tuscany.das.rdb.graphbuilder.impl.MultiTableRegistry;
|
||||
import org.apache.tuscany.das.rdb.graphbuilder.impl.TableRegistry;
|
||||
import org.apache.tuscany.sdo.impl.ChangeSummaryImpl;
|
||||
import org.apache.tuscany.sdo.api.SDOUtil;
|
||||
|
||||
import commonj.sdo.ChangeSummary;
|
||||
import commonj.sdo.DataGraph;
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.Property;
|
||||
import commonj.sdo.Type;
|
||||
import commonj.sdo.helper.TypeHelper;
|
||||
import commonj.sdo.impl.HelperProvider;
|
||||
|
||||
public class GraphMerger {
|
||||
|
||||
private static Logger logger = Logger.getLogger("GraphMerger");
|
||||
|
||||
private Map keys = new HashMap();
|
||||
|
||||
private TableRegistry registry = new MultiTableRegistry();
|
||||
|
||||
private Config config = null;//JIRA-962 for any new tests with schema , we need this
|
||||
|
||||
// TODO lots of cleanup/design
|
||||
public GraphMerger() {
|
||||
// Empty Constructor
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
public GraphMerger(Config cfg) {
|
||||
this.config = cfg;
|
||||
}
|
||||
|
||||
// TODO Replace EMF reference with SDOUtil function when available
|
||||
// (Tuscany-583)
|
||||
public DataObject emptyGraph(Config config) {
|
||||
|
||||
if (config.getDataObjectModel() == null) {
|
||||
throw new RuntimeException("DataObjectModel must be specified in the Config");
|
||||
}
|
||||
|
||||
String uri = "http:///org.apache.tuscany.das.rdb/das";
|
||||
TypeHelper typeHelper = HelperProvider.getDefaultContext().getTypeHelper();
|
||||
Type rootType = null;
|
||||
rootType = typeHelper.getType(uri + "/DataGraphRoot", "DataGraphRoot");
|
||||
if(rootType == null){
|
||||
rootType = SDOUtil.createType(HelperProvider.getDefaultContext(), uri + "/DataGraphRoot", "DataGraphRoot", false);
|
||||
if (logger.isDebugEnabled()) {
|
||||
logger.debug("GraphMerger.emptyGraph():creating type for "+uri);
|
||||
}
|
||||
}
|
||||
|
||||
List types = SDOUtil.getTypes(HelperProvider.getDefaultContext(), config.getDataObjectModel());
|
||||
if (types == null) {
|
||||
throw new RuntimeException("SDO Types have not been registered for URI " + config.getDataObjectModel());
|
||||
}
|
||||
|
||||
Iterator i = types.iterator();
|
||||
while (i.hasNext()) {
|
||||
Type type = (Type) i.next();
|
||||
Property property = rootType.getProperty(type.getName());
|
||||
if( !(property != null &&
|
||||
(property.getType().isDataType()== type.isDataType()) &&
|
||||
(property.isContainment() == true) &&
|
||||
(property.isMany() == true)) ){
|
||||
property = SDOUtil.createProperty(rootType, type.getName(), type);
|
||||
SDOUtil.setContainment(property, true);
|
||||
SDOUtil.setMany(property, true);
|
||||
}
|
||||
}
|
||||
|
||||
// Create the DataGraph
|
||||
DataGraph g = SDOUtil.createDataGraph();
|
||||
|
||||
// Create the root object
|
||||
g.createRootObject(rootType);
|
||||
|
||||
ChangeSummary summary = g.getChangeSummary();
|
||||
summary.beginLogging();
|
||||
|
||||
return g.getRootObject();
|
||||
}
|
||||
|
||||
public DataObject merge(List graphs) {
|
||||
DataObject primaryGraph = (DataObject) graphs.get(0);
|
||||
|
||||
Iterator i = graphs.iterator();
|
||||
if (i.hasNext()) {
|
||||
i.next();
|
||||
}
|
||||
while (i.hasNext()) {
|
||||
primaryGraph = merge(primaryGraph, (DataObject) i.next());
|
||||
}
|
||||
|
||||
return primaryGraph;
|
||||
}
|
||||
|
||||
public DataObject merge(DataObject primary, DataObject secondary) {
|
||||
addGraphToRegistry(primary);
|
||||
|
||||
ChangeSummary summary = primary.getDataGraph().getChangeSummary();
|
||||
summary.endLogging();
|
||||
Iterator i = secondary.getType().getProperties().iterator();
|
||||
|
||||
while (i.hasNext()) {
|
||||
Property p = (Property) i.next();
|
||||
|
||||
Iterator objects = secondary.getList(p.getName()).iterator();
|
||||
while (objects.hasNext()) {
|
||||
DataObject object = (DataObject) objects.next();
|
||||
createObjectWithSubtree(primary, p, object);
|
||||
}
|
||||
}
|
||||
((ChangeSummaryImpl) summary).resumeLogging();
|
||||
return primary;
|
||||
}
|
||||
|
||||
private void createObjectWithSubtree(DataObject root, Property p, DataObject object) {
|
||||
Object pk = getPrimaryKey(object);
|
||||
|
||||
if (!registry.contains(object.getType().getName(), Collections.singletonList(pk))) {
|
||||
DataObject newObject = root.createDataObject(p.getName());
|
||||
Iterator attrs = object.getType().getProperties().iterator();
|
||||
while (attrs.hasNext()) {
|
||||
Property attr = (Property) attrs.next();
|
||||
if (attr.getType().isDataType()) {
|
||||
newObject.set(attr.getName(), object.get(attr));
|
||||
}
|
||||
}
|
||||
registry.put(object.getType().getName(), Collections.singletonList(pk), newObject);
|
||||
Iterator refs = object.getType().getProperties().iterator();
|
||||
while (refs.hasNext()) {
|
||||
Property ref = (Property) refs.next();
|
||||
if (!ref.getType().isDataType()) {
|
||||
List refObjects;
|
||||
if (!ref.isMany()) {
|
||||
refObjects = Collections.singletonList(object.get(ref));
|
||||
} else {
|
||||
refObjects = (List) object.get(ref);
|
||||
}
|
||||
Iterator iter = refObjects.iterator();
|
||||
while (iter.hasNext()) {
|
||||
DataObject refObject = (DataObject) iter.next();
|
||||
createObjectWithSubtree(root, refObject.getContainmentProperty(), refObject);
|
||||
refObject = registry.get(refObject.getType().getName(),
|
||||
Collections.singletonList(getPrimaryKey(refObject)));
|
||||
if (ref.isMany()) {
|
||||
newObject.getList(newObject.getType().getProperty(ref.getName())).add(refObject);
|
||||
} else {
|
||||
newObject.set(newObject.getType().getProperty(ref.getName()), refObject);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private void addGraphToRegistry(DataObject graph1) {
|
||||
Iterator i = graph1.getType().getProperties().iterator();
|
||||
while (i.hasNext()) {
|
||||
Property p = (Property) i.next();
|
||||
Iterator objects = graph1.getList(p).iterator();
|
||||
while (objects.hasNext()) {
|
||||
DataObject object = (DataObject) objects.next();
|
||||
Object pk = object.get(getPrimaryKeyName(object));
|
||||
if (logger.isDebugEnabled()) {
|
||||
logger.debug("Adding object with pk " + pk + " to registry");
|
||||
}
|
||||
registry.put(object.getType().getName(), Collections.singletonList(pk), object);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private Object getPrimaryKey(DataObject object) {
|
||||
String pkName = getPrimaryKeyName(object);
|
||||
return object.get(pkName);
|
||||
}
|
||||
|
||||
private String getPrimaryKeyName(DataObject object) {
|
||||
return (String) keys.get(object.getType().getName());
|
||||
}
|
||||
|
||||
//JIRA-952
|
||||
public void addPrimaryKey(String key) {
|
||||
QualifiedColumn column = null;
|
||||
if(this.config != null && this.config.isDatabaseSchemaNameSupported()){
|
||||
column = new QualifiedColumn(key, this.config.isDatabaseSchemaNameSupported());
|
||||
}
|
||||
else{
|
||||
column = new QualifiedColumn(key);
|
||||
}
|
||||
|
||||
if (logger.isDebugEnabled()) {
|
||||
logger.debug("Adding " + column.getTableName() + " " + column.getColumnName() + " to keys");
|
||||
}
|
||||
keys.put(column.getTableName(), column.getColumnName());
|
||||
}
|
||||
}
|
|
@ -1,49 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.util;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.Iterator;
|
||||
|
||||
/**
|
||||
*/
|
||||
public final class CollectionsUtil {
|
||||
|
||||
private CollectionsUtil() {
|
||||
|
||||
}
|
||||
|
||||
// Utilities
|
||||
public static boolean disjoint(Collection c1, Collection c2) {
|
||||
|
||||
if (c1.size() > c2.size()) {
|
||||
Collection c = c1;
|
||||
c1 = c2;
|
||||
c2 = c;
|
||||
}
|
||||
for (Iterator iterator = c2.iterator(); iterator.hasNext();) {
|
||||
Object o = (Object)iterator.next();
|
||||
if (c1.contains(o)) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,130 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.util;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.tuscany.das.rdb.config.Command;
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.config.ConfigFactory;
|
||||
import org.apache.tuscany.das.rdb.config.Create;
|
||||
import org.apache.tuscany.das.rdb.config.Delete;
|
||||
import org.apache.tuscany.das.rdb.config.Parameter;
|
||||
import org.apache.tuscany.das.rdb.config.Update;
|
||||
|
||||
import commonj.sdo.helper.HelperContext;
|
||||
import commonj.sdo.helper.XMLHelper;
|
||||
import commonj.sdo.impl.HelperProvider;
|
||||
|
||||
/**
|
||||
* Config util provides config-related utilities such as loading a Config
|
||||
* instance from an InputStream
|
||||
*
|
||||
*/
|
||||
public final class ConfigUtil {
|
||||
|
||||
private ConfigUtil() {
|
||||
|
||||
}
|
||||
|
||||
public static Config loadConfig(InputStream configStream) {
|
||||
|
||||
if (configStream == null) {
|
||||
throw new RuntimeException("Cannot load configuration from a null InputStream. "
|
||||
+ "Possibly caused by an incorrect config xml file name");
|
||||
}
|
||||
|
||||
HelperContext context = HelperProvider.getDefaultContext();
|
||||
ConfigFactory.INSTANCE.register(context);
|
||||
XMLHelper helper = context.getXMLHelper();
|
||||
|
||||
try {
|
||||
return (Config) helper.load(configStream).getRootObject();
|
||||
} catch (IOException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
public static String getParameters(Create createCommand) {
|
||||
List parameters = createCommand.getParameters().getParameter();
|
||||
if(parameters != null) {
|
||||
Iterator itr = parameters.iterator();
|
||||
StringBuffer serializedParameters = new StringBuffer();
|
||||
|
||||
while(itr.hasNext()) {
|
||||
serializedParameters.append(((Parameter)itr.next()).getName()+" ");
|
||||
}
|
||||
return serializedParameters.toString().trim();
|
||||
}
|
||||
else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
public static String getParameters(Update updateCommand) {
|
||||
List parameters = updateCommand.getParameters().getParameter();
|
||||
if(parameters != null) {
|
||||
Iterator itr = parameters.iterator();
|
||||
StringBuffer serializedParameters = new StringBuffer();
|
||||
|
||||
while(itr.hasNext()) {
|
||||
serializedParameters.append(((Parameter)itr.next()).getName()+" ");
|
||||
}
|
||||
return serializedParameters.toString().trim();
|
||||
}
|
||||
else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
public static String getParameters(Delete deleteCommand) {
|
||||
List parameters = deleteCommand.getParameters().getParameter();
|
||||
if(parameters != null) {
|
||||
Iterator itr = parameters.iterator();
|
||||
StringBuffer serializedParameters = new StringBuffer();
|
||||
|
||||
while(itr.hasNext()) {
|
||||
serializedParameters.append(((Parameter)itr.next()).getName()+" ");
|
||||
}
|
||||
return serializedParameters.toString().trim();
|
||||
}
|
||||
else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
public static String getParameters(Command command) {
|
||||
List parameters = command.getParameter();
|
||||
if(parameters != null) {
|
||||
Iterator itr = parameters.iterator();
|
||||
StringBuffer serializedParameters = new StringBuffer();
|
||||
|
||||
while(itr.hasNext()) {
|
||||
serializedParameters.append(((Parameter)itr.next()).getName()+" ");
|
||||
}
|
||||
return serializedParameters.toString().trim();
|
||||
}
|
||||
else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,79 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.util;
|
||||
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import commonj.sdo.ChangeSummary;
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.Property;
|
||||
import commonj.sdo.ChangeSummary.Setting;
|
||||
import commonj.sdo.helper.DataFactory;
|
||||
|
||||
/**
|
||||
*/
|
||||
public final class DataObjectUtil {
|
||||
|
||||
private DataObjectUtil() {
|
||||
|
||||
}
|
||||
|
||||
// Utilities
|
||||
public static DataObject getRestoredCopy(DataObject changedDO) {
|
||||
DataObject changedCopy = getCopy(changedDO);
|
||||
restoreAttributeValues(changedCopy, changedDO);
|
||||
return changedCopy;
|
||||
}
|
||||
|
||||
public static DataObject getCopy(DataObject original) {
|
||||
|
||||
DataObject copy = DataFactory.INSTANCE.create(original.getType());
|
||||
|
||||
// Fill in values
|
||||
Iterator i = original.getType().getProperties().iterator();
|
||||
while (i.hasNext()) {
|
||||
Property feature = (Property) i.next();
|
||||
copy.set(feature, original.get(feature));
|
||||
}
|
||||
return copy;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param changedCopy
|
||||
* @return
|
||||
*/
|
||||
private static void restoreAttributeValues(DataObject changedCopy, DataObject changedDO) {
|
||||
|
||||
ChangeSummary changeSummary = changedDO.getDataGraph().getChangeSummary();
|
||||
List changes = changeSummary.getOldValues(changedDO);
|
||||
if (changes == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
Iterator i = changes.iterator();
|
||||
while (i.hasNext()) {
|
||||
Setting s = (Setting) i.next();
|
||||
if (s.getProperty().getType().isDataType()) {
|
||||
changedCopy.set(s.getProperty(), s.getValue());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -1,7 +0,0 @@
|
|||
Apache Tuscany is an effort undergoing incubation at The Apache Software
|
||||
Foundation (ASF), sponsored by the Apache Web Services PMC. Incubation is
|
||||
required of all newly accepted projects until a further review indicates that
|
||||
the infrastructure, communications, and decision making process have stabilized
|
||||
in a manner consistent with other successful ASF projects. While incubation
|
||||
status is not necessarily a reflection of the completeness or stability of the
|
||||
code, it does indicate that the project has yet to be fully endorsed by the ASF.
|
|
@ -1,353 +0,0 @@
|
|||
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
|
||||
1. Definitions.
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following
|
||||
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||
replaced with your own identifying information. (Don't include
|
||||
the brackets!) The text should be enclosed in the appropriate
|
||||
comment syntax for the file format. We also recommend that a
|
||||
file or class name and description of purpose be included on the
|
||||
same "printed page" as the copyright notice for easier
|
||||
identification within third-party archives.
|
||||
|
||||
Copyright [yyyy] [name of copyright owner]
|
||||
|
||||
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
|
||||
limitations under the License.
|
||||
|
||||
===============================================================================================================
|
||||
|
||||
Other components and dependencies under Apache Software License 2.0 :
|
||||
|
||||
log4j-1.2.14.jar - Apache Logging Services
|
||||
derby 10.2.2.0.jar - Apache Derby
|
||||
stax-api-1.0.1.jar - The Streaming API for XML (StAX)
|
||||
wstx-asl-3.2.0.jar - WoodStox StAX implementation
|
||||
standard-1.1.1.jar - The Apache Jackarta Taglibs
|
||||
jstl-1.1.2.jar - The Apache Jackarta Taglibs
|
||||
*.tld - The Apache Jackarta Taglibs
|
||||
|
||||
===============================================================================================================
|
||||
|
||||
|
||||
Apache Tuscany SDO for Java Subcomponents
|
||||
=========================================:
|
||||
|
||||
The Tuscany SDO for Java release includes a number of subcomponents with
|
||||
separate copyright notices and license terms. Your use of the source
|
||||
code for the these subcomponents is subject to the terms and
|
||||
conditions of the following licenses.
|
||||
|
||||
License for the Service Data Objects JavaDoc and Interface Definition files. (tuscany-sdo-api-r2.1-1.0-incubating.jar)
|
||||
|
||||
Permission to copy, make derivative works of, and distribute the Service Data Objects
|
||||
JavaDoc and Interface Definition Files files in any medium without fee or royalty as part
|
||||
of a compliant implementation of the Service Data Objects Specification is hereby granted.
|
||||
The Service Data Objects Specification may be found at any of the following locations:
|
||||
|
||||
http://dev2dev.bea.com/technologies/commonj/index.jsp
|
||||
http://www.ibm.com/developerworks/library/specification/ws-sdo/
|
||||
http://oracle.com/technology/webservices/sca
|
||||
https://www.sdn.sap.com/
|
||||
http://www.xcalia/xdn/specs/sdo
|
||||
|
||||
THE SERVICE DATA OBJECTS SPECIFICATION AND THE JAVADOC AND INTERFACE DEFINITION FILES
|
||||
ARE PROVIDED "AS IS," AND THE AUTHORS MAKE NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, REGARDING THIS
|
||||
SPECIFICATION OR THE JAVADOC AND INTERFACE DEFINITION FILES AND THE IMPLEMENTATION OF THEIR CONTENTS,
|
||||
INCLUDING, BUT NOT LIMITED TO, WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE,
|
||||
NON-INFRINGEMENT OR TITLE. THE AUTHORS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL,
|
||||
INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF OR RELATING TO ANY USE OR DISTRIBUTION OF THE
|
||||
SERVICE DATA OBJECTS SPECIFICATION OR THE JAVADOC OR INTERFACE DEFINTION FILES.
|
||||
|
||||
The name and trademarks of the Authors may NOT be used in any manner, including advertising or
|
||||
publicity pertaining to the Service Component Architecture Specification or its contents without specific,
|
||||
written prior permission. Title to copyright in the Service Data Objects Specification and the
|
||||
JavaDoc and Interface Definition Files will at all times remain with the Authors.
|
||||
|
||||
No other rights are granted by implication, estoppel or otherwise.
|
||||
|
||||
=================================================================================================================
|
||||
|
||||
For the Eclipse EMF components
|
||||
(codegen-2.2.3.jar
|
||||
codegen-ecore-2.2.3.jar
|
||||
common-2.2.3.jar
|
||||
ecore-2.2.3.jar
|
||||
ecore-change-2.2.3.jar
|
||||
ecore-xmi-2.2.3.jar
|
||||
xsd-2.2.3.jar)
|
||||
|
||||
Eclipse Public License - v 1.0
|
||||
|
||||
THE ACCOMPANYING PROGRAM IS PROVIDED UNDER THE TERMS OF THIS ECLIPSE PUBLIC LICENSE ("AGREEMENT"). ANY USE, REPRODUCTION OR DISTRIBUTION OF THE PROGRAM CONSTITUTES RECIPIENT'S ACCEPTANCE OF THIS AGREEMENT.
|
||||
|
||||
1. DEFINITIONS
|
||||
|
||||
"Contribution" means:
|
||||
|
||||
a) in the case of the initial Contributor, the initial code and documentation distributed under this Agreement, and
|
||||
b) in the case of each subsequent Contributor:
|
||||
|
||||
i) changes to the Program, and
|
||||
|
||||
ii) additions to the Program;
|
||||
|
||||
where such changes and/or additions to the Program originate from and are distributed by that particular Contributor. A Contribution 'originates' from a Contributor if it was added to the Program by such Contributor itself or anyone acting on such Contributor's behalf. Contributions do not include additions to the Program which: (i) are separate modules of software distributed in conjunction with the Program under their own license agreement, and (ii) are not derivative works of the Program.
|
||||
|
||||
"Contributor" means any person or entity that distributes the Program.
|
||||
|
||||
"Licensed Patents " mean patent claims licensable by a Contributor which are necessarily infringed by the use or sale of its Contribution alone or when combined with the Program.
|
||||
|
||||
"Program" means the Contributions distributed in accordance with this Agreement.
|
||||
|
||||
"Recipient" means anyone who receives the Program under this Agreement, including all Contributors.
|
||||
|
||||
2. GRANT OF RIGHTS
|
||||
|
||||
a) Subject to the terms of this Agreement, each Contributor hereby grants Recipient a non-exclusive, worldwide, royalty-free copyright license to reproduce, prepare derivative works of, publicly display, publicly perform, distribute and sublicense the Contribution of such Contributor, if any, and such derivative works, in source code and object code form.
|
||||
|
||||
b) Subject to the terms of this Agreement, each Contributor hereby grants Recipient a non-exclusive, worldwide, royalty-free patent license under Licensed Patents to make, use, sell, offer to sell, import and otherwise transfer the Contribution of such Contributor, if any, in source code and object code form. This patent license shall apply to the combination of the Contribution and the Program if, at the time the Contribution is added by the Contributor, such addition of the Contribution causes such combination to be covered by the Licensed Patents. The patent license shall not apply to any other combinations which include the Contribution. No hardware per se is licensed hereunder.
|
||||
|
||||
c) Recipient understands that although each Contributor grants the licenses to its Contributions set forth herein, no assurances are provided by any Contributor that the Program does not infringe the patent or other intellectual property rights of any other entity. Each Contributor disclaims any liability to Recipient for claims brought by any other entity based on infringement of intellectual property rights or otherwise. As a condition to exercising the rights and licenses granted hereunder, each Recipient hereby assumes sole responsibility to secure any other intellectual property rights needed, if any. For example, if a third party patent license is required to allow Recipient to distribute the Program, it is Recipient's responsibility to acquire that license before distributing the Program.
|
||||
|
||||
d) Each Contributor represents that to its knowledge it has sufficient copyright rights in its Contribution, if any, to grant the copyright license set forth in this Agreement.
|
||||
|
||||
3. REQUIREMENTS
|
||||
|
||||
A Contributor may choose to distribute the Program in object code form under its own license agreement, provided that:
|
||||
|
||||
a) it complies with the terms and conditions of this Agreement; and
|
||||
|
||||
b) its license agreement:
|
||||
|
||||
i) effectively disclaims on behalf of all Contributors all warranties and conditions, express and implied, including warranties or conditions of title and non-infringement, and implied warranties or conditions of merchantability and fitness for a particular purpose;
|
||||
|
||||
ii) effectively excludes on behalf of all Contributors all liability for damages, including direct, indirect, special, incidental and consequential damages, such as lost profits;
|
||||
|
||||
iii) states that any provisions which differ from this Agreement are offered by that Contributor alone and not by any other party; and
|
||||
|
||||
iv) states that source code for the Program is available from such Contributor, and informs licensees how to obtain it in a reasonable manner on or through a medium customarily used for software exchange.
|
||||
|
||||
When the Program is made available in source code form:
|
||||
|
||||
a) it must be made available under this Agreement; and
|
||||
|
||||
b) a copy of this Agreement must be included with each copy of the Program.
|
||||
|
||||
Contributors may not remove or alter any copyright notices contained within the Program.
|
||||
|
||||
Each Contributor must identify itself as the originator of its Contribution, if any, in a manner that reasonably allows subsequent Recipients to identify the originator of the Contribution.
|
||||
|
||||
4. COMMERCIAL DISTRIBUTION
|
||||
|
||||
Commercial distributors of software may accept certain responsibilities with respect to end users, business partners and the like. While this license is intended to facilitate the commercial use of the Program, the Contributor who includes the Program in a commercial product offering should do so in a manner which does not create potential liability for other Contributors. Therefore, if a Contributor includes the Program in a commercial product offering, such Contributor ("Commercial Contributor") hereby agrees to defend and indemnify every other Contributor ("Indemnified Contributor") against any losses, damages and costs (collectively "Losses") arising from claims, lawsuits and other legal actions brought by a third party against the Indemnified Contributor to the extent caused by the acts or omissions of such Commercial Contributor in connection with its distribution of the Program in a commercial product offering. The obligations in this section do not apply to any claims or Losses relating to any actual or alleged intellectual property infringement. In order to qualify, an Indemnified Contributor must: a) promptly notify the Commercial Contributor in writing of such claim, and b) allow the Commercial Contributor to control, and cooperate with the Commercial Contributor in, the defense and any related settlement negotiations. The Indemnified Contributor may participate in any such claim at its own expense.
|
||||
|
||||
For example, a Contributor might include the Program in a commercial product offering, Product X. That Contributor is then a Commercial Contributor. If that Commercial Contributor then makes performance claims, or offers warranties related to Product X, those performance claims and warranties are such Commercial Contributor's responsibility alone. Under this section, the Commercial Contributor would have to defend claims against the other Contributors related to those performance claims and warranties, and if a court requires any other Contributor to pay any damages as a result, the Commercial Contributor must pay those damages.
|
||||
|
||||
5. NO WARRANTY
|
||||
|
||||
EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is solely responsible for determining the appropriateness of using and distributing the Program and assumes all risks associated with its exercise of rights under this Agreement , including but not limited to the risks and costs of program errors, compliance with applicable laws, damage to or loss of data, programs or equipment, and unavailability or interruption of operations.
|
||||
|
||||
6. DISCLAIMER OF LIABILITY
|
||||
|
||||
EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
7. GENERAL
|
||||
|
||||
If any provision of this Agreement is invalid or unenforceable under applicable law, it shall not affect the validity or enforceability of the remainder of the terms of this Agreement, and without further action by the parties hereto, such provision shall be reformed to the minimum extent necessary to make such provision valid and enforceable.
|
||||
|
||||
If Recipient institutes patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Program itself (excluding combinations of the Program with other software or hardware) infringes such Recipient's patent(s), then such Recipient's rights granted under Section 2(b) shall terminate as of the date such litigation is filed.
|
||||
|
||||
All Recipient's rights under this Agreement shall terminate if it fails to comply with any of the material terms or conditions of this Agreement and does not cure such failure in a reasonable period of time after becoming aware of such noncompliance. If all Recipient's rights under this Agreement terminate, Recipient agrees to cease use and distribution of the Program as soon as reasonably practicable. However, Recipient's obligations under this Agreement and any licenses granted by Recipient relating to the Program shall continue and survive.
|
||||
|
||||
Everyone is permitted to copy and distribute copies of this Agreement, but in order to avoid inconsistency the Agreement is copyrighted and may only be modified in the following manner. The Agreement Steward reserves the right to publish new versions (including revisions) of this Agreement from time to time. No one other than the Agreement Steward has the right to modify this Agreement. The Eclipse Foundation is the initial Agreement Steward. The Eclipse Foundation may assign the responsibility to serve as the Agreement Steward to a suitable separate entity. Each new version of the Agreement will be given a distinguishing version number. The Program (including Contributions) may always be distributed subject to the version of the Agreement under which it was received. In addition, after a new version of the Agreement is published, Contributor may elect to distribute the Program (including its Contributions) under the new version. Except as expressly stated in Sections 2(a) and 2(b) above, Recipient receives no rights or licenses to the intellectual property of any Contributor under this Agreement, whether expressly, by implication, estoppel or otherwise. All rights in the Program not expressly granted under this Agreement are reserved.
|
||||
|
||||
This Agreement is governed by the laws of the State of New York and the intellectual property laws of the United States of America. No party to this Agreement will bring a legal action under this Agreement more than one year after the cause of action arose. Each party waives its rights to a jury trial in any resulting litigation.
|
||||
|
||||
===================================================================================================
|
|
@ -1,32 +0,0 @@
|
|||
Apache Tuscany SDO for Java
|
||||
Copyright 2006, 2007 The Apache Software Foundation
|
||||
|
||||
This product includes software developed at
|
||||
The Apache Software Foundation (http://www.apache.org/).
|
||||
|
||||
Apache Tuscany is an effort undergoing incubation at The Apache Software Foundation (ASF),
|
||||
sponsored by the Apache Web Services PMC. Incubation is required of all newly accepted
|
||||
projects until a further review indicates that the infrastructure, communications,
|
||||
and decision making process have stabilized in a manner consistent with other successful
|
||||
ASF projects. While incubation status is not necessarily a reflection of the completeness
|
||||
or stability of the code, it does indicate that the project has yet to be fully endorsed
|
||||
by the ASF.
|
||||
|
||||
Unless otherwise indicated, all distribution made available by the Apache Software Foundation
|
||||
is provided to you under the terms and conditions of the Apache License Version 2.0 ("AL").
|
||||
A copy of the AL is provided with this distribution as the LICENSE.txt file present in the
|
||||
root directory, and is also available at http://www.apache.org/licenses/.
|
||||
|
||||
The terms and conditions governing the distribution may refer to the AL or other license
|
||||
agreements, notices or terms and conditions. Some of these other license agreements may
|
||||
include (but are not limited to):
|
||||
|
||||
. Eclipse Public License Version 1.0 (available at http://www.eclipse.org/legal/epl-v10.html)
|
||||
|
||||
It is your obligation to read and accept all such terms and conditions prior to use of the
|
||||
distribution. If term or condition is provided, please contact the Apache Software Foundation
|
||||
to determine what terms and conditions govern that particular distribution.
|
||||
|
||||
This product also includes software developed by the Open Service Oriented Architecture organisation
|
||||
(http://osoa.org). The license for this software may be found in the LICENSE.txt file contained in this
|
||||
distribution.
|
|
@ -1,35 +0,0 @@
|
|||
Apache Tuscany DAS beta1 build (June, 2006)
|
||||
=================+++++++========+==========
|
||||
|
||||
http://incubator.apache.org/tuscany/
|
||||
|
||||
Tuscany is an effort undergoing incubation at the Apache Software Foundation
|
||||
(ASF), sponsored by the Web Services PMC.
|
||||
|
||||
Incubation is required of all newly accepted projects until a further review
|
||||
indicates that the infrastructure, communications, and decision making process
|
||||
have stabilized in a manner consistent with other successful ASF projects.
|
||||
|
||||
While incubation status is not necessarily a reflection of the completeness or
|
||||
stability of the code, it does indicate that the project has yet to be fully
|
||||
endorsed by the ASF.
|
||||
|
||||
|
||||
Support
|
||||
-------
|
||||
|
||||
Any problem with this release can be reported to the Tuscany mailing list
|
||||
or in the JIRA issue tracker.
|
||||
|
||||
Mailing list subscription:
|
||||
tuscany-dev-subscribe@ws.apache.org
|
||||
|
||||
Jira:
|
||||
http://issues.apache.org/jira/browse/Tuscany
|
||||
|
||||
|
||||
Thank you for using Tuscany!
|
||||
|
||||
|
||||
The Tuscany Team.
|
||||
|
|
@ -1,152 +0,0 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!--
|
||||
Licensed to the Apache Software Foundation (ASF) under one
|
||||
or more contributor license agreements. See the NOTICE file
|
||||
distributed with this work for additional information
|
||||
regarding copyright ownership. The ASF licenses this file
|
||||
to you 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 limitations
|
||||
under the License.
|
||||
-->
|
||||
<xsd:schema
|
||||
xmlns:config="http:///org.apache.tuscany.das.rdb/config.xsd"
|
||||
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
|
||||
targetNamespace="http:///org.apache.tuscany.das.rdb/config.xsd"
|
||||
elementFormDefault="qualified">
|
||||
|
||||
<xsd:element name="Config" type="config:Config"/>
|
||||
|
||||
<xsd:complexType name="Config">
|
||||
<xsd:sequence>
|
||||
<xsd:element maxOccurs="unbounded" minOccurs="0" name="Command"
|
||||
type="config:Command"/>
|
||||
<xsd:element maxOccurs="unbounded" minOccurs="0" name="Table" type="config:Table"/>
|
||||
<xsd:element maxOccurs="unbounded" minOccurs="0" name="Relationship"
|
||||
type="config:Relationship"/>
|
||||
<xsd:element maxOccurs="1" minOccurs="0" name="ConnectionInfo"
|
||||
type="config:ConnectionInfo"/>
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="uri" type="xsd:string"/>
|
||||
<xsd:attribute name="dataObjectModel" type="xsd:string"/>
|
||||
<xsd:attribute name="databaseSchemaNameSupported" type="xsd:boolean" default="false"/>
|
||||
<xsd:attribute name="generatedKeysSupported">
|
||||
<xsd:simpleType>
|
||||
<xsd:restriction base="xsd:string">
|
||||
<xsd:enumeration value="true"/>
|
||||
<xsd:enumeration value="false"/>
|
||||
</xsd:restriction>
|
||||
</xsd:simpleType>
|
||||
</xsd:attribute>
|
||||
</xsd:complexType>
|
||||
|
||||
<xsd:complexType name="ConnectionProperties">
|
||||
<xsd:attribute name="driverClass" type="xsd:string"/>
|
||||
<xsd:attribute name="databaseURL" type="xsd:string"/>
|
||||
<xsd:attribute name="userName" type="xsd:string" default=""/>
|
||||
<xsd:attribute name="password" type="xsd:string" default=""/>
|
||||
<xsd:attribute name="loginTimeout" type="xsd:int" default="0"/>
|
||||
</xsd:complexType>
|
||||
|
||||
<xsd:complexType name="ConnectionInfo">
|
||||
<xsd:sequence>
|
||||
<xsd:element maxOccurs="1" minOccurs="0" name="ConnectionProperties" type="config:ConnectionProperties"/>
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="dataSource" type="xsd:string"/>
|
||||
<xsd:attribute name="managedtx" type="xsd:boolean" default="true"/>
|
||||
</xsd:complexType>
|
||||
|
||||
|
||||
<xsd:complexType name="Command">
|
||||
<xsd:sequence>
|
||||
<xsd:element maxOccurs="unbounded" minOccurs="0" name="Parameter"
|
||||
type="config:Parameter"/>
|
||||
<xsd:element maxOccurs="unbounded" minOccurs="0" name="ResultDescriptor"
|
||||
type="config:ResultDescriptor"/>
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string"/>
|
||||
<xsd:attribute name="SQL" type="xsd:string"/>
|
||||
<xsd:attribute name="kind" type="xsd:string"/>
|
||||
</xsd:complexType>
|
||||
<xsd:complexType name="Parameter">
|
||||
<xsd:attribute name="name" type="xsd:string"/>
|
||||
<xsd:attribute name="columnType" type="xsd:string"/>
|
||||
<xsd:attribute name="direction" type="xsd:string" default="IN"/>
|
||||
<xsd:attribute name="index" type="xsd:int"/>
|
||||
</xsd:complexType>
|
||||
<xsd:complexType name="Parameters">
|
||||
<xsd:sequence>
|
||||
<xsd:element maxOccurs="unbounded" minOccurs="0" name="Parameter" type="config:Parameter"/>
|
||||
</xsd:sequence>
|
||||
</xsd:complexType>
|
||||
<xsd:complexType name="Relationship">
|
||||
<xsd:sequence>
|
||||
<xsd:element maxOccurs="unbounded" minOccurs="0" name="KeyPair"
|
||||
type="config:KeyPair"/>
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="name" type="xsd:string"/>
|
||||
<xsd:attribute name="primaryKeyTable" type="xsd:string"/>
|
||||
<xsd:attribute name="foreignKeyTable" type="xsd:string"/>
|
||||
<xsd:attribute name="many" type="xsd:boolean"/>
|
||||
<xsd:attribute name="keyRestricted" type="xsd:boolean"/>
|
||||
</xsd:complexType>
|
||||
<xsd:complexType name="Table">
|
||||
<xsd:sequence>
|
||||
<xsd:element maxOccurs="unbounded" minOccurs="0" name="Column"
|
||||
type="config:Column"/>
|
||||
<xsd:element maxOccurs="1" minOccurs="0" name="create" type="config:Create"/>
|
||||
<xsd:element maxOccurs="1" minOccurs="0" name="update" type="config:Update"/>
|
||||
<xsd:element maxOccurs="1" minOccurs="0" name="delete" type="config:Delete"/>
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="tableName" type="xsd:string"/>
|
||||
<xsd:attribute name="typeName" type="xsd:string"/>
|
||||
<xsd:attribute name="schemaName" type="xsd:string" default=""/>
|
||||
</xsd:complexType>
|
||||
<xsd:complexType name="Create">
|
||||
<xsd:sequence>
|
||||
<xsd:element maxOccurs="1" minOccurs="0" name="Parameters" type="config:Parameters"/>
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="sql" type="xsd:string"/>
|
||||
</xsd:complexType>
|
||||
<xsd:complexType name="Update">
|
||||
<xsd:sequence>
|
||||
<xsd:element maxOccurs="1" minOccurs="0" name="Parameters" type="config:Parameters"/>
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="sql" type="xsd:string"/>
|
||||
</xsd:complexType>
|
||||
<xsd:complexType name="Delete">
|
||||
<xsd:sequence>
|
||||
<xsd:element maxOccurs="1" minOccurs="0" name="Parameters" type="config:Parameters"/>
|
||||
</xsd:sequence>
|
||||
<xsd:attribute name="sql" type="xsd:string"/>
|
||||
</xsd:complexType>
|
||||
<xsd:complexType name="KeyPair">
|
||||
<xsd:attribute name="primaryKeyColumn" type="xsd:string"/>
|
||||
<xsd:attribute name="foreignKeyColumn" type="xsd:string"/>
|
||||
</xsd:complexType>
|
||||
<xsd:complexType name="Column">
|
||||
<xsd:attribute name="columnName" type="xsd:string"/>
|
||||
<xsd:attribute name="propertyName" type="xsd:string"/>
|
||||
<xsd:attribute name="converterClassName" type="xsd:string"/>
|
||||
<xsd:attribute name="primaryKey" type="xsd:boolean"/>
|
||||
<xsd:attribute name="generated" type="xsd:boolean"/>
|
||||
<xsd:attribute name="collision" type="xsd:boolean"/>
|
||||
<xsd:attribute name="managed" type="xsd:boolean" default="true"/>
|
||||
</xsd:complexType>
|
||||
<xsd:complexType name="ResultDescriptor">
|
||||
<xsd:attribute name="columnIndex" type="xsd:int" default="-1"/>
|
||||
<xsd:attribute name="columnName" type="xsd:string"/>
|
||||
<xsd:attribute name="tableName" type="xsd:string"/>
|
||||
<xsd:attribute name="schemaName" type="xsd:string"/>
|
||||
<xsd:attribute name="columnType" type="xsd:string"/>
|
||||
</xsd:complexType>
|
||||
|
||||
</xsd:schema>
|
File diff suppressed because it is too large
Load diff
|
@ -1,164 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.test;
|
||||
|
||||
import java.util.Iterator;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.test.data.BookData;
|
||||
import org.apache.tuscany.das.rdb.test.data.CustomerData;
|
||||
import org.apache.tuscany.das.rdb.test.framework.DasTest;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class AliasTests extends DasTest {
|
||||
|
||||
protected void setUp() throws Exception {
|
||||
|
||||
super.setUp();
|
||||
new BookData(getAutoConnection()).refresh();
|
||||
new CustomerData(getAutoConnection()).refresh();
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests the use of column aliasing. The property name change is found in the
|
||||
* BooksConfig.xml file Otherwise similar to testTableAlias
|
||||
*
|
||||
* @throws Exception
|
||||
*/
|
||||
public void testColumnAlias() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("BooksConfigWithAlias.xml"), getConnection());
|
||||
|
||||
Command select = das.getCommand("get all books");
|
||||
// select.setConnection( getConnection() );
|
||||
|
||||
DataObject root = select.executeQuery();
|
||||
|
||||
DataObject book = root.getDataObject("Book[2]");
|
||||
book.set("Writer", "Dr. Seuss");
|
||||
|
||||
das.applyChanges(root);
|
||||
|
||||
select = das.getCommand("get Cat in the Hat");
|
||||
|
||||
root = select.executeQuery();
|
||||
// Ensure the change actually updated
|
||||
assertEquals("Dr. Seuss", root.getString("Book[1]/Writer"));
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests to ensure that columns are being properly read when using an Alias,
|
||||
* just a bunch of simple creating, renaming, and deleting of entries
|
||||
* while using an alias.
|
||||
*/
|
||||
public void testColumnData() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("BooksConfigWithAlias.xml"), getConnection());
|
||||
|
||||
Command select = das.getCommand("get book by ID");
|
||||
select.setParameter(1, new Integer(1));
|
||||
|
||||
// *******Verifys a column entry is readable
|
||||
DataObject root = select.executeQuery();
|
||||
assertEquals("Fyodor Dostoevsky", root.getString("Book[1]/Writer"));
|
||||
|
||||
DataObject bookToChange = root.getDataObject("Book[1]");
|
||||
bookToChange.set("Writer", "Fyodor Dostoevskii"); // His last name COULD be spelt like that too!
|
||||
|
||||
das.applyChanges(root);
|
||||
|
||||
// *******Verifys correct information in entry after a column data is changed
|
||||
select = das.getCommand("get all books");
|
||||
// select.setConnection(getConnection());
|
||||
|
||||
root = select.executeQuery();
|
||||
bookToChange = null;
|
||||
Iterator i = root.getList("Book").iterator();
|
||||
while (i.hasNext()) {
|
||||
DataObject d = (DataObject) i.next();
|
||||
if ("Fyodor Dostoevskii".equals(d.getString("Writer"))) {
|
||||
bookToChange = d;
|
||||
}
|
||||
}
|
||||
assertFalse(bookToChange == null);
|
||||
|
||||
bookToChange.delete();
|
||||
|
||||
das.applyChanges(root);
|
||||
|
||||
// *******Verifys correct in table, after entry is deleted
|
||||
select = das.getCommand("get all books");
|
||||
// select.setConnection(getConnection());
|
||||
|
||||
root = select.executeQuery();
|
||||
assertEquals(1, root.getList("Book").size());
|
||||
assertEquals("Doctor Seuss", root.getString("Book[1]/Writer"));
|
||||
}
|
||||
|
||||
/**
|
||||
* Test to check if updating a table works when using Aliasing Previously this was test_4 in ExceptionTests.
|
||||
*/
|
||||
public void testTableAlias() throws Exception {
|
||||
|
||||
// Create Table config programmatically
|
||||
// ConfigHelper helper = new ConfigHelper();
|
||||
// helper.addTable("BOOK", "Book");
|
||||
// helper.addPrimaryKey("BOOK.BOOK_ID");
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("BooksConfigWithAlias.xml"), getConnection());
|
||||
Command select = das.getCommand("get book by ID");
|
||||
select.setParameter(1, new Integer(1));
|
||||
|
||||
DataObject root = select.executeQuery();
|
||||
|
||||
DataObject newBook = root.createDataObject("Book");
|
||||
newBook.setString("NAME", "Ant Colonies of the Old World");
|
||||
newBook.setInt("BOOK_ID", 1001);
|
||||
root.getList("Book").add(newBook);
|
||||
|
||||
das.applyChanges(root);
|
||||
|
||||
root = select.executeQuery();
|
||||
|
||||
// Verify
|
||||
select.setParameter(1, new Integer(1001));
|
||||
root = select.executeQuery();
|
||||
|
||||
assertEquals("Ant Colonies of the Old World", root.getString("Book[1]/NAME"));
|
||||
}
|
||||
|
||||
/**
|
||||
* Test ability to assign DataObject type and propertyaliases with xml file
|
||||
*/
|
||||
public void testRead() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("customerMapping.xml"), getConnection());
|
||||
// Read a customer
|
||||
Command select = das.createCommand("SELECT * FROM CUSTOMER WHERE CUSTOMER.ID = 1");
|
||||
|
||||
DataObject root = select.executeQuery();
|
||||
DataObject customer = root.getDataObject("Customer[1]");
|
||||
assertEquals(1, customer.getInt("id"));
|
||||
assertEquals("1212 foobar lane", customer.getString("address"));
|
||||
assertEquals("Williams", customer.getString("lastname"));
|
||||
|
||||
}
|
||||
}
|
|
@ -1,153 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.test;
|
||||
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.test.data.CompanyData;
|
||||
import org.apache.tuscany.das.rdb.test.data.CompanyDeptData;
|
||||
import org.apache.tuscany.das.rdb.test.data.DepEmpData;
|
||||
import org.apache.tuscany.das.rdb.test.data.DepartmentData;
|
||||
import org.apache.tuscany.das.rdb.test.data.EmployeeData;
|
||||
import org.apache.tuscany.das.rdb.test.framework.DasTest;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class BestPracticeTests extends DasTest {
|
||||
|
||||
protected void setUp() throws Exception {
|
||||
super.setUp();
|
||||
|
||||
new CompanyData(getAutoConnection()).refresh();
|
||||
new DepartmentData(getAutoConnection()).refresh();
|
||||
new EmployeeData(getAutoConnection()).refresh();
|
||||
new CompanyDeptData(getAutoConnection()).refresh();
|
||||
new DepEmpData(getAutoConnection()).refresh();
|
||||
|
||||
}
|
||||
|
||||
//Read list of companies
|
||||
public void testReadCompanies() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CompanyConfig.xml"), getConnection());
|
||||
Command read = das.getCommand("all companies");
|
||||
DataObject root = read.executeQuery();
|
||||
assertEquals(3, root.getList("COMPANY").size());
|
||||
|
||||
}
|
||||
|
||||
//Read list of companies
|
||||
public void testReadCompaniesWithDepartments() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CompanyConfig.xml"), getConnection());
|
||||
Command read = das.getCommand("all companies and departments");
|
||||
DataObject root = read.executeQuery();
|
||||
|
||||
Iterator i = root.getList("COMPANY").iterator();
|
||||
while (i.hasNext()) {
|
||||
DataObject d = (DataObject) i.next();
|
||||
List departments = d.getList("departments");
|
||||
if (d.getString("NAME").equals("Do-rite plumbing") || d.getString("NAME").equals("ACME Publishing")) {
|
||||
assertEquals(0, departments.size());
|
||||
} else {
|
||||
assertEquals(1, departments.size());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public void testddDepartmentToFirstCompany() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CompanyConfig.xml"), getConnection());
|
||||
Command read = das.getCommand("all companies and departments");
|
||||
DataObject root = read.executeQuery();
|
||||
DataObject firstCustomer = root.getDataObject("COMPANY[1]");
|
||||
int deptCount = firstCustomer.getList("departments").size();
|
||||
|
||||
DataObject newDepartment = root.createDataObject("DEPARTMENT");
|
||||
firstCustomer.getList("departments").add(newDepartment);
|
||||
|
||||
das.applyChanges(root);
|
||||
|
||||
//verify
|
||||
root = read.executeQuery();
|
||||
firstCustomer = root.getDataObject("COMPANY[1]");
|
||||
assertEquals(deptCount + 1, firstCustomer.getList("departments").size());
|
||||
}
|
||||
|
||||
/**
|
||||
* Test ability to correctly flush heirarchy of objects that have generated
|
||||
* keys
|
||||
*/
|
||||
public void testFlushCreateHeirarchy() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CompanyConfig.xml"), getConnection());
|
||||
Command select = das.getCommand("all companies and departments");
|
||||
DataObject root = select.executeQuery();
|
||||
|
||||
// Create a new Company
|
||||
DataObject company = root.createDataObject("COMPANY");
|
||||
company.setString("NAME", "Do-rite Pest Control");
|
||||
|
||||
// Create a new Department
|
||||
//Do not set ID or CompanyID since these are generated
|
||||
DataObject department = root.createDataObject("DEPARTMENT");
|
||||
department.setString("NAME", "Do-rite Pest Control");
|
||||
department.setString("LOCATION", "The boonies");
|
||||
department.setString("DEPNUMBER", "101");
|
||||
|
||||
// Associate the new department with the new company
|
||||
company.getList("departments").add(department);
|
||||
|
||||
// Get apply command
|
||||
das.applyChanges(root);
|
||||
|
||||
// Save the id
|
||||
Integer id = (Integer) company.get("ID");
|
||||
|
||||
// Verify the change
|
||||
|
||||
select = das.getCommand("company by id with departments");
|
||||
select.setParameter(1, id);
|
||||
root = select.executeQuery();
|
||||
assertEquals("Do-rite Pest Control", root.getDataObject("COMPANY[1]").getString("NAME"));
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Test ability to get an empty graph with the Types/Properties intact
|
||||
*/
|
||||
public void testGetEmptyGraph() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CompanyConfig.xml"), getConnection());
|
||||
|
||||
Command select = das.getCommand("company by id with departments");
|
||||
Integer idOfNoExistingCompany = new Integer(-1);
|
||||
select.setParameter(1, idOfNoExistingCompany);
|
||||
DataObject root = select.executeQuery();
|
||||
|
||||
//Will fail if there is no property named "COMPANY"
|
||||
assertEquals(0, root.getList("COMPANY").size());
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -1,111 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.test;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.test.data.CustomerData;
|
||||
import org.apache.tuscany.das.rdb.test.data.OrderData;
|
||||
import org.apache.tuscany.das.rdb.test.framework.DasTest;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class CUDGeneration extends DasTest {
|
||||
|
||||
protected void setUp() throws Exception {
|
||||
super.setUp();
|
||||
|
||||
new CustomerData(getAutoConnection()).refresh();
|
||||
new OrderData(getAutoConnection()).refresh();
|
||||
}
|
||||
|
||||
/**
|
||||
* This tests provides invalid SQL and should fail on Apply.execute. If not
|
||||
* then the engine is generating CUD and overlooking the provided
|
||||
* statements.
|
||||
*/
|
||||
public void testCUDGeneration1() throws Exception {
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("basicCustomerMappingWithInvalidCUD.xml"), getConnection());
|
||||
|
||||
// Read customer with particular ID
|
||||
Command select = das.createCommand("Select * from CUSTOMER where ID = 1");
|
||||
DataObject root = select.executeQuery();
|
||||
|
||||
DataObject customer = (DataObject) root.get("CUSTOMER[1]");
|
||||
|
||||
// Modify customer
|
||||
customer.set("LASTNAME", "Pavick");
|
||||
|
||||
// Flush changes
|
||||
try {
|
||||
das.applyChanges(root);
|
||||
fail("Should fail with invalid SQL. Provided CUD not used!!");
|
||||
} catch (RuntimeException e) {
|
||||
// Everything OK
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public void testInsertCUDGeneration() throws Exception {
|
||||
DAS das = DAS.FACTORY.createDAS(getConnection());
|
||||
|
||||
Command select = das.createCommand("Select * from CUSTOMER where ID = 1");
|
||||
DataObject root = select.executeQuery();
|
||||
|
||||
DataObject customer = root.createDataObject("CUSTOMER");
|
||||
customer.setInt("ID", 720);
|
||||
customer.set("LASTNAME", "foobar");
|
||||
customer.set("ADDRESS", "asdfasdf");
|
||||
|
||||
das.applyChanges(root);
|
||||
|
||||
select = das.createCommand("select * from CUSTOMER where ID = 720");
|
||||
root = select.executeQuery();
|
||||
|
||||
assertEquals(1, root.getList("CUSTOMER").size());
|
||||
}
|
||||
|
||||
public void testReadModifyApply() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("1xM_mapping_no_cud.xml"), getConnection());
|
||||
|
||||
// Build the select command to read a specific customer and related
|
||||
// orders
|
||||
Command select = das.createCommand("SELECT * FROM CUSTOMER LEFT JOIN ANORDER ON "
|
||||
+ "CUSTOMER.ID = ANORDER.CUSTOMER_ID where CUSTOMER.ID = ?");
|
||||
|
||||
// Parameterize the command
|
||||
select.setParameter(1, new Integer(1));
|
||||
|
||||
// Get the graph
|
||||
DataObject root = select.executeQuery();
|
||||
|
||||
// Modify a customer
|
||||
DataObject customer = (DataObject) root.get("Customer[1]");
|
||||
customer.set("LASTNAME", "Pavick");
|
||||
|
||||
// Modify an order
|
||||
DataObject order = (DataObject) customer.get("orders[1]");
|
||||
order.setString("PRODUCT", "Kitchen Sink 001");
|
||||
|
||||
das.applyChanges(root);
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -1,167 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.test;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.ConfigHelper;
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.test.data.CompanyData;
|
||||
import org.apache.tuscany.das.rdb.test.data.CustomerData;
|
||||
import org.apache.tuscany.das.rdb.test.framework.DasTest;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class CheckSupportGeneratedKeys extends DasTest {
|
||||
protected void setUp() throws Exception {
|
||||
super.setUp();
|
||||
|
||||
new CustomerData(getAutoConnection()).refresh();//no generated keys used
|
||||
new CompanyData(getAutoConnection()).refresh();//generated keys used
|
||||
}
|
||||
|
||||
protected void tearDown() throws Exception {
|
||||
super.tearDown();
|
||||
}
|
||||
|
||||
//<Config> useGetGeneratedKeys set to TRUE - Company
|
||||
public void testInsert() throws Exception {
|
||||
ConfigHelper helper = new ConfigHelper();
|
||||
Config config = helper.getConfig();
|
||||
config.setGeneratedKeysSupported("true");
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(config, getConnection());
|
||||
Command insert = das.createCommand("insert into COMPANY (NAME) values (?)");
|
||||
insert.setParameter(1, "AAA Rental");
|
||||
insert.execute();
|
||||
Integer key = new Integer(insert.getGeneratedKey());
|
||||
// Verify insert
|
||||
Command select = das.createCommand("Select ID, NAME from COMPANY where ID = ?");
|
||||
select.setParameter(1, key);
|
||||
DataObject root = select.executeQuery();
|
||||
assertEquals(key, root.get("COMPANY[1]/ID"));
|
||||
}
|
||||
|
||||
//<Config> useGetGeneratedKeys not set - Company (should work as default TRUE)
|
||||
public void testInsert1() throws Exception {
|
||||
ConfigHelper helper = new ConfigHelper();
|
||||
Config config = helper.getConfig();
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(config, getConnection());
|
||||
Command insert = das.createCommand("insert into COMPANY (NAME) values (?)");
|
||||
insert.setParameter(1, "AAA Rental");
|
||||
insert.execute();
|
||||
Integer key = new Integer(insert.getGeneratedKey());
|
||||
// Verify insert
|
||||
Command select = das.createCommand("Select ID, NAME from COMPANY where ID = ?");
|
||||
select.setParameter(1, key);
|
||||
DataObject root = select.executeQuery();
|
||||
assertEquals(key, root.get("COMPANY[1]/ID"));
|
||||
}
|
||||
|
||||
//<Config> useGetGeneratedKeys set to FALSE - Company -
|
||||
// exception as insert.getGen..Keys will throw RuntimeException
|
||||
public void testInsert2() throws Exception {
|
||||
ConfigHelper helper = new ConfigHelper();
|
||||
Config config = helper.getConfig();
|
||||
config.setGeneratedKeysSupported("false");
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(config, getConnection());
|
||||
Command insert = das.createCommand("insert into COMPANY (NAME) values (?)");
|
||||
insert.setParameter(1, "AAA Rental");
|
||||
insert.execute();//this will happen as table is created with proper clause
|
||||
|
||||
try{
|
||||
Integer key = new Integer(insert.getGeneratedKey());
|
||||
fail("Should not be able to retrieve key "+key);//unexpected
|
||||
}catch(RuntimeException e){
|
||||
//e.printStackTrace();
|
||||
assertTrue(true);//expected
|
||||
}
|
||||
}
|
||||
|
||||
//<Config> useGetGeneratedKeys set to TRUE - Customer - flag should be ignored during insert
|
||||
public void testInsert3() throws Exception {
|
||||
ConfigHelper helper = new ConfigHelper();
|
||||
Config config = helper.getConfig();
|
||||
config.setGeneratedKeysSupported("true");
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(config, getConnection());
|
||||
Command insert = das.createCommand("insert into CUSTOMER (ID, LASTNAME, ADDRESS) values (?, ?, ?)");
|
||||
String key = "10";
|
||||
insert.setParameter(1, key);
|
||||
insert.setParameter(2, "CUST10");
|
||||
insert.setParameter(3, "ADDR10");
|
||||
insert.execute();
|
||||
|
||||
// Verify insert
|
||||
Command select = das.createCommand("Select ID, LASTNAME from CUSTOMER where ID = ?");
|
||||
select.setParameter(1, key);
|
||||
DataObject root = select.executeQuery();
|
||||
assertEquals(key, root.get("CUSTOMER[1]/ID").toString());
|
||||
}
|
||||
|
||||
//<Config> useGetGeneratedKeys set to FALSE - Customer, flag has no effect
|
||||
public void testInsert4() throws Exception {
|
||||
ConfigHelper helper = new ConfigHelper();
|
||||
Config config = helper.getConfig();
|
||||
config.setGeneratedKeysSupported("false");
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(config, getConnection());
|
||||
Command insert = das.createCommand("insert into CUSTOMER (ID, LASTNAME, ADDRESS) values (?, ?, ?)");
|
||||
String key = "10";
|
||||
insert.setParameter(1, key);
|
||||
insert.setParameter(2, "CUST10");
|
||||
insert.setParameter(3, "ADDR10");
|
||||
insert.execute();
|
||||
try{
|
||||
Integer retkey = new Integer(insert.getGeneratedKey());
|
||||
fail("Should not be able to retrieve key "+retkey);
|
||||
}catch(RuntimeException e){
|
||||
//e.printStackTrace();
|
||||
assertTrue(true);//expected
|
||||
}
|
||||
|
||||
// Verify insert
|
||||
Command select = das.createCommand("Select ID, LASTNAME from CUSTOMER where ID = ?");
|
||||
select.setParameter(1, key);
|
||||
DataObject root = select.executeQuery();
|
||||
assertEquals(key, root.get("CUSTOMER[1]/ID").toString());
|
||||
}
|
||||
|
||||
//<Config> useGetGeneratedKeys not set - Customer - default TRUE is ignored
|
||||
public void testInsert5() throws Exception {
|
||||
ConfigHelper helper = new ConfigHelper();
|
||||
Config config = helper.getConfig();
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(config, getConnection());
|
||||
Command insert = das.createCommand("insert into CUSTOMER (ID, LASTNAME, ADDRESS) values (?, ?, ?)");
|
||||
String key = "10";
|
||||
insert.setParameter(1, key);
|
||||
insert.setParameter(2, "CUST10");
|
||||
insert.setParameter(3, "ADDR10");
|
||||
insert.execute();
|
||||
|
||||
// Verify insert
|
||||
Command select = das.createCommand("Select ID, LASTNAME from CUSTOMER where ID = ?");
|
||||
select.setParameter(1, key);
|
||||
DataObject root = select.executeQuery();
|
||||
assertEquals(key, root.get("CUSTOMER[1]/ID").toString());
|
||||
}
|
||||
}
|
|
@ -1,161 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.test;
|
||||
|
||||
/*
|
||||
* This test
|
||||
*
|
||||
*/
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.config.Config;
|
||||
import org.apache.tuscany.das.rdb.test.data.CustomerData;
|
||||
import org.apache.tuscany.das.rdb.test.data.OrderData;
|
||||
import org.apache.tuscany.das.rdb.test.framework.DasTest;
|
||||
import org.apache.tuscany.das.rdb.util.ConfigUtil;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
/**
|
||||
*
|
||||
* This tests use of the XML Config file. Tests will utilize the
|
||||
* customer-orders-orderdetails tables. The plan is for the config file to have a
|
||||
* section that applies to all commands and another that applies to specific commands.
|
||||
*
|
||||
* The config file will be used to initialize a command factory that will then return named commands.
|
||||
*
|
||||
* There will be two read commands:
|
||||
*
|
||||
* 1) Return all customers 2) Return a specific customer (by ID) and related orders and order details
|
||||
*
|
||||
* A test will demonstrate the creation of the factory and then reuse of commands created from the same config data file
|
||||
*
|
||||
*/
|
||||
public class CommandGroupTests extends DasTest {
|
||||
|
||||
protected void setUp() throws Exception {
|
||||
super.setUp();
|
||||
|
||||
new CustomerData(getAutoConnection()).refresh();
|
||||
new OrderData(getAutoConnection()).refresh();
|
||||
}
|
||||
|
||||
protected void tearDown() throws Exception {
|
||||
super.tearDown();
|
||||
}
|
||||
|
||||
/**
|
||||
* Read
|
||||
*/
|
||||
public void testRead() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CustomersOrdersConfig.xml"), getConnection());
|
||||
|
||||
Command read = das.getCommand("all customers");
|
||||
DataObject root = read.executeQuery();
|
||||
|
||||
assertEquals(5, root.getList("CUSTOMER").size());
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Read
|
||||
*/
|
||||
public void testReadUsingConfigInput() throws Exception {
|
||||
Config config = ConfigUtil.loadConfig(getConfig("CustomersOrdersConfig.xml"));
|
||||
DAS das = DAS.FACTORY.createDAS(config, getConnection());
|
||||
|
||||
Command read = das.getCommand("all customers");
|
||||
DataObject root = read.executeQuery();
|
||||
|
||||
assertEquals(5, root.getList("CUSTOMER").size());
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Read an order using parm marker
|
||||
*/
|
||||
public void testReadWithParmmarker() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CustomersOrdersConfig.xml"), getConnection());
|
||||
|
||||
Command read = das.getCommand("order by id");
|
||||
read.setParameter(1, new Integer(1));
|
||||
DataObject root = read.executeQuery();
|
||||
|
||||
assertEquals("recombobulator", root.getString("ANORDER[1]/PRODUCT"));
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Specify connection properties in config. Add explicit update command
|
||||
*/
|
||||
public void testUpdate() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CustomersOrdersConfig.xml"), getConnection());
|
||||
|
||||
Command read = das.getCommand("all customers");
|
||||
DataObject root = read.executeQuery();
|
||||
// Verify precondition
|
||||
assertFalse(root.get("CUSTOMER[1]/LASTNAME").equals("Pavick"));
|
||||
int id = root.getInt("CUSTOMER[1]/ID");
|
||||
|
||||
Command update = das.getCommand("update customer");
|
||||
update.setParameter(1, new Integer(id));
|
||||
update.execute();
|
||||
|
||||
// Verify update - reuse select command
|
||||
root = read.executeQuery();
|
||||
assertEquals("Pavick", root.get("CUSTOMER[1]/LASTNAME"));
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Read all customers, select a specific customer. Then read that
|
||||
* customer and related orders. Modify an order and flush changes back
|
||||
*/
|
||||
public void testRead2() throws Exception {
|
||||
|
||||
// Create the group and set common connection
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CustomersOrdersConfig.xml"), getConnection());
|
||||
|
||||
// Read all customers and remember the first one
|
||||
Command read = das.getCommand("all customers");
|
||||
DataObject root = read.executeQuery();
|
||||
Integer id = (Integer) root.get("CUSTOMER[1]/ID");
|
||||
|
||||
// Read the specific Customer from above and its related orders
|
||||
Command custOrders = das.getCommand("customer and orders");
|
||||
custOrders.setParameter(1, id);
|
||||
root = custOrders.executeQuery();
|
||||
|
||||
// Modify the first order and flush this change back to the database
|
||||
root.setString("CUSTOMER[1]/orders[1]/PRODUCT", "Defibrillator");
|
||||
Integer orderId = (Integer) root.get("CUSTOMER[1]/orders[1]/ID");
|
||||
das.applyChanges(root);
|
||||
|
||||
// Verify
|
||||
Command orderByID = das.getCommand("order by id");
|
||||
orderByID.setParameter(1, orderId);
|
||||
assertEquals("Defibrillator", root.getString("ANORDER[1]/PRODUCT"));
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -1,103 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.test;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.test.company.CompanyFactory;
|
||||
import org.apache.tuscany.das.rdb.test.company.CompanyType;
|
||||
import org.apache.tuscany.das.rdb.test.company.DepartmentType;
|
||||
import org.apache.tuscany.das.rdb.test.company.EmployeeType;
|
||||
import org.apache.tuscany.das.rdb.test.data.CompanyData;
|
||||
import org.apache.tuscany.das.rdb.test.data.CompanyDeptData;
|
||||
import org.apache.tuscany.das.rdb.test.data.DepEmpData;
|
||||
import org.apache.tuscany.das.rdb.test.data.DepartmentData;
|
||||
import org.apache.tuscany.das.rdb.test.data.EmployeeData;
|
||||
import org.apache.tuscany.das.rdb.test.framework.DasTest;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.helper.HelperContext;
|
||||
import commonj.sdo.impl.HelperProvider;
|
||||
|
||||
public class CompanyTests extends DasTest {
|
||||
|
||||
protected void setUp() throws Exception {
|
||||
super.setUp();
|
||||
|
||||
new CompanyData(getAutoConnection()).refresh();
|
||||
new DepartmentData(getAutoConnection()).refresh();
|
||||
new EmployeeData(getAutoConnection()).refresh();
|
||||
new CompanyDeptData(getAutoConnection()).refresh();
|
||||
new DepEmpData(getAutoConnection()).refresh();
|
||||
|
||||
}
|
||||
|
||||
public void testSimple() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("companyMapping.xml"), getConnection());
|
||||
|
||||
// Build the select command
|
||||
Command selectCommand = das.createCommand("select COMPANY.ID, COMPANY.NAME, "
|
||||
+ "EMPLOYEE.ID, EMPLOYEE.NAME, EMPLOYEE.SN, EMPLOYEE.MANAGER, "
|
||||
+ "DEPARTMENT.ID, DEPARTMENT.NAME, DEPARTMENT.LOCATION, DEPARTMENT.DEPNUMBER from COMPANY, DEPARTMENT, EMPLOYEE "
|
||||
+ "where COMPANY.ID=DEPARTMENT.COMPANYID and DEPARTMENT.ID=EMPLOYEE.DEPARTMENTID");
|
||||
|
||||
// Get the graph
|
||||
DataObject root = selectCommand.executeQuery();
|
||||
|
||||
// Get a company
|
||||
DataObject company = (DataObject) root.getList("CompanyType").get(0);
|
||||
assertEquals("MegaCorp", company.get("NAME"));
|
||||
|
||||
// Get a department
|
||||
DataObject department = (DataObject) company.getList("departments").get(0);
|
||||
assertEquals("Advanced Technologies", department.get("NAME"));
|
||||
|
||||
DataObject employee = (DataObject) department.getList("employees").get(0);
|
||||
assertEquals("John Jones", employee.get("NAME"));
|
||||
}
|
||||
|
||||
public void testSimpleStatic() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("companyMappingWithConverters.xml"), getConnection());
|
||||
HelperContext context = HelperProvider.getDefaultContext();
|
||||
CompanyFactory.INSTANCE.register(context);
|
||||
// Build the select command
|
||||
Command selectCommand = das.createCommand("select COMPANY.ID, COMPANY.NAME, "
|
||||
+ "EMPLOYEE.ID, EMPLOYEE.NAME, EMPLOYEE.SN, EMPLOYEE.MANAGER, "
|
||||
+ "DEPARTMENT.ID, DEPARTMENT.NAME, DEPARTMENT.LOCATION, DEPARTMENT.DEPNUMBER from COMPANY, DEPARTMENT, EMPLOYEE "
|
||||
+ "where COMPANY.ID=DEPARTMENT.COMPANYID and DEPARTMENT.ID=EMPLOYEE.DEPARTMENTID");
|
||||
|
||||
// Get the graph
|
||||
DataObject root = selectCommand.executeQuery();
|
||||
|
||||
CompanyType company = (CompanyType) root.getList("CompanyType").get(0);
|
||||
|
||||
assertEquals("MegaCorp", company.getName());
|
||||
|
||||
// Get a department
|
||||
DepartmentType department = (DepartmentType) company.getDepartments().get(0);
|
||||
assertEquals("Advanced Technologies", department.getName());
|
||||
|
||||
EmployeeType employee = (EmployeeType) department.getEmployees().get(0);
|
||||
|
||||
assertEquals("John Jones", employee.getName());
|
||||
}
|
||||
|
||||
}
|
|
@ -1,265 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.test;
|
||||
|
||||
/*
|
||||
*
|
||||
*
|
||||
*/
|
||||
|
||||
import java.sql.SQLException;
|
||||
import java.util.Vector;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.ConfigHelper;
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.config.Relationship;
|
||||
import org.apache.tuscany.das.rdb.test.data.OrderDetailsData;
|
||||
import org.apache.tuscany.das.rdb.test.data.OrderDetailsDescriptionData;
|
||||
import org.apache.tuscany.das.rdb.test.framework.DasTest;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
public class CompoundKeyRelationshipTests extends DasTest {
|
||||
|
||||
protected void setUp() throws Exception {
|
||||
super.setUp();
|
||||
|
||||
//new OrderData(getAutoConnection()).refresh();
|
||||
//new ProductData(getAutoConnection()).refresh();
|
||||
new OrderDetailsData(getAutoConnection()).refresh();
|
||||
new OrderDetailsDescriptionData(getAutoConnection()).refresh();
|
||||
}
|
||||
|
||||
protected void tearDown() throws Exception {
|
||||
super.tearDown();
|
||||
}
|
||||
|
||||
/**
|
||||
* Test ability to read a compound graph
|
||||
*/
|
||||
public void testRead() throws Exception {
|
||||
|
||||
String statement = "SELECT * FROM ORDERDETAILS LEFT JOIN ORDERDETAILSDESC "
|
||||
+ "ON ORDERDETAILS.ORDERID = ORDERDETAILSDESC.ORDERID AND " +
|
||||
" ORDERDETAILS.PRODUCTID = ORDERDETAILSDESC.PRODUCTID " +
|
||||
" WHERE ORDERDETAILS.ORDERID = 1 AND ORDERDETAILS.PRODUCTID = 1";
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("OrderDetailsAndDescription.xml"), getConnection());
|
||||
// Read some order details and related order details description
|
||||
Command select = das.createCommand(statement);
|
||||
|
||||
DataObject root = select.executeQuery();
|
||||
DataObject orderdetails = root.getDataObject("ORDERDETAILS[1]");
|
||||
|
||||
assertEquals(2, orderdetails.getList("orderDetailsDesc").size());
|
||||
}
|
||||
|
||||
/**
|
||||
* Same as above except uses xml file for relationhip and key information.
|
||||
* Employs CUD generation.
|
||||
*/
|
||||
public void testRelationshipModification2() throws Exception {
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("OrderDetailsAndDescription.xml"), getConnection());
|
||||
// Read some order details and related order details descs
|
||||
Command select = das
|
||||
.createCommand("SELECT * FROM ORDERDETAILS LEFT JOIN ORDERDETAILSDESC ON ORDERDETAILS.ORDERID = ORDERDETAILSDESC.ORDERID " +
|
||||
" AND ORDERDETAILS.PRODUCTID = ORDERDETAILSDESC.PRODUCTID");
|
||||
|
||||
DataObject root = select.executeQuery();
|
||||
|
||||
DataObject ordDet1 = root.getDataObject("ORDERDETAILS[1]");
|
||||
DataObject ordDet2 = root.getDataObject("ORDERDETAILS[2]");
|
||||
|
||||
// Save IDs
|
||||
Integer ord1ID = (Integer) ordDet1.get("ORDERID");
|
||||
Integer prod1ID = (Integer) ordDet1.get("PRODUCTID");
|
||||
|
||||
Integer ord2ID = (Integer) ordDet2.get("ORDERID");
|
||||
Integer prod2ID = (Integer) ordDet2.get("PRODUCTID");
|
||||
|
||||
// save order count
|
||||
Integer order1DetDescCount = new Integer(ordDet1.getList("orderDetailsDesc").size());
|
||||
Integer order2DetDescCount = new Integer(ordDet2.getList("orderDetailsDesc").size());
|
||||
|
||||
// Move an order detail desc to ord det1 from ord det2
|
||||
DataObject orderDetailsDesc = (DataObject) ordDet2.getList("orderDetailsDesc").get(0);
|
||||
ordDet1.getList("orderDetailsDesc").add(orderDetailsDesc);
|
||||
|
||||
// Flush changes
|
||||
das.applyChanges(root);
|
||||
|
||||
// verify ord det1 relationship updates
|
||||
select = das
|
||||
.createCommand("SELECT * FROM ORDERDETAILS LEFT JOIN ORDERDETAILSDESC ON ORDERDETAILS.ORDERID = ORDERDETAILSDESC.ORDERID " +
|
||||
" AND ORDERDETAILS.PRODUCTID = ORDERDETAILSDESC.PRODUCTID where ORDERDETAILS.ORDERID = ? AND ORDERDETAILS.PRODUCTID = ?");
|
||||
select.setParameter(1, ord1ID);
|
||||
select.setParameter(2, prod1ID);
|
||||
|
||||
root = select.executeQuery();
|
||||
assertEquals(order1DetDescCount.intValue() + 1, root.getList("ORDERDETAILS[1]/orderDetailsDesc").size());
|
||||
|
||||
// verify ord det2 relationship updates
|
||||
select.setParameter(1, ord2ID);
|
||||
select.setParameter(2, prod2ID);
|
||||
|
||||
root = select.executeQuery();
|
||||
assertEquals(order2DetDescCount.intValue() - 1, root.getList("ORDERDETAILS[1]/orderDetailsDesc").size());
|
||||
}
|
||||
|
||||
public void testFKBehavior() throws SQLException {
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("OrderDetailsAndDescription.xml"), getConnection());
|
||||
// Read some order details and related order details descs
|
||||
Command select = das
|
||||
.createCommand("SELECT * FROM ORDERDETAILS LEFT JOIN ORDERDETAILSDESC ON ORDERDETAILS.ORDERID = ORDERDETAILSDESC.ORDERID " +
|
||||
" AND ORDERDETAILS.PRODUCTID = ORDERDETAILSDESC.PRODUCTID");
|
||||
|
||||
DataObject root = select.executeQuery();
|
||||
|
||||
DataObject ordDet1 = root.getDataObject("ORDERDETAILS[1]");
|
||||
DataObject ordDet2 = root.getDataObject("ORDERDETAILS[2]");
|
||||
|
||||
// Save IDs
|
||||
Integer ord1ID = (Integer) ordDet1.get("ORDERID");
|
||||
Integer prod1ID = (Integer) ordDet1.get("PRODUCTID");
|
||||
|
||||
// Move an order det desc to ord det1 from ord det2
|
||||
DataObject orderDetDesc = (DataObject) ordDet2.getList("orderDetailsDesc").get(0);
|
||||
ordDet1.getList("orderDetailsDesc").add(orderDetDesc);
|
||||
orderDetDesc.setInt("ORDERID", ord1ID.intValue());
|
||||
|
||||
try {
|
||||
das.applyChanges(root);
|
||||
fail("An exception should be thrown");
|
||||
} catch (RuntimeException ex) {
|
||||
assertEquals("Foreign key properties should not be set when the corresponding relationship has changed", ex.getMessage());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public void testFKBehavior2() throws SQLException {
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("OrderDetailsAndDescription.xml"), getConnection());
|
||||
// Read some order details and related order details descs
|
||||
Command select = das
|
||||
.createCommand("SELECT * FROM ORDERDETAILS LEFT JOIN ORDERDETAILSDESC ON ORDERDETAILS.ORDERID = ORDERDETAILSDESC.ORDERID " +
|
||||
" AND ORDERDETAILS.PRODUCTID = ORDERDETAILSDESC.PRODUCTID");
|
||||
|
||||
DataObject root = select.executeQuery();
|
||||
|
||||
DataObject ordDet1 = root.getDataObject("ORDERDETAILS[1]");
|
||||
DataObject ordDet2 = root.getDataObject("ORDERDETAILS[2]");
|
||||
|
||||
// Save IDs
|
||||
Integer ord1ID = (Integer) ordDet1.get("ORDERID");
|
||||
Integer prod1ID = (Integer) ordDet1.get("PRODUCTID");
|
||||
|
||||
// Create an order det desc for ord det1
|
||||
DataObject orderDetDesc = root.createDataObject("ORDERDETAILSDESC");
|
||||
orderDetDesc.setInt("ID", 500);
|
||||
orderDetDesc.setInt("ORDERID", ord1ID.intValue());
|
||||
ordDet1.getList("orderDetailsDesc").add(orderDetDesc);
|
||||
|
||||
try {
|
||||
das.applyChanges(root);
|
||||
fail("An exception should be thrown");
|
||||
} catch (RuntimeException ex) {
|
||||
assertEquals("Foreign key properties should not be set when the corresponding relationship has changed", ex.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
//add relationship through config helper
|
||||
public void testValidFKColumn() throws SQLException {
|
||||
ConfigHelper helper = new ConfigHelper();
|
||||
Vector parentColumnNames = new Vector();
|
||||
Vector childColumnNames = new Vector();
|
||||
|
||||
parentColumnNames.add(0, "ORDERDETAILS.ORDERID");
|
||||
parentColumnNames.add(1, "ORDERDETAILS.PRODUCTID");
|
||||
|
||||
childColumnNames.add(0, "ORDERDETAILSDESC.ORDERID");
|
||||
childColumnNames.add(1, "ORDERDETAILSDESC.PRODUCTID");
|
||||
|
||||
Relationship r = helper.addRelationship(parentColumnNames, childColumnNames);
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(helper.getConfig(), getConnection());
|
||||
Command select = das.createCommand("SELECT * FROM ORDERDETAILS LEFT JOIN ORDERDETAILSDESC ON ORDERDETAILS.ORDERID = ORDERDETAILSDESC.ORDERID " +
|
||||
" AND ORDERDETAILS.PRODUCTID = ORDERDETAILSDESC.PRODUCTID");
|
||||
|
||||
DataObject root = select.executeQuery();
|
||||
DataObject ordDet1 = root.getDataObject("ORDERDETAILS[1]");
|
||||
int order1DetDescCount = ordDet1.getList("ORDERDETAILSDESC").size();
|
||||
|
||||
DataObject orderDetDesc = root.createDataObject("ORDERDETAILSDESC");
|
||||
orderDetDesc.setInt("ID", 500);
|
||||
|
||||
if(ordDet1 == null) System.out.println("order det1 is null");
|
||||
if(ordDet1.getList("ORDERDETAILSDESC") == null)System.out.println("list is null");
|
||||
|
||||
ordDet1.getList("ORDERDETAILSDESC").add(orderDetDesc);
|
||||
try {
|
||||
das.applyChanges(root);
|
||||
|
||||
select = das.createCommand("SELECT * FROM ORDERDETAILS LEFT JOIN ORDERDETAILSDESC ON ORDERDETAILS.ORDERID = ORDERDETAILSDESC.ORDERID " +
|
||||
" AND ORDERDETAILS.PRODUCTID = ORDERDETAILSDESC.PRODUCTID");
|
||||
|
||||
int modOrder1DetDescCount = select.executeQuery().
|
||||
getDataObject("ORDERDETAILS[1]").getList("ORDERDETAILSDESC").size();
|
||||
this.assertEquals(modOrder1DetDescCount, order1DetDescCount+1);
|
||||
} catch (RuntimeException ex) {
|
||||
fail("Exception was not expected:DETAILS:"+ ex.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
//add invalid relationship through config helper using invalid FK column name
|
||||
public void testInvalidFKColumn() throws SQLException {
|
||||
ConfigHelper helper = new ConfigHelper();
|
||||
Vector parentColumnNames = new Vector();
|
||||
Vector childColumnNames = new Vector();
|
||||
|
||||
parentColumnNames.add(0, "ORDERDETAILS.ORDERID");
|
||||
parentColumnNames.add(1, "ORDERDETAILS.PRODUCTID");
|
||||
|
||||
childColumnNames.add(0, "ORDERDETAILSDESC.ORDERID_INVALID");
|
||||
childColumnNames.add(1, "ORDERDETAILSDESC.PRODUCTID");
|
||||
|
||||
Relationship r = helper.addRelationship(parentColumnNames, childColumnNames);
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(helper.getConfig(), getConnection());
|
||||
Command select = das.createCommand("SELECT * FROM ORDERDETAILS LEFT JOIN ORDERDETAILSDESC ON ORDERDETAILS.ORDERID = ORDERDETAILSDESC.ORDERID " +
|
||||
" AND ORDERDETAILS.PRODUCTID = ORDERDETAILSDESC.PRODUCTID");
|
||||
|
||||
DataObject root = select.executeQuery();
|
||||
DataObject ordDet1 = root.getDataObject("ORDERDETAILS[1]");
|
||||
int order1DetDescCount = ordDet1.getList("ORDERDETAILSDESC").size();
|
||||
|
||||
DataObject orderDetDesc = root.createDataObject("ORDERDETAILSDESC");
|
||||
orderDetDesc.setInt("ID", 500);
|
||||
|
||||
if(ordDet1 == null) System.out.println("order det1 is null");
|
||||
if(ordDet1.getList("ORDERDETAILSDESC") == null)System.out.println("list is null");
|
||||
|
||||
ordDet1.getList("ORDERDETAILSDESC").add(orderDetDesc);
|
||||
try {
|
||||
das.applyChanges(root);
|
||||
fail("Exception was expected");
|
||||
} catch (RuntimeException ex) {
|
||||
assertEquals("Invalid foreign key column: ORDERID_INVALID", ex.getMessage());
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,109 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.test;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.test.data.OrderData;
|
||||
import org.apache.tuscany.das.rdb.test.data.OrderDetailsData;
|
||||
import org.apache.tuscany.das.rdb.test.framework.DasTest;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
|
||||
/**
|
||||
* Tests for Compound Keys
|
||||
*/
|
||||
public class CompoundKeyTests extends DasTest {
|
||||
|
||||
protected void setUp() throws Exception {
|
||||
super.setUp();
|
||||
|
||||
new OrderDetailsData(getAutoConnection()).refresh();
|
||||
new OrderData(getAutoConnection()).refresh();
|
||||
}
|
||||
|
||||
protected void tearDown() throws Exception {
|
||||
super.tearDown();
|
||||
}
|
||||
|
||||
public void testRead() throws Exception {
|
||||
DAS das = DAS.FACTORY.createDAS(getConnection());
|
||||
Command getOrderDetails = das.createCommand("Select * from ORDERDETAILS where ORDERID = ? AND PRODUCTID = ?");
|
||||
|
||||
getOrderDetails.setParameter(1, new Integer(1));
|
||||
getOrderDetails.setParameter(2, new Integer(1));
|
||||
|
||||
DataObject root = getOrderDetails.executeQuery();
|
||||
|
||||
DataObject orderDetail = (DataObject) root.get("ORDERDETAILS[1]");
|
||||
assertEquals(1.1f, orderDetail.getFloat("PRICE"), 0.01);
|
||||
|
||||
}
|
||||
|
||||
public void testReadModifyWrite2() throws Exception {
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("OrdersOrderDetailsConfig.xml"), getConnection());
|
||||
Command getOrderDetails = das.createCommand("Select * from ORDERDETAILS where ORDERID = 1 AND PRODUCTID = 1");
|
||||
|
||||
DataObject root = getOrderDetails.executeQuery();
|
||||
|
||||
DataObject orderDetails = (DataObject) root.get("ORDERDETAILS[1]");
|
||||
assertEquals(1.1f, orderDetails.getFloat("PRICE"), 0.01);
|
||||
|
||||
// Modify
|
||||
orderDetails.setFloat("PRICE", 0f);
|
||||
|
||||
// Build apply changes command
|
||||
|
||||
das.applyChanges(root);
|
||||
|
||||
// Verify
|
||||
root = getOrderDetails.executeQuery();
|
||||
orderDetails = root.getDataObject("ORDERDETAILS[1]");
|
||||
assertEquals(0f, orderDetails.getFloat("PRICE"), 0.01);
|
||||
|
||||
}
|
||||
|
||||
public void testReadOrdersAndDetails2() throws Exception {
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("OrdersOrderDetailsConfig.xml"), getConnection());
|
||||
Command read = das.createCommand("SELECT * FROM ANORDER LEFT JOIN ORDERDETAILS "
|
||||
+ "ON ANORDER.ID = ORDERDETAILS.ORDERID ORDER BY ANORDER.ID");
|
||||
|
||||
DataObject root = read.executeQuery();
|
||||
|
||||
DataObject firstOrder = root.getDataObject("ANORDER[1]");
|
||||
assertEquals(1, firstOrder.getInt("ID"));
|
||||
assertEquals(2, firstOrder.getList("ORDERDETAILS").size());
|
||||
|
||||
}
|
||||
|
||||
public void testReadAndDelete() throws Exception {
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("OrdersOrderDetailsConfig.xml"), getConnection());
|
||||
Command getOrderDetails = das.createCommand("Select * from ORDERDETAILS where ORDERID = ? AND PRODUCTID = ?");
|
||||
|
||||
getOrderDetails.setParameter(1, new Integer(1));
|
||||
getOrderDetails.setParameter(2, new Integer(1));
|
||||
|
||||
DataObject root = getOrderDetails.executeQuery();
|
||||
|
||||
DataObject orderDetail = (DataObject) root.get("ORDERDETAILS[1]");
|
||||
orderDetail.delete();
|
||||
das.applyChanges(root);
|
||||
|
||||
}
|
||||
}
|
|
@ -1,222 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.tuscany.das.rdb.test;
|
||||
|
||||
import java.text.DateFormat;
|
||||
import java.text.ParseException;
|
||||
import java.text.SimpleDateFormat;
|
||||
import java.util.Date;
|
||||
|
||||
import org.apache.tuscany.das.rdb.Command;
|
||||
import org.apache.tuscany.das.rdb.DAS;
|
||||
import org.apache.tuscany.das.rdb.test.customer.Customer;
|
||||
import org.apache.tuscany.das.rdb.test.customer.CustomerFactory;
|
||||
import org.apache.tuscany.das.rdb.test.data.CustomerData;
|
||||
import org.apache.tuscany.das.rdb.test.data.OrderData;
|
||||
import org.apache.tuscany.das.rdb.test.framework.DasTest;
|
||||
|
||||
import commonj.sdo.DataObject;
|
||||
import commonj.sdo.helper.HelperContext;
|
||||
import commonj.sdo.impl.HelperProvider;
|
||||
/**
|
||||
* Tests the Converter framwork
|
||||
*/
|
||||
public class ConverterTests extends DasTest {
|
||||
|
||||
private static DateFormat myformat = new SimpleDateFormat("yyyy.MM.dd");
|
||||
|
||||
private static Date kbday;
|
||||
|
||||
private static Date tbday;
|
||||
|
||||
protected void setUp() throws Exception {
|
||||
super.setUp();
|
||||
new CustomerData(getAutoConnection()).refresh();
|
||||
new OrderData(getAutoConnection()).refresh();
|
||||
}
|
||||
|
||||
protected void tearDown() throws Exception {
|
||||
super.tearDown();
|
||||
}
|
||||
|
||||
static {
|
||||
try {
|
||||
kbday = myformat.parse("1957.09.27");
|
||||
tbday = myformat.parse("1966.12.20");
|
||||
} catch (ParseException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* This tests the use of an arbitrary converter. The column converted is a VARCAHAR. ResultSetShape is used to specify that the property will be a
|
||||
* SDODataTypes.DATE.
|
||||
*
|
||||
* So this example uses a converter that transforms a string column into a date property and conversely, a date property back to a string for the
|
||||
* underlying column.
|
||||
*
|
||||
* The converter returns 1957.09.27 if the column value is "Williams" and 1966.12.20 if the value is "Pavick"
|
||||
*
|
||||
* On write, the converter returns "Pavick" if the property value is 1966.12.20 and "Williams" if the property value is 1957.09.27
|
||||
*
|
||||
*/
|
||||
public void testArbitraryConverter() throws Exception {
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CustomerConfigWithConverter.xml"), getConnection());
|
||||
|
||||
// Create and initialize command to read customers
|
||||
Command read = das.getCommand("testArbitraryConverter");
|
||||
|
||||
// Read
|
||||
DataObject root = read.executeQuery();
|
||||
|
||||
// Verify
|
||||
assertEquals(kbday, root.getDate("CUSTOMER[1]/LASTNAME"));
|
||||
|
||||
// Modify
|
||||
root.setDate("CUSTOMER[1]/LASTNAME", tbday);
|
||||
|
||||
das.applyChanges(root);
|
||||
|
||||
// Read
|
||||
root = read.executeQuery();
|
||||
|
||||
// Verify
|
||||
assertEquals(tbday, root.getDate("CUSTOMER[1]/LASTNAME"));
|
||||
|
||||
}
|
||||
|
||||
public void testInvalidConverter1() throws Exception {
|
||||
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("InvalidConverter.xml"), getConnection());
|
||||
|
||||
// Build the select command to read a specific customer and related
|
||||
// orders
|
||||
Command select = das
|
||||
.createCommand("SELECT * FROM CUSTOMER LEFT JOIN ANORDER " + "ON CUSTOMER.ID = ANORDER.CUSTOMER_ID where CUSTOMER.ID = ?");
|
||||
|
||||
// Parameterize the command
|
||||
select.setParameter(1, new Integer(1));
|
||||
|
||||
// Get the graph
|
||||
try {
|
||||
select.executeQuery();
|
||||
} catch (Exception ex) {
|
||||
assertEquals("java.lang.ClassNotFoundException: not.a.valid.class", ex.getMessage());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public void testInvalidConverter2() throws Exception {
|
||||
|
||||
HelperContext context = HelperProvider.getDefaultContext();
|
||||
CustomerFactory.INSTANCE.register(context);
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("InvalidConverter.xml"), getConnection());
|
||||
|
||||
// Build the select command to read a specific customer and related
|
||||
// orders
|
||||
Command select = das.createCommand("SELECT * FROM ANORDER");
|
||||
|
||||
// Get the graph
|
||||
|
||||
DataObject root = select.executeQuery();
|
||||
DataObject order = root.getDataObject("AnOrder[1]");
|
||||
|
||||
Customer customer = (Customer) root.createDataObject("Customer");
|
||||
customer.setID(700);
|
||||
customer.setLastName("Daniel");
|
||||
customer.setAddress("an address");
|
||||
|
||||
customer.getOrders().add(order);
|
||||
|
||||
try {
|
||||
das.applyChanges(root);
|
||||
} catch (Exception ex) {
|
||||
assertEquals("java.lang.ClassNotFoundException: not.a.valid.class", ex.getMessage());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* This tests the use of a converter that does not produce a new "type". Instead it
|
||||
* modifies the original value before storing to the database. In this exampe, the
|
||||
* converter restores the original value on read.
|
||||
*
|
||||
* This is illustrated by obfuscating the lastname value before it is stored to the database and
|
||||
* deobfuscating on read.
|
||||
*
|
||||
*/
|
||||
public void testConverter3() throws Exception {
|
||||
DAS das = DAS.FACTORY.createDAS(getConfig("CustomerConfigWithConverter2.xml"), getConnection());
|
||||
|
||||
// Create and initialize command to read customers
|
||||
Command read = das.getCommand("getFirstCustomer");
|
||||
|
||||
// Read
|
||||
DataObject root = read.executeQuery();
|
||||
|
||||
//Modify
|
||||
root.setString("CUSTOMER[1]/LASTNAME", "Some new name");
|
||||
|
||||
das.applyChanges(root);
|
||||
|
||||
// Read
|
||||
root = read.executeQuery();
|
||||
|
||||
// Verify that I can read back the deobfuscated value
|
||||
assertEquals("Some new name", root.getString("CUSTOMER[1]/LASTNAME"));
|
||||
|
||||
//Now read directly without applying the converter to ensure that the value was obfuscated
|
||||
//in the database.
|
||||
DAS das2 = DAS.FACTORY.createDAS(getConnection());
|
||||
Command directRead = das2.createCommand("select * from CUSTOMER where ID = 1");
|
||||
root = directRead.executeQuery();
|
||||
|
||||
assertEquals("Fbzr arj anzr", root.getString("CUSTOMER[1]/LASTNAME"));
|
||||
assertEquals(obfuscate("Some new name"), root.getString("CUSTOMER[1]/LASTNAME"));
|
||||
|
||||
}
|
||||
|
||||
// Utilities
|
||||
|
||||
private String obfuscate (String original) throws Exception {
|
||||
return toRot13(original);
|
||||
}
|
||||
|
||||
private String deobfuscate (String obfuscated) throws Exception {
|
||||
return toRot13(obfuscated);
|
||||
}
|
||||
|
||||
//A simple, reversible, obfuscation algorithm using a ROT13 implementation
|
||||
private String toRot13(String original) throws Exception {
|
||||
|
||||
int abyte = 0;
|
||||
byte[] buffer = original.getBytes("ISO-8859-1");
|
||||
|
||||
for (int i = 0; i < buffer.length; i++) {
|
||||
abyte = buffer[i];
|
||||
int cap = abyte & 32;
|
||||
abyte &= ~cap;
|
||||
abyte = ((abyte >= 'A') && (abyte <= 'Z') ? ((abyte - 'A' + 13) % 26 + 'A') : abyte) | cap;
|
||||
buffer[i] = (byte) abyte;
|
||||
}
|
||||
|
||||
return new String(buffer, "ISO-8859-1");
|
||||
}
|
||||
|
||||
}
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue