Migrate application to Maven

This commit migrates the `initializr-service` to a regular Maven project.

Closes gh-252
This commit is contained in:
Stephane Nicoll 2016-06-30 16:06:44 +02:00
parent 98a1049cec
commit 1fd8e2c047
10 changed files with 144 additions and 116 deletions

8
.gitignore vendored
View File

@ -13,12 +13,4 @@ build
target
.springBeans
tmp*
initializer-service/spring
grapes
spring.zip
repository/
*.jar
*.jar.orig
*.jar.original
.idea
*.iml

View File

@ -31,6 +31,10 @@ many environments (including embedded in your own project)
* `initializr-actuator`: optional module to provide statistics and metrics on project
generation
`initializr-service` is an additional module that represents the production instance that
is available at link:https://start.spring.io[]. It is not enabled by default but you can
enable the `full` profile in your IDE to easily run it locally.
== Supported interfaces
Spring Initializr can be used as follows:
@ -91,7 +95,7 @@ $ curl https://start.spring.io/starter.tgz -d dependencies=web,actuator \
-d language=groovy -d type=gradle-project -d baseDir=another-project | tar -xzvf -
----
NOTE: The `/starter.tgz` endpoint offers the same feature as `/starter.zip` but generates
NOTE: The `/starter.tgz` endpoint offers the same feature as `/starter.zip` but generates
a compressed tarball instead.
You could use this infrastructure to create your own client since the project is generated
@ -177,43 +181,7 @@ You may also want to <<run-app,run the default instance locally>>.
[[build]]
== Building from Source
You need Java (1.6 or better) and a bash-like shell.
If you are on a Mac and using http://brew.sh/[homebrew], all you need to do to install it is:
[indent=0]
----
$ brew tap pivotal/tap
$ brew install springboot
----
It will install `/usr/local/bin/spring`. You can jump right to <<run-app>>.
An alternative way to install the `spring` command line interface can be installed like this:
[indent=0]
----
$ curl start.spring.io/install.sh | bash
----
After running that command you should see a `spring` directory:
[indent=0]
----
$ ./spring/bin/spring --help
usage: spring [--help] [--version]
<command> [<args>]
...
----
You could add that `bin` directory to your `PATH` (the examples below
assume you did that).
If you don't have `curl` or `zip` you can probably get them (for
Windows users we recommend http://cygwin.org[cygwin]), or you can
download the http://start.spring.io/spring.zip[zip file] and unpack
it yourself.
You need Java (1.7 or better), Maven 3.2+ and a bash-like shell.
[[building]]
=== Building
@ -237,13 +205,13 @@ If you want to run the smoke tests using Geb, you need to enable the
[[run-app]]
=== Running the app locally
Once you have <<building, built the library>>, you can easily start the app using the `spring` command
from the `initializr-service` directory:
Once you have <<building, built the library>>, you can easily start the app as any other
Spring Boot app from the `initializr-service` directory:
[indent=0]
----
$ cd initializr-service
$ spring run app.groovy
$ mvn spring-boot:run
----
## Deploying to Cloud Foundry
@ -258,29 +226,23 @@ If you are on a Mac and using http://brew.sh/[homebrew], install the Cloud Found
Alternatively, download a suitable binary for your platform from
https://console.run.pivotal.io/tools[Pivotal Web Services].
An example Cloud Foundry `manifest.yml` file is provided. You should ensure that
the application name and URL (name and host values) are suitable for your environment
before running `cf push`.
You should ensure that the application name and URL (name and host values) are suitable for
your environment before running `cf push`.
You can jar up the app and make it executable in any environment.
Make sure first that the jar has been created:
[indent=0]
----
$ spring jar start.jar app.groovy
$ mvn package
----
Once the jar has been created, you can push the application:
[indent=0]
----
$ cf push start -p start.jar -n start-<space>
$ cf push your-initializr -p target/initializr-service-1.0.0.BUILD-SNAPSHOT
----
Where `<space>` is the name of the space. As a failsafe, and a
reminder to be explicit, the deployment will fail in production
without the `-n`. It is needed to select the route because there is a
manifest that defaults it to `start-development`.
== License
Spring Initializr is Open Source software released under the
http://www.apache.org/licenses/LICENSE-2.0.html[Apache 2.0 license].

