mirror of
https://github.com/octoleo/plantuml-server.git
synced 2025-01-04 21:45:19 +00:00
update and fix checkstyle and javadoc plugins
This commit is contained in:
parent
8d5be87f03
commit
098e630a28
19
.vscode/settings.json
vendored
Normal file
19
.vscode/settings.json
vendored
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
"java.configuration.updateBuildConfiguration": "automatic",
|
||||||
|
"cSpell.words": [
|
||||||
|
"Arnaud",
|
||||||
|
"ditaa",
|
||||||
|
"endditaa",
|
||||||
|
"enduml",
|
||||||
|
"epstext",
|
||||||
|
"etag",
|
||||||
|
"Lalloni",
|
||||||
|
"plantuml",
|
||||||
|
"Roques",
|
||||||
|
"servlet",
|
||||||
|
"servlets",
|
||||||
|
"startditaa",
|
||||||
|
"startuml"
|
||||||
|
],
|
||||||
|
"cSpell.allowCompoundWords": true
|
||||||
|
}
|
8
COPYING
8
COPYING
@ -1,7 +1,7 @@
|
|||||||
GNU GENERAL PUBLIC LICENSE
|
GNU GENERAL PUBLIC LICENSE
|
||||||
Version 3, 29 June 2007
|
Version 3, 29 June 2007
|
||||||
|
|
||||||
Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
|
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
|
||||||
Everyone is permitted to copy and distribute verbatim copies
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
of this license document, but changing it is not allowed.
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
@ -645,7 +645,7 @@ the "copyright" line and a pointer to where the full notice is found.
|
|||||||
GNU General Public License for more details.
|
GNU General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License
|
You should have received a copy of the GNU General Public License
|
||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
Also add information on how to contact you by electronic and paper mail.
|
Also add information on how to contact you by electronic and paper mail.
|
||||||
|
|
||||||
@ -664,11 +664,11 @@ might be different; for a GUI interface, you would use an "about box".
|
|||||||
You should also get your employer (if you work as a programmer) or school,
|
You should also get your employer (if you work as a programmer) or school,
|
||||||
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
||||||
For more information on this, and how to apply and follow the GNU GPL, see
|
For more information on this, and how to apply and follow the GNU GPL, see
|
||||||
<http://www.gnu.org/licenses/>.
|
<https://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
The GNU General Public License does not permit incorporating your program
|
The GNU General Public License does not permit incorporating your program
|
||||||
into proprietary programs. If your program is a subroutine library, you
|
into proprietary programs. If your program is a subroutine library, you
|
||||||
may consider it more useful to permit linking proprietary applications with
|
may consider it more useful to permit linking proprietary applications with
|
||||||
the library. If this is what you want to do, use the GNU Lesser General
|
the library. If this is what you want to do, use the GNU Lesser General
|
||||||
Public License instead of this License. But first, please read
|
Public License instead of this License. But first, please read
|
||||||
<http://www.gnu.org/philosophy/why-not-lgpl.html>.
|
<https://www.gnu.org/licenses/why-not-lgpl.html>.
|
||||||
|
109
README.md
109
README.md
@ -1,60 +1,59 @@
|
|||||||
PlantUML Server
|
# PlantUML Server
|
||||||
===============
|
|
||||||
[![Build Status](https://travis-ci.org/plantuml/plantuml-server.png?branch=master)](https://travis-ci.org/plantuml/plantuml-server)
|
![workflow status](https://github.com/plantuml/plantuml-server/actions/workflows/main.yml/badge.svg)
|
||||||
[![](https://images.microbadger.com/badges/image/plantuml/plantuml-server.svg)](https://microbadger.com/images/plantuml/plantuml-server "Get your own image badge on microbadger.com")
|
[![docker pulls](https://img.shields.io/docker/pulls/plantuml/plantuml-server.svg)](https://hub.docker.com/r/plantuml/plantuml-server)
|
||||||
[![Docker Pull](https://img.shields.io/docker/pulls/plantuml/plantuml-server.svg)](https://hub.docker.com/r/plantuml/plantuml-server/)
|
|
||||||
PlantUML Server is a web application to generate UML diagrams on-the-fly.
|
PlantUML Server is a web application to generate UML diagrams on-the-fly.
|
||||||
|
|
||||||
![](https://raw.githubusercontent.com/ftomassetti/plantuml-server/readme/screenshots/screenshot.png)
|
![PlantUML Server](https://raw.githubusercontent.com/plantuml/plantuml-server/master/screenshots/screenshot.png)
|
||||||
|
|
||||||
To know more about PlantUML, please visit http://plantuml.com/.
|
To know more about PlantUML, please visit https://plantuml.com.
|
||||||
|
|
||||||
|
|
||||||
Requirements
|
## Requirements
|
||||||
============
|
|
||||||
|
|
||||||
* jre/jdk 1.6.0 or above
|
- jre/jdk 1.6.0 or above
|
||||||
* apache maven 3.0.2 or above
|
- apache maven 3.0.2 or above
|
||||||
|
|
||||||
How to run the server
|
|
||||||
=====================
|
## How to run the server
|
||||||
|
|
||||||
Just run:
|
Just run:
|
||||||
|
|
||||||
```
|
```sh
|
||||||
mvn jetty:run
|
mvn jetty:run
|
||||||
```
|
```
|
||||||
|
|
||||||
The server is now listing to [http://localhost:8080/plantuml](http://localhost:8080/plantuml).
|
The server is now listening to [http://localhost:8080/plantuml](http://localhost:8080/plantuml).
|
||||||
In this way the server is run on an embedded jetty server.
|
In this way the server is run on an embedded jetty server.
|
||||||
|
|
||||||
You can specify the port at which it runs:
|
You can specify the port at which it runs:
|
||||||
|
|
||||||
```
|
```sh
|
||||||
mvn jetty:run -Djetty.port=9999
|
mvn jetty:run -Djetty.port=9999
|
||||||
```
|
```
|
||||||
|
|
||||||
How to run the server with Docker
|
|
||||||
=================================
|
## How to run the server with Docker
|
||||||
|
|
||||||
You can run Plantuml with jetty or tomcat container
|
You can run Plantuml with jetty or tomcat container
|
||||||
```
|
```sh
|
||||||
docker run -d -p 8080:8080 plantuml/plantuml-server:jetty
|
docker run -d -p 8080:8080 plantuml/plantuml-server:jetty
|
||||||
docker run -d -p 8080:8080 plantuml/plantuml-server:tomcat
|
docker run -d -p 8080:8080 plantuml/plantuml-server:tomcat
|
||||||
```
|
```
|
||||||
|
|
||||||
The server is now listing to [http://localhost:8080](http://localhost:8080).
|
The server is now listening to [http://localhost:8080](http://localhost:8080).
|
||||||
|
|
||||||
## Read-only container
|
### Read-only container
|
||||||
|
|
||||||
The jetty container supports read-only files system, you can run the read-only mode with:
|
The jetty container supports read-only files system, you can run the read-only mode with:
|
||||||
```
|
```sh
|
||||||
docker run -d -p 8080:8080 --read-only -v /tmp/jetty plantuml/plantuml-server:jetty-readonly
|
docker run -d -p 8080:8080 --read-only -v /tmp/jetty plantuml/plantuml-server:jetty
|
||||||
```
|
```
|
||||||
|
|
||||||
This makes the container compatible with more restricted environment such as OpenShift, just make sure you mount a volume (can be ephemeral) on `/tmp/jetty`.
|
This makes the container compatible with more restricted environment such as OpenShift, just make sure you mount a volume (can be ephemeral) on `/tmp/jetty`.
|
||||||
|
|
||||||
## Change base URL
|
### Change base URL
|
||||||
|
|
||||||
To run plantuml using different base url, change the `docker-compose.yml` file:
|
To run plantuml using different base url, change the `docker-compose.yml` file:
|
||||||
```yaml
|
```yaml
|
||||||
@ -62,69 +61,67 @@ environment:
|
|||||||
- BASE_URL=plantuml
|
- BASE_URL=plantuml
|
||||||
```
|
```
|
||||||
|
|
||||||
And run `docker-compose up`. This will start a modified version of the image using
|
And run `docker-compose up`. This will start a modified version of the image using the base url `/plantuml`, e.g. http://localhost:8080/plantuml
|
||||||
the base url `/plantuml`, e.g. http://localhost/plantuml
|
|
||||||
|
|
||||||
How to set PlantUML options
|
|
||||||
=================================
|
|
||||||
|
|
||||||
You can apply some option to your PlantUML server with environement variable.
|
## How to set PlantUML options
|
||||||
|
|
||||||
|
You can apply some option to your PlantUML server with environment variable.
|
||||||
|
|
||||||
If you run the directly the jar, you can pass the option with `-D` flag
|
If you run the directly the jar, you can pass the option with `-D` flag
|
||||||
```
|
```sh
|
||||||
java -D THE_ENV_VARIABLE=THE_ENV_VALUE -Djetty.contextpath=/ -jar target/dependency/jetty-runner.jar target/plantuml.war
|
java -D THE_ENV_VARIABLE=THE_ENV_VALUE -Djetty.contextpath=/ -jar target/dependency/jetty-runner.jar target/plantuml.war
|
||||||
```
|
```
|
||||||
or
|
or
|
||||||
```
|
```sh
|
||||||
mvn jetty:run -D THE_ENV_VARIABLE=THE_ENV_VALUE -Djetty.port=9999
|
mvn jetty:run -D THE_ENV_VARIABLE=THE_ENV_VALUE -Djetty.port=9999
|
||||||
```
|
```
|
||||||
|
|
||||||
If you use docker, you can use the `-e` flag:
|
If you use docker, you can use the `-e` flag:
|
||||||
```
|
```sh
|
||||||
docker run -d -p 8080:8080 -e THE_ENV_VARIABLE=THE_ENV_VALUE plantuml/plantuml-server:jetty
|
docker run -d -p 8080:8080 -e THE_ENV_VARIABLE=THE_ENV_VALUE plantuml/plantuml-server:jetty
|
||||||
```
|
```
|
||||||
|
|
||||||
You can set all the following variables:
|
You can set all the following variables:
|
||||||
|
|
||||||
- `BASE_URL`
|
* `PLANTUML_LIMIT_SIZE`
|
||||||
* PlantUML base url
|
* Limits image width and height
|
||||||
* Default value: `ROOT`
|
* Default value: `4096`
|
||||||
- `PLANTUML_LIMIT_SIZE`
|
* `GRAPHVIZ_DOT`
|
||||||
* Limits image width and height
|
* Link to 'dot' executable
|
||||||
* Default value: `4096`
|
* Default value: `/usr/local/bin/dot` or `/usr/bin/dot`
|
||||||
- `PLANTUML_STATS`
|
* `PLANTUML_STATS`
|
||||||
* Set it to `on` to enable [statistics report](http://plantuml.com/statistics-report)
|
* Set it to `on` to enable [statistics report](https://plantuml.com/statistics-report)
|
||||||
* Default value: `off`
|
* Default value: `off`
|
||||||
- `HTTP_AUTHORIZATION`
|
* `HTTP_AUTHORIZATION`
|
||||||
* when calling the `proxy` endpoint, the value of `HTTP_AUTHORIZATION` will be used to set the HTTP Authorization header
|
* when calling the `proxy` endpoint, the value of `HTTP_AUTHORIZATION` will be used to set the HTTP Authorization header
|
||||||
* Default value: `null`
|
* Default value: `null`
|
||||||
- `ALLOW_PLANTUML_INCLUDE`
|
* `ALLOW_PLANTUML_INCLUDE`
|
||||||
* Enables `!include` processing which can read files from the server into diagrams. Files are read relative to the current working directory.
|
* Enables `!include` processing which can read files from the server into diagrams. Files are read relative to the current working directory.
|
||||||
* Default value: `false`
|
* Default value: `false`
|
||||||
|
|
||||||
Alternate: How to build your docker image
|
|
||||||
======================================================
|
## Alternate: How to build your docker image
|
||||||
|
|
||||||
This method uses maven to run the application. That requires internet connectivity.
|
This method uses maven to run the application. That requires internet connectivity.
|
||||||
So, you can use following command to create a self-contained docker image that will "just-work".
|
So, you can use following command to create a self-contained docker image that will "just-work".
|
||||||
|
|
||||||
*Note: Generate the WAR (instructions further below) prior to running "docker build"*
|
*Note: Generate the WAR (instructions further below) prior to running "docker build"*
|
||||||
|
|
||||||
|
```sh
|
||||||
|
docker image build -t plantuml-server:local .
|
||||||
|
docker run -d -p 8080:8080 plantuml-server:local
|
||||||
```
|
```
|
||||||
docker image build -t plantuml-server .
|
The server is now listening to [http://localhost:8080/plantuml](http://localhost:8080/plantuml).
|
||||||
docker run -d -p 8080:8080 plantuml-server
|
|
||||||
```
|
|
||||||
The server is now listing to [http://localhost:8080/plantuml](http://localhost:8080/plantuml).
|
|
||||||
|
|
||||||
You may specify the port in `-p` Docker command line argument.
|
You may specify the port in `-p` Docker command line argument.
|
||||||
|
|
||||||
|
|
||||||
How to generate the war
|
## How to generate the war
|
||||||
=======================
|
|
||||||
|
|
||||||
To build the war, just run:
|
To build the war, just run:
|
||||||
|
|
||||||
```
|
```sh
|
||||||
mvn package
|
mvn package
|
||||||
```
|
```
|
||||||
|
|
||||||
|
45
pom.xml
45
pom.xml
@ -1,3 +1,4 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
@ -8,6 +9,28 @@
|
|||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
<build>
|
<build>
|
||||||
<finalName>plantuml</finalName>
|
<finalName>plantuml</finalName>
|
||||||
|
<pluginManagement>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-checkstyle-plugin</artifactId>
|
||||||
|
<version>3.1.2</version>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.puppycrawl.tools</groupId>
|
||||||
|
<artifactId>checkstyle</artifactId>
|
||||||
|
<version>9.0.1</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
<configuration>
|
||||||
|
<configLocation>${basedir}/src/main/config/checkstyle.xml</configLocation>
|
||||||
|
<linkXRef>false</linkXRef>
|
||||||
|
<consoleOutput>true</consoleOutput>
|
||||||
|
<failsOnError>true</failsOnError>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</pluginManagement>
|
||||||
<plugins>
|
<plugins>
|
||||||
<plugin>
|
<plugin>
|
||||||
<artifactId>maven-eclipse-plugin</artifactId>
|
<artifactId>maven-eclipse-plugin</artifactId>
|
||||||
@ -95,18 +118,11 @@
|
|||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
<artifactId>maven-checkstyle-plugin</artifactId>
|
<artifactId>maven-checkstyle-plugin</artifactId>
|
||||||
<version>2.11</version>
|
<version>3.1.2</version>
|
||||||
<executions>
|
<executions>
|
||||||
<execution>
|
<execution>
|
||||||
<id>validate</id>
|
<?m2e execute onConfiguration,onIncremental?>
|
||||||
<phase>validate</phase>
|
<phase>validate</phase>
|
||||||
<configuration>
|
|
||||||
<configLocation>${basedir}/src/main/config/checkstyle.xml</configLocation>
|
|
||||||
<encoding>UTF-8</encoding>
|
|
||||||
<consoleOutput>true</consoleOutput>
|
|
||||||
<failsOnError>true</failsOnError>
|
|
||||||
<linkXRef>false</linkXRef>
|
|
||||||
</configuration>
|
|
||||||
<goals>
|
<goals>
|
||||||
<goal>check</goal>
|
<goal>check</goal>
|
||||||
</goals>
|
</goals>
|
||||||
@ -133,7 +149,7 @@
|
|||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
<artifactId>maven-javadoc-plugin</artifactId>
|
<artifactId>maven-javadoc-plugin</artifactId>
|
||||||
<version>2.9.1</version>
|
<version>3.3.1</version>
|
||||||
<configuration>
|
<configuration>
|
||||||
<show>private</show>
|
<show>private</show>
|
||||||
<nohelp>true</nohelp>
|
<nohelp>true</nohelp>
|
||||||
@ -150,16 +166,12 @@
|
|||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
<artifactId>maven-checkstyle-plugin</artifactId>
|
<artifactId>maven-checkstyle-plugin</artifactId>
|
||||||
<version>2.11</version>
|
<version>3.1.2</version>
|
||||||
<configuration>
|
|
||||||
<configLocation>${basedir}/src/main/config/checkstyle.xml</configLocation>
|
|
||||||
<encoding>UTF-8</encoding>
|
|
||||||
<linkXRef>false</linkXRef>
|
|
||||||
</configuration>
|
|
||||||
<reportSets>
|
<reportSets>
|
||||||
<reportSet>
|
<reportSet>
|
||||||
<reports>
|
<reports>
|
||||||
<report>checkstyle</report>
|
<report>checkstyle</report>
|
||||||
|
<report>checkstyle-aggregate</report>
|
||||||
</reports>
|
</reports>
|
||||||
</reportSet>
|
</reportSet>
|
||||||
</reportSets>
|
</reportSets>
|
||||||
@ -168,6 +180,7 @@
|
|||||||
</reporting>
|
</reporting>
|
||||||
<properties>
|
<properties>
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
|
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
|
||||||
<jetty.version>8.0.4.v20111024</jetty.version>
|
<jetty.version>8.0.4.v20111024</jetty.version>
|
||||||
<jetty.port>8080</jetty.port>
|
<jetty.port>8080</jetty.port>
|
||||||
<jetty.contextpath>/plantuml</jetty.contextpath>
|
<jetty.contextpath>/plantuml</jetty.contextpath>
|
||||||
|
@ -1,126 +1,117 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!DOCTYPE module PUBLIC "-//Puppy Crawl//DTD Check Configuration 1.3//EN" "http://www.puppycrawl.com/dtds/configuration_1_3.dtd">
|
<!DOCTYPE module PUBLIC "-//Puppy Crawl//DTD Check Configuration 1.3//EN" "http://www.puppycrawl.com/dtds/configuration_1_3.dtd">
|
||||||
|
|
||||||
<!--
|
|
||||||
This configuration file was written by the eclipse-cs plugin configuration editor
|
|
||||||
-->
|
|
||||||
<!--
|
|
||||||
Checkstyle-Configuration: checkstyle
|
|
||||||
Description: none
|
|
||||||
-->
|
|
||||||
<module name="Checker">
|
<module name="Checker">
|
||||||
<property name="severity" value="error"/>
|
<property name="charset" value="UTF-8" />
|
||||||
<property name="charset" value="UTF-8"/>
|
<property name="severity" value="error" />
|
||||||
<module name="TreeWalker">
|
<module name="FileLength" />
|
||||||
<module name="JavadocMethod">
|
<module name="FileTabCharacter">
|
||||||
<property name="severity" value="ignore"/>
|
<property name="eachLine" value="true" />
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="JavadocType">
|
|
||||||
<property name="severity" value="ignore"/>
|
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="JavadocVariable">
|
|
||||||
<property name="severity" value="ignore"/>
|
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="JavadocStyle">
|
|
||||||
<property name="severity" value="ignore"/>
|
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="ConstantName"/>
|
|
||||||
<module name="LocalFinalVariableName"/>
|
|
||||||
<module name="LocalVariableName"/>
|
|
||||||
<module name="MemberName"/>
|
|
||||||
<module name="MethodName"/>
|
|
||||||
<module name="PackageName"/>
|
|
||||||
<module name="ParameterName"/>
|
|
||||||
<module name="StaticVariableName"/>
|
|
||||||
<module name="TypeName"/>
|
|
||||||
<module name="AvoidStarImport"/>
|
|
||||||
<module name="IllegalImport"/>
|
|
||||||
<module name="RedundantImport"/>
|
|
||||||
<module name="UnusedImports"/>
|
|
||||||
<module name="LineLength">
|
|
||||||
<property name="max" value="120"/>
|
|
||||||
<property name="tabWidth" value="4"/>
|
|
||||||
</module>
|
|
||||||
<module name="MethodLength"/>
|
|
||||||
<module name="ParameterNumber"/>
|
|
||||||
<module name="EmptyForIteratorPad"/>
|
|
||||||
<module name="MethodParamPad"/>
|
|
||||||
<module name="NoWhitespaceAfter"/>
|
|
||||||
<module name="NoWhitespaceBefore"/>
|
|
||||||
<module name="OperatorWrap"/>
|
|
||||||
<module name="ParenPad"/>
|
|
||||||
<module name="TypecastParenPad"/>
|
|
||||||
<module name="WhitespaceAfter"/>
|
|
||||||
<module name="WhitespaceAround"/>
|
|
||||||
<module name="ModifierOrder">
|
|
||||||
<property name="severity" value="ignore"/>
|
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="RedundantModifier"/>
|
|
||||||
<module name="AvoidNestedBlocks"/>
|
|
||||||
<module name="EmptyBlock">
|
|
||||||
<property name="severity" value="ignore"/>
|
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="LeftCurly"/>
|
|
||||||
<module name="NeedBraces"/>
|
|
||||||
<module name="RightCurly"/>
|
|
||||||
<module name="AvoidInlineConditionals">
|
|
||||||
<property name="severity" value="ignore"/>
|
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="EmptyStatement"/>
|
|
||||||
<module name="EqualsHashCode"/>
|
|
||||||
<module name="HiddenField"/>
|
|
||||||
<module name="IllegalInstantiation"/>
|
|
||||||
<module name="InnerAssignment"/>
|
|
||||||
<module name="MagicNumber">
|
|
||||||
<property name="severity" value="ignore"/>
|
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="MissingSwitchDefault"/>
|
|
||||||
<module name="RedundantThrows"/>
|
|
||||||
<module name="SimplifyBooleanExpression">
|
|
||||||
<property name="severity" value="ignore"/>
|
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="SimplifyBooleanReturn"/>
|
|
||||||
<module name="DesignForExtension">
|
|
||||||
<property name="severity" value="ignore"/>
|
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="FinalClass"/>
|
|
||||||
<module name="HideUtilityClassConstructor"/>
|
|
||||||
<module name="InterfaceIsType"/>
|
|
||||||
<module name="VisibilityModifier"/>
|
|
||||||
<module name="ArrayTypeStyle"/>
|
|
||||||
<module name="FinalParameters">
|
|
||||||
<property name="severity" value="ignore"/>
|
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
|
||||||
</module>
|
|
||||||
<module name="TodoComment"/>
|
|
||||||
<module name="UpperEll"/>
|
|
||||||
</module>
|
</module>
|
||||||
<module name="JavadocPackage">
|
<module name="JavadocPackage">
|
||||||
<property name="severity" value="ignore"/>
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
<property name="allowLegacy" value="true"/>
|
<property name="allowLegacy" value="true" />
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="LineLength">
|
||||||
|
<property name="max" value="120" />
|
||||||
|
<property name="tabWidth" value="4" />
|
||||||
</module>
|
</module>
|
||||||
<module name="NewlineAtEndOfFile">
|
<module name="NewlineAtEndOfFile">
|
||||||
<property name="severity" value="ignore"/>
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit"/>
|
<property name="severity" value="ignore" />
|
||||||
</module>
|
|
||||||
<module name="Translation"/>
|
|
||||||
<module name="FileLength"/>
|
|
||||||
<module name="FileTabCharacter">
|
|
||||||
<property name="eachLine" value="true"/>
|
|
||||||
</module>
|
</module>
|
||||||
<module name="RegexpSingleline">
|
<module name="RegexpSingleline">
|
||||||
<property name="format" value="\s+$"/>
|
<property name="format" value="\s+$" />
|
||||||
<property name="message" value="Line has trailing spaces."/>
|
<property name="message" value="Line has trailing spaces." />
|
||||||
|
</module>
|
||||||
|
<module name="Translation" />
|
||||||
|
<module name="TreeWalker">
|
||||||
|
<module name="ArrayTypeStyle" />
|
||||||
|
<module name="AvoidInlineConditionals">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="AvoidNestedBlocks" />
|
||||||
|
<module name="AvoidStarImport" />
|
||||||
|
<module name="ConstantName" />
|
||||||
|
<module name="DesignForExtension">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="EmptyBlock">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="EmptyForIteratorPad" />
|
||||||
|
<module name="EmptyStatement" />
|
||||||
|
<module name="EqualsHashCode" />
|
||||||
|
<module name="FinalClass" />
|
||||||
|
<module name="FinalParameters">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="HiddenField" />
|
||||||
|
<module name="HideUtilityClassConstructor" />
|
||||||
|
<module name="IllegalImport" />
|
||||||
|
<module name="IllegalInstantiation" />
|
||||||
|
<module name="InnerAssignment" />
|
||||||
|
<module name="InterfaceIsType" />
|
||||||
|
<module name="JavadocMethod">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="JavadocStyle">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="JavadocType">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="JavadocVariable">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="LeftCurly" />
|
||||||
|
<module name="LocalFinalVariableName" />
|
||||||
|
<module name="LocalVariableName" />
|
||||||
|
<module name="MagicNumber">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="MemberName" />
|
||||||
|
<module name="MethodLength" />
|
||||||
|
<module name="MethodName" />
|
||||||
|
<module name="MethodParamPad" />
|
||||||
|
<module name="MissingSwitchDefault" />
|
||||||
|
<module name="ModifierOrder">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="NeedBraces" />
|
||||||
|
<module name="NoWhitespaceAfter" />
|
||||||
|
<module name="NoWhitespaceBefore" />
|
||||||
|
<module name="OperatorWrap" />
|
||||||
|
<module name="PackageName" />
|
||||||
|
<module name="ParameterName" />
|
||||||
|
<module name="ParameterNumber" />
|
||||||
|
<module name="ParenPad" />
|
||||||
|
<module name="RedundantImport" />
|
||||||
|
<module name="RedundantModifier" />
|
||||||
|
<module name="RightCurly" />
|
||||||
|
<module name="SimplifyBooleanExpression">
|
||||||
|
<metadata name="net.sf.eclipsecs.core.lastEnabledSeverity" value="inherit" />
|
||||||
|
<property name="severity" value="ignore" />
|
||||||
|
</module>
|
||||||
|
<module name="SimplifyBooleanReturn" />
|
||||||
|
<module name="StaticVariableName" />
|
||||||
|
<module name="TodoComment" />
|
||||||
|
<module name="TypecastParenPad" />
|
||||||
|
<module name="TypeName" />
|
||||||
|
<module name="UnusedImports" />
|
||||||
|
<module name="UpperEll" />
|
||||||
|
<module name="VisibilityModifier" />
|
||||||
|
<module name="WhitespaceAfter" />
|
||||||
|
<module name="WhitespaceAround" />
|
||||||
</module>
|
</module>
|
||||||
</module>
|
</module>
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -25,13 +25,19 @@ package net.sourceforge.plantuml.servlet;
|
|||||||
|
|
||||||
import net.sourceforge.plantuml.FileFormat;
|
import net.sourceforge.plantuml.FileFormat;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* ASCII servlet of the webapp.
|
* ASCII servlet of the webapp.
|
||||||
* This servlet produces the UML sequence diagram in text format.
|
* This servlet produces the UML sequence diagram in text format.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class AsciiServlet extends UmlDiagramService {
|
public class AsciiServlet extends UmlDiagramService {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gives the wished output format of the diagram.
|
||||||
|
* This value is used by the DiagramResponse class.
|
||||||
|
*
|
||||||
|
* @return the format for ASCII responses
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
public FileFormat getOutputFormat() {
|
public FileFormat getOutputFormat() {
|
||||||
return FileFormat.UTXT;
|
return FileFormat.UTXT;
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -25,13 +25,19 @@ package net.sourceforge.plantuml.servlet;
|
|||||||
|
|
||||||
import net.sourceforge.plantuml.FileFormat;
|
import net.sourceforge.plantuml.FileFormat;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Base64 servlet of the webapp.
|
* Base64 servlet of the webapp.
|
||||||
* This servlet produces the UML diagram in Base64 format.
|
* This servlet produces the UML diagram in Base64 format.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class Base64Servlet extends UmlDiagramService {
|
public class Base64Servlet extends UmlDiagramService {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gives the wished output format of the diagram.
|
||||||
|
* This value is used by the DiagramResponse class.
|
||||||
|
*
|
||||||
|
* @return the format for Base64 responses
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
public FileFormat getOutputFormat() {
|
public FileFormat getOutputFormat() {
|
||||||
return FileFormat.BASE64;
|
return FileFormat.BASE64;
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -32,14 +32,13 @@ import javax.servlet.http.HttpServletRequest;
|
|||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
import net.sourceforge.plantuml.FileFormat;
|
import net.sourceforge.plantuml.FileFormat;
|
||||||
|
|
||||||
import net.sourceforge.plantuml.servlet.utility.UmlExtractor;
|
import net.sourceforge.plantuml.servlet.utility.UmlExtractor;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Check servlet of the webapp.
|
* Check servlet of the webapp.
|
||||||
* This servlet checks the syntax of the diagram and send a report in TEXT format.
|
* This servlet checks the syntax of the diagram and send a report in TEXT format.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class CheckSyntaxServlet extends HttpServlet {
|
public class CheckSyntaxServlet extends HttpServlet {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -52,12 +51,19 @@ public class CheckSyntaxServlet extends HttpServlet {
|
|||||||
DiagramResponse dr = new DiagramResponse(response, getOutputFormat(), request);
|
DiagramResponse dr = new DiagramResponse(response, getOutputFormat(), request);
|
||||||
try {
|
try {
|
||||||
dr.sendCheck(uml);
|
dr.sendCheck(uml);
|
||||||
} catch (IIOException iioe) {
|
} catch (IIOException e) {
|
||||||
// Browser has closed the connection, do nothing
|
// Browser has closed the connection, do nothing
|
||||||
}
|
}
|
||||||
dr = null;
|
dr = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Extract UML source from URI.
|
||||||
|
*
|
||||||
|
* @param uri the complete URI as returned by `request.getRequestURI()`
|
||||||
|
*
|
||||||
|
* @return the encoded UML text
|
||||||
|
*/
|
||||||
public String getSource(String uri) {
|
public String getSource(String uri) {
|
||||||
String[] result = uri.split("/check/", 2);
|
String[] result = uri.split("/check/", 2);
|
||||||
if (result.length != 2) {
|
if (result.length != 2) {
|
||||||
@ -67,6 +73,12 @@ public class CheckSyntaxServlet extends HttpServlet {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gives the wished output format of the diagram.
|
||||||
|
* This value is used by the DiagramResponse class.
|
||||||
|
*
|
||||||
|
* @return the format for check responses
|
||||||
|
*/
|
||||||
public FileFormat getOutputFormat() {
|
public FileFormat getOutputFormat() {
|
||||||
return FileFormat.UTXT;
|
return FileFormat.UTXT;
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -53,7 +53,7 @@ import net.sourceforge.plantuml.ErrorUml;
|
|||||||
* Delegates the diagram generation from the UML source and the filling of the HTTP response with the diagram in the
|
* Delegates the diagram generation from the UML source and the filling of the HTTP response with the diagram in the
|
||||||
* right format. Its own responsibility is to produce the right HTTP headers.
|
* right format. Its own responsibility is to produce the right HTTP headers.
|
||||||
*/
|
*/
|
||||||
class DiagramResponse {
|
public class DiagramResponse {
|
||||||
|
|
||||||
private static final String POWERED_BY = "PlantUML Version " + Version.versionString();
|
private static final String POWERED_BY = "PlantUML Version " + Version.versionString();
|
||||||
|
|
||||||
@ -77,22 +77,24 @@ class DiagramResponse {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
DiagramResponse(HttpServletResponse r, FileFormat f, HttpServletRequest rq) {
|
public DiagramResponse(HttpServletResponse r, FileFormat f, HttpServletRequest rq) {
|
||||||
response = r;
|
response = r;
|
||||||
format = f;
|
format = f;
|
||||||
request = rq;
|
request = rq;
|
||||||
}
|
}
|
||||||
|
|
||||||
void sendDiagram(String uml, int idx) throws IOException {
|
public void sendDiagram(String uml, int idx) throws IOException {
|
||||||
response.addHeader("Access-Control-Allow-Origin", "*");
|
response.addHeader("Access-Control-Allow-Origin", "*");
|
||||||
response.setContentType(getContentType());
|
response.setContentType(getContentType());
|
||||||
SourceStringReader reader = new SourceStringReader(uml);
|
SourceStringReader reader = new SourceStringReader(uml);
|
||||||
if (format == FileFormat.BASE64) {
|
if (format == FileFormat.BASE64) {
|
||||||
final ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
byte[] imageBytes;
|
||||||
final DiagramDescription result = reader.outputImage(baos, idx, new FileFormatOption(FileFormat.PNG));
|
try (ByteArrayOutputStream outstream = new ByteArrayOutputStream()) {
|
||||||
baos.close();
|
reader.outputImage(outstream, idx, new FileFormatOption(FileFormat.PNG));
|
||||||
final String encodedBytes = "data:image/png;base64,"
|
imageBytes = outstream.toByteArray();
|
||||||
+ Base64Coder.encodeLines(baos.toByteArray()).replaceAll("\\s", "");
|
}
|
||||||
|
final String base64 = Base64Coder.encodeLines(imageBytes).replaceAll("\\s", "");
|
||||||
|
final String encodedBytes = "data:image/png;base64," + base64;
|
||||||
response.getOutputStream().write(encodedBytes.getBytes());
|
response.getOutputStream().write(encodedBytes.getBytes());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -109,7 +111,7 @@ class DiagramResponse {
|
|||||||
if (diagram instanceof PSystemError) {
|
if (diagram instanceof PSystemError) {
|
||||||
response.setStatus(HttpServletResponse.SC_BAD_REQUEST);
|
response.setStatus(HttpServletResponse.SC_BAD_REQUEST);
|
||||||
}
|
}
|
||||||
final ImageData result = diagram.exportDiagram(response.getOutputStream(), idx, new FileFormatOption(format));
|
diagram.exportDiagram(response.getOutputStream(), idx, new FileFormatOption(format));
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean notModified(BlockUml blockUml) {
|
private boolean notModified(BlockUml blockUml) {
|
||||||
@ -126,7 +128,7 @@ class DiagramResponse {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void sendMap(String uml) throws IOException {
|
public void sendMap(String uml) throws IOException {
|
||||||
response.setContentType(getContentType());
|
response.setContentType(getContentType());
|
||||||
SourceStringReader reader = new SourceStringReader(uml);
|
SourceStringReader reader = new SourceStringReader(uml);
|
||||||
final BlockUml blockUml = reader.getBlocks().get(0);
|
final BlockUml blockUml = reader.getBlocks().get(0);
|
||||||
@ -141,16 +143,17 @@ class DiagramResponse {
|
|||||||
final String cmap = map.getCMapData("plantuml");
|
final String cmap = map.getCMapData("plantuml");
|
||||||
httpOut.print(cmap);
|
httpOut.print(cmap);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void sendCheck(String uml) throws IOException {
|
public void sendCheck(String uml) throws IOException {
|
||||||
response.setContentType(getContentType());
|
response.setContentType(getContentType());
|
||||||
SourceStringReader reader = new SourceStringReader(uml);
|
SourceStringReader reader = new SourceStringReader(uml);
|
||||||
DiagramDescription desc = reader.outputImage(
|
DiagramDescription desc = reader.outputImage(
|
||||||
new NullOutputStream(), new FileFormatOption(FileFormat.PNG, false));
|
new NullOutputStream(), new FileFormatOption(FileFormat.PNG, false));
|
||||||
PrintWriter httpOut = response.getWriter();
|
PrintWriter httpOut = response.getWriter();
|
||||||
httpOut.print(desc.getDescription());
|
httpOut.print(desc.getDescription());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addHeaderForCache(BlockUml blockUml) {
|
private void addHeaderForCache(BlockUml blockUml) {
|
||||||
long today = System.currentTimeMillis();
|
long today = System.currentTimeMillis();
|
||||||
// Add http headers to force the browser to cache the image
|
// Add http headers to force the browser to cache the image
|
||||||
@ -176,11 +179,10 @@ class DiagramResponse {
|
|||||||
|
|
||||||
public static void addHeaders(HttpServletResponse response) {
|
public static void addHeaders(HttpServletResponse response) {
|
||||||
response.addHeader("X-Powered-By", POWERED_BY);
|
response.addHeader("X-Powered-By", POWERED_BY);
|
||||||
response.addHeader("X-Patreon", "Support us on http://plantuml.com/patreon");
|
response.addHeader("X-Patreon", "Support us on https://plantuml.com/patreon");
|
||||||
response.addHeader("X-Donate", "http://plantuml.com/paypal");
|
response.addHeader("X-Donate", "https://plantuml.com/paypal");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private String getContentType() {
|
private String getContentType() {
|
||||||
return CONTENT_TYPE.get(format);
|
return CONTENT_TYPE.get(format);
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -25,13 +25,19 @@ package net.sourceforge.plantuml.servlet;
|
|||||||
|
|
||||||
import net.sourceforge.plantuml.FileFormat;
|
import net.sourceforge.plantuml.FileFormat;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* EPS servlet of the webapp.
|
* EPS servlet of the webapp.
|
||||||
* This servlet produces the UML diagram in EPS format.
|
* This servlet produces the UML diagram in EPS format.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class EpsServlet extends UmlDiagramService {
|
public class EpsServlet extends UmlDiagramService {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gives the wished output format of the diagram.
|
||||||
|
* This value is used by the DiagramResponse class.
|
||||||
|
*
|
||||||
|
* @return the format for EPS responses
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
public FileFormat getOutputFormat() {
|
public FileFormat getOutputFormat() {
|
||||||
return FileFormat.EPS;
|
return FileFormat.EPS;
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -25,13 +25,19 @@ package net.sourceforge.plantuml.servlet;
|
|||||||
|
|
||||||
import net.sourceforge.plantuml.FileFormat;
|
import net.sourceforge.plantuml.FileFormat;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* EPS servlet of the webapp.
|
* EPS Text servlet of the webapp.
|
||||||
* This servlet produces the UML diagram in EPS format.
|
* This servlet produces the UML diagram in EPS Text format.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class EpsTextServlet extends UmlDiagramService {
|
public class EpsTextServlet extends UmlDiagramService {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gives the wished output format of the diagram.
|
||||||
|
* This value is used by the DiagramResponse class.
|
||||||
|
*
|
||||||
|
* @return the format for EPS Text responses
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
public FileFormat getOutputFormat() {
|
public FileFormat getOutputFormat() {
|
||||||
return FileFormat.EPS_TEXT;
|
return FileFormat.EPS_TEXT;
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -25,13 +25,19 @@ package net.sourceforge.plantuml.servlet;
|
|||||||
|
|
||||||
import net.sourceforge.plantuml.FileFormat;
|
import net.sourceforge.plantuml.FileFormat;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Image servlet of the webapp.
|
* Image servlet of the webapp.
|
||||||
* This servlet produces the UML diagram in PNG format.
|
* This servlet produces the UML diagram in PNG format.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class ImgServlet extends UmlDiagramService {
|
public class ImgServlet extends UmlDiagramService {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gives the wished output format of the diagram.
|
||||||
|
* This value is used by the DiagramResponse class.
|
||||||
|
*
|
||||||
|
* @return the format for image responses
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
public FileFormat getOutputFormat() {
|
public FileFormat getOutputFormat() {
|
||||||
return FileFormat.PNG;
|
return FileFormat.PNG;
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -35,11 +35,11 @@ import net.sourceforge.plantuml.FileFormat;
|
|||||||
|
|
||||||
import net.sourceforge.plantuml.servlet.utility.UmlExtractor;
|
import net.sourceforge.plantuml.servlet.utility.UmlExtractor;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* MAP servlet of the webapp.
|
* MAP servlet of the webapp.
|
||||||
* This servlet produces the image map of the diagram in HTML format.
|
* This servlet produces the image map of the diagram in HTML format.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class MapServlet extends HttpServlet {
|
public class MapServlet extends HttpServlet {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -52,7 +52,7 @@ public class MapServlet extends HttpServlet {
|
|||||||
DiagramResponse dr = new DiagramResponse(response, getOutputFormat(), request);
|
DiagramResponse dr = new DiagramResponse(response, getOutputFormat(), request);
|
||||||
try {
|
try {
|
||||||
dr.sendMap(uml);
|
dr.sendMap(uml);
|
||||||
} catch (IIOException iioe) {
|
} catch (IIOException e) {
|
||||||
// Browser has closed the connection, do nothing
|
// Browser has closed the connection, do nothing
|
||||||
}
|
}
|
||||||
dr = null;
|
dr = null;
|
||||||
@ -67,6 +67,12 @@ public class MapServlet extends HttpServlet {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gives the wished output format of the diagram.
|
||||||
|
* This value is used by the DiagramResponse class.
|
||||||
|
*
|
||||||
|
* @return the format for map responses
|
||||||
|
*/
|
||||||
public FileFormat getOutputFormat() {
|
public FileFormat getOutputFormat() {
|
||||||
return FileFormat.UTXT;
|
return FileFormat.UTXT;
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -40,12 +40,12 @@ import net.sourceforge.plantuml.FileFormat;
|
|||||||
import net.sourceforge.plantuml.FileFormatOption;
|
import net.sourceforge.plantuml.FileFormatOption;
|
||||||
import net.sourceforge.plantuml.SourceStringReader;
|
import net.sourceforge.plantuml.SourceStringReader;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Proxy servlet of the webapp.
|
* Proxy servlet of the webapp.
|
||||||
* This servlet retrieves the diagram source of a web resource (web html page)
|
* This servlet retrieves the diagram source of a web resource (web html page)
|
||||||
* and renders it.
|
* and renders it.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class OldProxyServlet extends HttpServlet {
|
public class OldProxyServlet extends HttpServlet {
|
||||||
|
|
||||||
private static final Pattern PROXY_PATTERN = Pattern.compile("/\\w+/proxy/((\\d+)/)?((\\w+)/)?(https?://.*)");
|
private static final Pattern PROXY_PATTERN = Pattern.compile("/\\w+/proxy/((\\d+)/)?((\\w+)/)?(https?://.*)");
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -43,9 +43,8 @@ import net.sourceforge.plantuml.code.Transcoder;
|
|||||||
import net.sourceforge.plantuml.code.TranscoderUtil;
|
import net.sourceforge.plantuml.code.TranscoderUtil;
|
||||||
import net.sourceforge.plantuml.png.MetadataTag;
|
import net.sourceforge.plantuml.png.MetadataTag;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Original idea from Achim Abeling for Confluence macro
|
* Original idea from Achim Abeling for Confluence macro
|
||||||
* See http://www.banapple.de/display/BANAPPLE/plantuml+user+macro
|
|
||||||
*
|
*
|
||||||
* This class is the old all-in-one historic implementation of the PlantUml server.
|
* This class is the old all-in-one historic implementation of the PlantUml server.
|
||||||
* See package.html for the new design. It's a work in progress.
|
* See package.html for the new design. It's a work in progress.
|
||||||
@ -53,17 +52,16 @@ import net.sourceforge.plantuml.png.MetadataTag;
|
|||||||
* Modified by Arnaud Roques
|
* Modified by Arnaud Roques
|
||||||
* Modified by Pablo Lalloni
|
* Modified by Pablo Lalloni
|
||||||
* Modified by Maxime Sinclair
|
* Modified by Maxime Sinclair
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class PlantUmlServlet extends HttpServlet {
|
public class PlantUmlServlet extends HttpServlet {
|
||||||
|
|
||||||
private static final String DEFAULT_ENCODED_TEXT = "SyfFKj2rKt3CoKnELR1Io4ZDoSa70000";
|
private static final String DEFAULT_ENCODED_TEXT = "SyfFKj2rKt3CoKnELR1Io4ZDoSa70000";
|
||||||
|
|
||||||
// Last part of the URL
|
// Last part of the URL
|
||||||
public static final Pattern URL_PATTERN = Pattern.compile("^.*[^a-zA-Z0-9\\-\\_]([a-zA-Z0-9\\-\\_]+)");
|
public static final Pattern URL_PATTERN = Pattern.compile("^.*[^a-zA-Z0-9\\-\\_]([a-zA-Z0-9\\-\\_]+)");
|
||||||
|
|
||||||
private static final Pattern RECOVER_UML_PATTERN = Pattern.compile("/uml/(.*)");
|
private static final Pattern RECOVER_UML_PATTERN = Pattern.compile("/uml/(.*)");
|
||||||
|
|
||||||
static {
|
static {
|
||||||
OptionFlags.ALLOW_INCLUDE = false;
|
OptionFlags.ALLOW_INCLUDE = false;
|
||||||
if ("true".equalsIgnoreCase(System.getenv("ALLOW_PLANTUML_INCLUDE"))) {
|
if ("true".equalsIgnoreCase(System.getenv("ALLOW_PLANTUML_INCLUDE"))) {
|
||||||
@ -112,10 +110,10 @@ public class PlantUmlServlet extends HttpServlet {
|
|||||||
if (text != null && PlantumlUtils.hasCMapData(text)) {
|
if (text != null && PlantumlUtils.hasCMapData(text)) {
|
||||||
request.setAttribute("mapneeded", Boolean.TRUE);
|
request.setAttribute("mapneeded", Boolean.TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// forward to index.jsp
|
// forward to index.jsp
|
||||||
final RequestDispatcher dispatcher = request.getRequestDispatcher("/index.jsp");
|
final RequestDispatcher dispatcher = request.getRequestDispatcher("/index.jsp");
|
||||||
dispatcher.forward(request, response);
|
dispatcher.forward(request, response);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -189,6 +187,4 @@ public class PlantUmlServlet extends HttpServlet {
|
|||||||
return is;
|
return is;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -49,12 +49,12 @@ import javax.imageio.IIOException;
|
|||||||
import javax.net.ssl.HttpsURLConnection;
|
import javax.net.ssl.HttpsURLConnection;
|
||||||
import javax.net.ssl.SSLPeerUnverifiedException;
|
import javax.net.ssl.SSLPeerUnverifiedException;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Proxy servlet of the webapp.
|
* Proxy servlet of the webapp.
|
||||||
* This servlet retrieves the diagram source of a web resource (web html page)
|
* This servlet retrieves the diagram source of a web resource (web html page)
|
||||||
* and renders it.
|
* and renders it.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class ProxyServlet extends HttpServlet {
|
public class ProxyServlet extends HttpServlet {
|
||||||
|
|
||||||
static {
|
static {
|
||||||
@ -95,7 +95,7 @@ public class ProxyServlet extends HttpServlet {
|
|||||||
DiagramResponse dr = new DiagramResponse(response, getOutputFormat(fmt), request);
|
DiagramResponse dr = new DiagramResponse(response, getOutputFormat(fmt), request);
|
||||||
try {
|
try {
|
||||||
dr.sendDiagram(uml, 0);
|
dr.sendDiagram(uml, 0);
|
||||||
} catch (IIOException iioe) {
|
} catch (IIOException e) {
|
||||||
// Browser has closed the connection, so the HTTP OutputStream is closed
|
// Browser has closed the connection, so the HTTP OutputStream is closed
|
||||||
// Silently catch the exception to avoid annoying log
|
// Silently catch the exception to avoid annoying log
|
||||||
}
|
}
|
||||||
@ -145,9 +145,9 @@ public class ProxyServlet extends HttpServlet {
|
|||||||
|
|
||||||
private HttpURLConnection getConnection(final URL url) throws IOException {
|
private HttpURLConnection getConnection(final URL url) throws IOException {
|
||||||
final HttpURLConnection con = (HttpURLConnection) url.openConnection();
|
final HttpURLConnection con = (HttpURLConnection) url.openConnection();
|
||||||
if (con instanceof HttpsURLConnection) {
|
//if (con instanceof HttpsURLConnection) {
|
||||||
// printHttpsCert((HttpsURLConnection) con);
|
// printHttpsCert((HttpsURLConnection) con);
|
||||||
}
|
//}
|
||||||
con.setRequestMethod("GET");
|
con.setRequestMethod("GET");
|
||||||
String token = System.getenv("HTTP_AUTHORIZATION");
|
String token = System.getenv("HTTP_AUTHORIZATION");
|
||||||
if (token != null) {
|
if (token != null) {
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -25,13 +25,19 @@ package net.sourceforge.plantuml.servlet;
|
|||||||
|
|
||||||
import net.sourceforge.plantuml.FileFormat;
|
import net.sourceforge.plantuml.FileFormat;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* SVG servlet of the webapp.
|
* SVG servlet of the webapp.
|
||||||
* This servlet produces the UML diagram in SVG format.
|
* This servlet produces the UML diagram in SVG format.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class SvgServlet extends UmlDiagramService {
|
public class SvgServlet extends UmlDiagramService {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gives the wished output format of the diagram.
|
||||||
|
* This value is used by the DiagramResponse class.
|
||||||
|
*
|
||||||
|
* @return the format for svg responses
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
public FileFormat getOutputFormat() {
|
public FileFormat getOutputFormat() {
|
||||||
return FileFormat.SVG;
|
return FileFormat.SVG;
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -40,7 +40,7 @@ import java.util.regex.Pattern;
|
|||||||
/**
|
/**
|
||||||
* Common service servlet to produce diagram from compressed UML source contained in the end part of the requested URI.
|
* Common service servlet to produce diagram from compressed UML source contained in the end part of the requested URI.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public abstract class UmlDiagramService extends HttpServlet {
|
public abstract class UmlDiagramService extends HttpServlet {
|
||||||
|
|
||||||
static {
|
static {
|
||||||
@ -99,7 +99,7 @@ public abstract class UmlDiagramService extends HttpServlet {
|
|||||||
DiagramResponse dr = new DiagramResponse(response, getOutputFormat(), request);
|
DiagramResponse dr = new DiagramResponse(response, getOutputFormat(), request);
|
||||||
try {
|
try {
|
||||||
dr.sendDiagram(uml, idx);
|
dr.sendDiagram(uml, idx);
|
||||||
} catch (IIOException iioe) {
|
} catch (IIOException e) {
|
||||||
// Browser has closed the connection, so the HTTP OutputStream is closed
|
// Browser has closed the connection, so the HTTP OutputStream is closed
|
||||||
// Silently catch the exception to avoid annoying log
|
// Silently catch the exception to avoid annoying log
|
||||||
}
|
}
|
||||||
@ -109,11 +109,11 @@ public abstract class UmlDiagramService extends HttpServlet {
|
|||||||
private static final Pattern RECOVER_UML_PATTERN = Pattern.compile("/\\w+/(\\d+/)?(.*)");
|
private static final Pattern RECOVER_UML_PATTERN = Pattern.compile("/\\w+/(\\d+/)?(.*)");
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Extracts the compressed UML source from the HTTP URI.
|
* Extracts the UML source text and its index from the HTTP request.
|
||||||
*
|
*
|
||||||
* @param uri
|
* @param request http request
|
||||||
* the complete URI as returned by request.getRequestURI()
|
*
|
||||||
* @return the compressed UML source
|
* @return the UML source text and its index
|
||||||
*/
|
*/
|
||||||
public final String[] getSourceAndIdx(HttpServletRequest request) {
|
public final String[] getSourceAndIdx(HttpServletRequest request) {
|
||||||
final Matcher recoverUml = RECOVER_UML_PATTERN.matcher(
|
final Matcher recoverUml = RECOVER_UML_PATTERN.matcher(
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -31,11 +31,11 @@ import javax.servlet.http.HttpServlet;
|
|||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Welcome servlet of the webapp.
|
* Welcome servlet of the webapp.
|
||||||
* Displays the sample Bob and Alice sequence diagram.
|
* Displays the sample Bob and Alice sequence diagram.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("SERIAL")
|
||||||
public class Welcome extends HttpServlet {
|
public class Welcome extends HttpServlet {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,15 +1,21 @@
|
|||||||
<html>
|
<html>
|
||||||
<body>
|
<body>
|
||||||
<p>This package is in charge of the JEE PlantUml Server.</p>
|
<p>This package is in charge of the JEE PlantUml Server.</p>
|
||||||
<p>there are 2 kind of servlets in this package :<br>
|
<p>There are 2 kind of servlets in this package:<br>
|
||||||
- Interactive servlets : Welcome, PlantUmlServlet that are in charge of the web pages dedicated to human users.<br>
|
- Interactive servlets: Welcome, PlantUmlServlet that are in charge of the web pages dedicated to human users.<br>
|
||||||
- Service servlets : ImgServlet, SvgServlet, EpsServlet, EpsTextServlet, AsciiServlet, ProxyServlet that only produce a diagram as output.<br>
|
- Service servlets: ImgServlet, SvgServlet, EpsServlet, EpsTextServlet, AsciiServlet, ProxyServlet that only produce a diagram as output.<br>
|
||||||
<br>
|
<br>
|
||||||
Structure of the service part of the PlantUmlServer: <br>
|
Structure of the service part of the PlantUmlServer: <br>
|
||||||
<img src="http://www.plantuml.com/plantuml/img/XP51ReCm44Ntd6AMH0etwAPIbNPJjIhg0OoPm4WsTiPZrAZDtGk5913IP3b_dlx_7jTK8g3riWUBja0EIJsLf7RbJDeIcavHHH1MMa0R5G9yMlD4gc9bS-IMDC9t0k1ZOKX3wwY4qZsZf2yYlYSCoWVk8WO1tgrX9WVlce30mQywZrFGQ9OBKrD1XPAxo1hJenAPPlo636uSMoKz_1R5HndcT9KSag7tMFeKshU-qDBhxTRJW6sV_FVCW4qv6foRMJFRloe_tntEvvnamSDFbYqlUuFjZCVv1lJExcj_n9R_DZ1DTOV8stl4Oz14_pCkkpnqSgxVRPVhQV5hm2y0" />
|
<img
|
||||||
</p>
|
alt="Class diagram of the service part of the PlantUmlServer"
|
||||||
<p>
|
src="https://www.plantuml.com/plantuml/svg/XP31Ri8m44Jl_eez1Wd-e0SgLRGNrAfHFy3OIx1ansQzHaKj_zv4mKfCYZXwvcbclEl8aZWvAmv68w0BV0Q7ReSKIuaFNXVItg3j5BcBJ58nl3676kbaaKTHMHaZV3dxOcH3qlM0KGW_0Y2adJKAJjveqFuLkPf4VE8nOMIWun8AEGRVHWIAOI40Sb4EgvbCsq23NFj42gki9385lp4MDvwSv1v-JnmI3-zg8IvYs7qTdKlxrRTQzV-wvRHWtpKFtupOwcl0kCpPmj_AK7eNCQc0fz_L2hOol-VU1_dlStRdbn-Ojdb0rAT7n7DKnjnd_EhsL69StRbpEm-_2wonrSdPFm00"
|
||||||
<img src="http://www.plantuml.com/plantuml/img/XP1DZi8m38NtdCA23RFe0OfGLr24n4y5uW2cU2fBQL8vBeBRup8ZHEc2LPJtNhuNMraTmOey2Ie73-4N48hT2hZ6Ye2TQwEQHvTHuQiZoTMHGfB1ssq65Uanj5BIzESZTghTycQ0KeFy1KrvPNjkqgD-gTktshIQ1wbH1wKBnagmFb1iWezaB-RpKiYcoBAlqKZ-ygyQk45HBhb1hp0kd1sdxGOSdmNbFWQCiE4pJD8qpzDqz4cpWixkVlpSCAsxhHgsKvDX_H3G6_q1" />
|
>
|
||||||
</p>
|
</p>
|
||||||
|
<p>
|
||||||
|
<img
|
||||||
|
alt="Generation of a PNG image illustrated"
|
||||||
|
src="https://www.plantuml.com/plantuml/svg/XP1DZi8m38NtdCA23RFe0OfGLr24n4y5uW2cU2fBQL8vBeBRup8ZHEc2LPJtNhuNMraTmOey2Ie73-4N48hT2hZ6Ye2TQwEQHvTHuQiZoTMHGfB1ssq65Uanj5BIzESZTghTycQ0KeFy1KrvPNjkqgD-gTktshIQ1wbH1wKBnagmFb1iWezaB-RpKiYcoBAlqKZ-ygyQk45HBhb1hp0kd1sdxGOSdmNbFWQCiE4pJD8qpzDqz4cpWixkVlpSCAsxhHgsKvDX_H3G6_q1"
|
||||||
|
>
|
||||||
|
</p>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* PlantUML : a free UML diagram generator
|
* PlantUML : a free UML diagram generator
|
||||||
* ========================================================================
|
* ========================================================================
|
||||||
*
|
*
|
||||||
* Project Info: http://plantuml.sourceforge.net
|
* Project Info: https://plantuml.com
|
||||||
*
|
*
|
||||||
* This file is part of PlantUML.
|
* This file is part of PlantUML.
|
||||||
*
|
*
|
||||||
@ -45,14 +45,13 @@ public class UmlExtractor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Build the complete UML source from the compressed source extracted from the HTTP URI.
|
* Build the complete UML source from the compressed source extracted from the
|
||||||
|
* HTTP URI.
|
||||||
*
|
*
|
||||||
* @param source
|
* @param source the last part of the URI containing the compressed UML
|
||||||
* the last part of the URI containing the compressed UML
|
|
||||||
* @return the textual UML source
|
* @return the textual UML source
|
||||||
*/
|
*/
|
||||||
static public String getUmlSource(String source) {
|
static public String getUmlSource(String source) {
|
||||||
|
|
||||||
// build the UML source from the compressed part of the URL
|
// build the UML source from the compressed part of the URL
|
||||||
String text;
|
String text;
|
||||||
try {
|
try {
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
<html>
|
<html>
|
||||||
<body>
|
<body>
|
||||||
<p>This package contains utility classes of the JEE PlantUml Server.</p>
|
<p>This package contains utility classes of the JEE PlantUml Server.</p>
|
||||||
<ul>
|
<ul>
|
||||||
<li>NullOutputStream is used by the Map feature.</li>
|
<li>NullOutputStream is used by the Map feature.</li>
|
||||||
<li>UmlExtractor encapsulates the PlantUML library to decode the UML compressed source.</li>
|
<li>UmlExtractor encapsulates the PlantUML library to decode the UML compressed source.</li>
|
||||||
</ul>
|
</ul>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
@ -51,7 +51,7 @@
|
|||||||
<c:if test="${cfg['SHOW_GITHUB_RIBBON'] eq 'on' }">
|
<c:if test="${cfg['SHOW_GITHUB_RIBBON'] eq 'on' }">
|
||||||
<%@ include file="resource/githubribbon.html" %>
|
<%@ include file="resource/githubribbon.html" %>
|
||||||
</c:if>
|
</c:if>
|
||||||
<p>Create your <a href="http://plantuml.com">PlantUML</a> diagrams directly in your browser !</p>
|
<p>Create your <a href="https://plantuml.com">PlantUML</a> diagrams directly in your browser !</p>
|
||||||
</div>
|
</div>
|
||||||
<div id="content">
|
<div id="content">
|
||||||
<%-- CONTENT --%>
|
<%-- CONTENT --%>
|
||||||
|
Loading…
Reference in New Issue
Block a user