commit 8669e8ad514a4dc4d33a2a275e1ca047d6f519e7 Author: ynn Date: Sun Mar 17 16:47:56 2019 +0100 Initial commit diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..9dad4ed --- /dev/null +++ b/.gitignore @@ -0,0 +1,237 @@ + +# Created by https://www.gitignore.io/api/osx,java,linux,maven,eclipse,intellij +# Edit at https://www.gitignore.io/?templates=osx,java,linux,maven,eclipse,intellij + +### Eclipse ### + +.metadata +bin/ +tmp/ +*.tmp +*.bak +*.swp +*~.nib +local.properties +.settings/ +.loadpath +.recommenders + +# External tool builders +.externalToolBuilders/ + +# Locally stored "Eclipse launch configurations" +*.launch + +# PyDev specific (Python IDE for Eclipse) +*.pydevproject + +# CDT-specific (C/C++ Development Tooling) +.cproject + +# CDT- autotools +.autotools + +# Java annotation processor (APT) +.factorypath + +# PDT-specific (PHP Development Tools) +.buildpath + +# sbteclipse plugin +.target + +# Tern plugin +.tern-project + +# TeXlipse plugin +.texlipse + +# STS (Spring Tool Suite) +.springBeans + +# Code Recommenders +.recommenders/ + +# Annotation Processing +.apt_generated/ + +# Scala IDE specific (Scala & Java development for Eclipse) +.cache-main +.scala_dependencies +.worksheet + +### Eclipse Patch ### +# Eclipse Core +.project + +# JDT-specific (Eclipse Java Development Tools) +.classpath + +# Annotation Processing +.apt_generated + +.sts4-cache/ + +### Intellij ### +# Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and WebStorm +# Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839 + +# User-specific stuff +.idea/**/workspace.xml +.idea/**/tasks.xml +.idea/**/usage.statistics.xml +.idea/**/dictionaries +.idea/**/shelf + +# Generated files +.idea/**/contentModel.xml + +# Sensitive or high-churn files +.idea/**/dataSources/ +.idea/**/dataSources.ids +.idea/**/dataSources.local.xml +.idea/**/sqlDataSources.xml +.idea/**/dynamic.xml +.idea/**/uiDesigner.xml +.idea/**/dbnavigator.xml + +# Gradle +.idea/**/gradle.xml +.idea/**/libraries + +# Gradle and Maven with auto-import +# When using Gradle or Maven with auto-import, you should exclude module files, +# since they will be recreated, and may cause churn. Uncomment if using +# auto-import. +# .idea/modules.xml +# .idea/*.iml +# .idea/modules + +# CMake +cmake-build-*/ + +# Mongo Explorer plugin +.idea/**/mongoSettings.xml + +# File-based project format +*.iws + +# IntelliJ +out/ + +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml + +# Cursive Clojure plugin +.idea/replstate.xml + +# Crashlytics plugin (for Android Studio and IntelliJ) +com_crashlytics_export_strings.xml +crashlytics.properties +crashlytics-build.properties +fabric.properties + +# Editor-based Rest Client +.idea/httpRequests + +# Android studio 3.1+ serialized cache file +.idea/caches/build_file_checksums.ser + +### Intellij Patch ### +# Comment Reason: https://github.com/joeblau/gitignore.io/issues/186#issuecomment-215987721 + +# *.iml +# modules.xml +# .idea/misc.xml +# *.ipr + +# Sonarlint plugin +.idea/sonarlint + +### Java ### +# Compiled class file +*.class + +# Log file +*.log + +# BlueJ files +*.ctxt + +# Mobile Tools for Java (J2ME) +.mtj.tmp/ + +# Package Files # +*.jar +*.war +*.nar +*.ear +*.zip +*.tar.gz +*.rar + +# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml +hs_err_pid* + +### Linux ### +*~ + +# temporary files which can be created if a process still has a handle open of a deleted file +.fuse_hidden* + +# KDE directory preferences +.directory + +# Linux trash folder which might appear on any partition or disk +.Trash-* + +# .nfs files are created when an open file is removed but is still being accessed +.nfs* + +### Maven ### +target/ +pom.xml.tag +pom.xml.releaseBackup +pom.xml.versionsBackup +pom.xml.next +release.properties +dependency-reduced-pom.xml +buildNumber.properties +.mvn/timing.properties +.mvn/wrapper/maven-wrapper.jar + +### OSX ### +# General +.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + +# Thumbnails +._* + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.Spotlight-V100 +.TemporaryItems +.Trashes +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + +# End of https://www.gitignore.io/api/osx,java,linux,maven,eclipse,intellij + +jetty-runner.jar +webapp-runner.jar diff --git a/README.md b/README.md new file mode 100644 index 0000000..ab8a62e --- /dev/null +++ b/README.md @@ -0,0 +1,74 @@ +# Squelette du TP + +## Utilisation + +Pour utiliser ce tp vous devez : + +1. le forker via le lien fork ci-dessus. +2. Votre repository doit être **privé**. Vous devez le partager avec votre encadrant de TP. +3. vous obtiendrez un nouveau lien : par exemple git@gitlab.istic.univ-rennes1.fr:monpseudo/.... +4. Dans le **workspace d'eclipse** faites `git clone git@gitlab.istic.univ-rennes1.fr:monpseudo/...` avec l'url précédente. +5. Ouvrez le workspace dans eclipse. +6. Utilisez Import> "Existing Maven Projects". +7. Selectionnez le projet et validez. + +Vous devriez avoir une version du projet dans votre propre compte gitlab. + +Vous pouvez le partager avec votre binome et l'encadrant de TP. + + +## Rapport + +Votre rapport doit être écrit ici en markdown. + +Vous trouverez la syntaxe de markdown ici : https://docs.gitlab.com/ee/user/markdown.html + +Placez vos images dans le répertoire images si nécessaire. + + + +## Faire des diagrammes + +En particulier vous pouvez utiliser [mermaid](https://mermaidjs.github.io/) : + + + +```mermaid +sequenceDiagram + participant Alice + participant Bob + Alice->John: Hello John, how are you? + loop Healthcheck + John->John: Fight against hypochondria + end + Note right of John: Rational thoughts
prevail... + John-->Alice: Great! + John->Bob: How about you? + Bob-->John: Jolly good! +``` + +## Insérer du code + +Insérer du `code` : + +```java +public interface ClientHandler { + public void handle(); +} +``` + +et des résultats : + +```bash +[yo@capybara dkgr]$ nc google.fr 80 +PWET / +HTTP/1.0 400 Bad Request +Content-Type: text/html; charset=UTF-8 +Referrer-Policy: no-referrer +Content-Length: 1555 +Date: Mon, 21 Jan 2019 12:18:02 GMT + + + + +``` diff --git a/jetty-runner.sh b/jetty-runner.sh new file mode 100755 index 0000000..ed00e31 --- /dev/null +++ b/jetty-runner.sh @@ -0,0 +1,10 @@ +#!/bin/bash + +# Téléchargement du runner jetty (https://www.eclipse.org/jetty/documentation/9.4.x/runner.html) +wget -O jetty-runner.jar -c http://central.maven.org/maven2/org/eclipse/jetty/jetty-runner/9.4.15.v20190215/jetty-runner-9.4.15.v20190215.jar + +# Compilation du war dans target +mvn package + +# Lancement du projet (à adapter si le jar change) +java -jar jetty-runner.jar target/pr.tp.services-0.0.1-SNAPSHOT.war \ No newline at end of file diff --git a/pom.xml b/pom.xml new file mode 100644 index 0000000..dffeda1 --- /dev/null +++ b/pom.xml @@ -0,0 +1,96 @@ + + 4.0.0 + fr.istic.pr + pr.tp.services + 0.0.1-SNAPSHOT + war + + + UTF-8 + 8 + 8 + 2.28 + 2.9.6 + + + + + + org.glassfish.jersey + jersey-bom + ${jersey.version} + pom + import + + + + + + + + + + javax.servlet + javax.servlet-api + 4.0.1 + provided + + + + + org.glassfish.jersey.containers + jersey-container-servlet + + + org.glassfish.jersey.core + jersey-common + + + org.glassfish.jersey.media + jersey-media-moxy + + + org.glassfish.jersey.inject + jersey-hk2 + + + org.glassfish.jersey.media + jersey-media-multipart + + + org.glassfish.jersey.media + jersey-media-json-processing + + + org.glassfish.jersey.media + jersey-media-sse + + + + + + javax.xml.bind + jaxb-api + 2.2.11 + + + com.sun.xml.bind + jaxb-core + 2.2.11 + + + com.sun.xml.bind + jaxb-impl + 2.2.11 + + + javax.activation + activation + 1.1.1 + + + + + \ No newline at end of file diff --git a/src/main/java/fr/istic/rest/Hello.java b/src/main/java/fr/istic/rest/Hello.java new file mode 100644 index 0000000..357ee9d --- /dev/null +++ b/src/main/java/fr/istic/rest/Hello.java @@ -0,0 +1,28 @@ +package fr.istic.rest; + +import javax.ws.rs.GET; +import javax.ws.rs.Path; +import javax.ws.rs.PathParam; +import javax.ws.rs.Produces; +import javax.ws.rs.core.MediaType; +import javax.xml.bind.annotation.XmlRootElement; + +@Path("/hello") +public class Hello { + + @XmlRootElement + public static class Message { + public String name; + public String greetings; + } + + @Path("/{name}") + @GET + @Produces(MediaType.APPLICATION_JSON) + public Message getDescription(@PathParam("name") String name) { + Message m = new Message(); + m.name = name; + m.greetings = "Hello"; + return m; + } +} \ No newline at end of file diff --git a/src/main/java/fr/istic/servlet/HelloServlet.java b/src/main/java/fr/istic/servlet/HelloServlet.java new file mode 100644 index 0000000..8247cdd --- /dev/null +++ b/src/main/java/fr/istic/servlet/HelloServlet.java @@ -0,0 +1,51 @@ +package fr.istic.servlet; + +import java.io.IOException; +import java.io.PrintWriter; + +import javax.servlet.ServletException; +import javax.servlet.annotation.WebServlet; +import javax.servlet.http.HttpServlet; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import javax.ws.rs.client.Client; +import javax.ws.rs.client.ClientBuilder; +import javax.ws.rs.core.MediaType; +import javax.xml.bind.annotation.XmlRootElement; + +@WebServlet("/client") +public class HelloServlet extends HttpServlet { + + // TODO : Adapter l'URL en fonction de votre resource (si vous utilisez un + // runner par exemple) + public static final String URL = "http://localhost:8080/pr.tp.services/api"; + + @XmlRootElement(name = "message") + public static class SomeMessage { + public String name; + public String greetings; + } + + @Override + protected void doGet(HttpServletRequest req, HttpServletResponse resp) + throws ServletException, IOException { + + // Ceci n'est utile que pour JAXB 2.3.1 et disparaitra plus tard : + System.setProperty("com.sun.xml.bind.v2.bytecode.ClassTailor.noOptimize", + "true"); + + PrintWriter out = resp.getWriter(); + resp.setContentType("text/plain"); + try { + Client client = ClientBuilder.newClient(); + String name = "Toto"; + SomeMessage serverResponse = client.target(URL).path("hello").path(name) + .request(MediaType.APPLICATION_JSON_TYPE).get(SomeMessage.class); + out.println(serverResponse.greetings + " " + serverResponse.name); + + } catch (Exception e) { + out.println("No server response"); + } + + } +} \ No newline at end of file diff --git a/src/main/webapp/WEB-INF/web.xml b/src/main/webapp/WEB-INF/web.xml new file mode 100644 index 0000000..6905f59 --- /dev/null +++ b/src/main/webapp/WEB-INF/web.xml @@ -0,0 +1,21 @@ + + + + + Jersey Web Application + org.glassfish.jersey.servlet.ServletContainer + + jersey.config.server.provider.packages + fr.istic.rest + + 1 + + + Jersey Web Application + /api/* + + diff --git a/webapp-runner.sh b/webapp-runner.sh new file mode 100755 index 0000000..d9f271a --- /dev/null +++ b/webapp-runner.sh @@ -0,0 +1,10 @@ +#!/bin/bash + +# Téléchargement du runner jetty (https://www.eclipse.org/jetty/documentation/9.4.x/runner.html) +wget -O webapp-runner.jar -c http://central.maven.org/maven2/com/github/jsimone/webapp-runner/9.0.16.0/webapp-runner-9.0.16.0.jar + +# Compilation du war dans target +mvn package + +# Lancement du projet (à adapter si le jar change) +java -jar webapp-runner.jar target/pr.tp.services-0.0.1-SNAPSHOT.war \ No newline at end of file