View File

@ -1,39 +0,0 @@
package app
import java.util.concurrent.Executor
import org.springframework.context.annotation.Configuration
import org.springframework.scheduling.annotation.AsyncConfigurerSupport
import org.springframework.scheduling.annotation.EnableAsync
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor
import io.spring.initializr.web.project.LegacyStsController
@Grab('io.spring.initializr:initializr-actuator:1.0.0.BUILD-SNAPSHOT')
@Grab('io.spring.initializr:initializr-web:1.0.0.BUILD-SNAPSHOT')
@Grab('spring-boot-starter-web')
@Grab('spring-boot-starter-redis')
class InitializerService {
@Bean
@SuppressWarnings("deprecation")
LegacyStsController legacyStsController() {
new LegacyStsController()
}
@Configuration
@EnableAsync
static class AsyncConfiguration extends AsyncConfigurerSupport {
@Override
Executor getAsyncExecutor() {
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor()
executor.setCorePoolSize(1)
executor.setMaxPoolSize(5)
executor.setThreadNamePrefix("initializr-")
executor.initialize()
executor
}
}
}

View File

@ -1,10 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<include resource="org/springframework/boot/logging/logback/base.xml"/>
<!--logger name="org.springframework" level="DEBUG"/-->
<logger name="org.springframework.core.env" level="WARN"/>
<logger name="org.springframework.jndi" level="WARN"/>
</configuration>

View File

@ -1,7 +0,0 @@
---
applications:
- name: start
memory: 1024M
host: start-development
domain: cfapps.io
path: .

View File

@ -0,0 +1,49 @@
<?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"
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>
<parent>
<groupId>io.spring.initializr</groupId>
<artifactId>initializr</artifactId>
<version>1.0.0.BUILD-SNAPSHOT</version>
</parent>
<artifactId>initializr-service</artifactId>
<name>Spring Initializr :: Service</name>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>io.spring.initializr</groupId>
<artifactId>initializr-web</artifactId>
</dependency>
<dependency>
<groupId>io.spring.initializr</groupId>
<artifactId>initializr-actuator</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.codehaus.gmavenplus</groupId>
<artifactId>gmavenplus-plugin</artifactId>
</plugin>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>

View File

@ -0,0 +1,67 @@
/*
* Copyright 2012-2016 the original author or authors.
*
* 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 io.spring.initializr.service
import java.util.concurrent.Executor
import io.spring.initializr.web.project.LegacyStsController
import org.springframework.boot.SpringApplication
import org.springframework.boot.autoconfigure.SpringBootApplication
import org.springframework.context.annotation.Bean
import org.springframework.context.annotation.Configuration
import org.springframework.scheduling.annotation.AsyncConfigurerSupport
import org.springframework.scheduling.annotation.EnableAsync
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor
/**
* Initializr service application. Enables legacy STS support for older
* clients.
*
* @author Stephane Nicoll
* @since 1.0
*/
@SpringBootApplication
class InitializrService {
public static void main(String[] args) {
SpringApplication.run(InitializrService, args)
}
@Bean
@SuppressWarnings("deprecation")
LegacyStsController legacyStsController() {
new LegacyStsController()
}
@Configuration
@EnableAsync
static class AsyncConfiguration extends AsyncConfigurerSupport {
@Override
Executor getAsyncExecutor() {
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor()
executor.setCorePoolSize(1)
executor.setMaxPoolSize(5)
executor.setThreadNamePrefix("initializr-")
executor.initialize()
executor
}
}
}

View File

@ -6,6 +6,11 @@ info:
spring-boot:
version: 1.3.6.RELEASE
logging:
level:
org.springframework.core.env: warn
org.springframework.jndi: warn
server:
compression:
enabled: true

View File

@ -194,4 +194,13 @@
</pluginManagement>
</build>
<profiles>
<profile>
<id>full</id>
<modules>
<module>initializr-service</module>
</modules>
</profile>
</profiles>
</project>