/* * Copyright 2011 gitblit.com. * * 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. */ package com.gitblit.client; import java.awt.Component; import java.awt.Cursor; import java.io.IOException; import java.text.MessageFormat; import javax.swing.JOptionPane; import javax.swing.SwingWorker; import com.gitblit.Constants.RpcRequest; import com.gitblit.GitBlitException.ForbiddenException; import com.gitblit.GitBlitException.NotAllowedException; import com.gitblit.GitBlitException.UnauthorizedException; import com.gitblit.GitBlitException.UnknownRequestException; public abstract class GitblitWorker extends SwingWorker { private final Component parent; private final RpcRequest request; public GitblitWorker(Component parent, RpcRequest request) { this.parent = parent; this.request = request; parent.setCursor(Cursor.getPredefinedCursor(Cursor.WAIT_CURSOR)); } protected RpcRequest getRequestType() { return request; } @Override protected Boolean doInBackground() throws IOException { return doRequest(); } @Override protected void done() { parent.setCursor(Cursor.getPredefinedCursor(Cursor.DEFAULT_CURSOR)); try { Boolean success = get(); if (success) { onSuccess(); } else { onFailure(); } } catch (Throwable t) { if (t instanceof ForbiddenException) { Utils.explainForbidden(parent, request); } else if (t instanceof UnauthorizedException) { Utils.explainUnauthorized(parent, request); } else if (t instanceof NotAllowedException) { Utils.explainNotAllowed(parent, request); } else if (t instanceof UnknownRequestException) { Utils.explainNotAllowed(parent, request); } else { Utils.showException(parent, t); } } } protected abstract Boolean doRequest() throws IOException; protected abstract void onSuccess(); protected void onFailure() { } protected void showFailure(String message, Object... args) { String msg = MessageFormat.format(message, args); JOptionPane.showMessageDialog(parent, msg, Translation.get("gb.error"), JOptionPane.ERROR_MESSAGE); } } value='dependabot/maven/org.eclipse.jetty-jetty-server-10.0.14'>dependabot/maven/org.eclipse.jetty-jetty-server-10.0.14 Vaadin 6, 7, 8 is a Java framework for modern Java web applications: https://github.com/vaadin/frameworkwww-data
summaryrefslogtreecommitdiffstats
path: root/documentation/sqlcontainer/chapter-sqlcontainer.asciidoc
blob: 9b5ff51573c82416ab0c13d30772c4fdd5440f78 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
[[sqlcontainer]]
== Vaadin SQLContainer

Vaadin SQLContainer is a container implementation that allows easy and
customizable access to data stored in various SQL-speaking databases.

SQLContainer supports two types of database access. Using
[classname]#TableQuery#, the pre-made query generators will enable fetching,
updating, and inserting data directly from the container into a database table -
automatically, whereas [classname]#FreeformQuery# allows the developer to use
their own, probably more complex query for fetching data and their own optional
implementations for writing, filtering and sorting support - item and property
handling as well as lazy loading will still be handled automatically.

In addition to the customizable database connection options, SQLContainer also
extends the Vaadin [classname]#Container# interface to implement more advanced
and more database-oriented filtering rules. Finally, the add-on also offers
connection pool implementations for JDBC connection pooling and JEE connection
pooling, as well as integrated transaction support; auto-commit mode is also
provided.

The purpose of this section is to briefly explain the architecture and some of
the inner workings of SQLContainer. It will also give the readers some examples
on how to use SQLContainer in their own applications. The requirements,
limitations and further development ideas are also discussed.

SQLContainer is available from the Vaadin Directory under the same unrestrictive
Apache License 2.0 as the Vaadin Framework itself.


include::sqlcontainer-architecture.asciidoc[leveloffset=+2]

include::sqlcontainer-getting-started.asciidoc[leveloffset=+2]

include::sqlcontainer-filteringsorting.asciidoc[leveloffset=+2]

include::sqlcontainer-editing.asciidoc[leveloffset=+2]

include::sqlcontainer-caching.asciidoc[leveloffset=+2]

include::sqlcontainer-referencing.asciidoc[leveloffset=+2]

include::sqlcontainer-freeform.asciidoc[leveloffset=+2]

include::sqlcontainer-nonimplemented.asciidoc[leveloffset=+2]

include::sqlcontainer-limitations.asciidoc[leveloffset=+2]