Slide 1

Slide 1 text

Matt Raible | @mraible Get Hip with JHipster April 22, 2019 Photo by Alyssa Black https://www.flickr.com/photos/alyssablack/12185839253

Slide 2

Slide 2 text

Blogger on raibledesigns.com and developer.okta.com/blog Web Developer and Java Champion Father, Skier, Mountain Biker, Whitewater Rafter Open Source Developer + User Who is Matt Raible? Bus Lover Okta Developer Advocate

Slide 3

Slide 3 text

No content

Slide 4

Slide 4 text

No content

Slide 5

Slide 5 text

No content

Slide 6

Slide 6 text

public class Okta { public Okta(DeveloperDNA developerDna) { DeveloperRelations devRel = developerDna.getDeveloperRelations(); Assert.notNull(devRel,"Developer Relations is required to operate effectively."); Set team = devRel.getTeam(); Assert.isTrue(!team.isEmpty(),"Team cannot be empty."); Assert.isTrue(!devRel.getSdks().isEmpty(), "SDKs required for developers."); } }

Slide 7

Slide 7 text

Authentication Standards

Slide 8

Slide 8 text

What about YOU? Are you a Java Developer? Web Developer? How long have you been doing web development? Do you like JSF? Do you like GWT? Do you like JavaScript? TypeScript?

Slide 9

Slide 9 text

Do you want to be a hip Java Developer?

Slide 10

Slide 10 text

Java 8 Parallel Collections JSR 310 Date and Time API Functional Interfaces with default method Lambda Expressions (a.k.a. Closures) Nashorn JavaScript Engine

Slide 11

Slide 11 text

Java 11 New String Methods File Utility Methods Local Variable Syntax: var Java EE and CORBA modules removed What about Java 12?

Slide 12

Slide 12 text

Hipster n. noun 1. One who is exceptionally aware of or interested in the latest trends and tastes.

Slide 13

Slide 13 text

Latest trends in JavaLand? Microservices Embedded App Servers Deployment with Containers Environments: dev, test, production Auto-Configuration Monitoring

Slide 14

Slide 14 text

Spring Boot Automatically configures Spring whenever possible Provides production-ready features such as metrics, health checks and externalized configuration Absolutely no code generation and no requirement for XML configuration Embeds Tomcat, Jetty or Undertow directly

Slide 15

Slide 15 text

SPRING INITIALIZR @ start.spring.io

Slide 16

Slide 16 text

@SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } @Entity class Blog { @Id @GeneratedValue private Long id; private String name; // getters, setters, toString(), etc } @RepositoryRestResource interface BlogRepository extends JpaRepository { }

Slide 17

Slide 17 text

@SpringBootApplication class NotesApplication fun main(args: Array) { SpringApplication.run(NotesApplication::class.java, *args) } @Entity data class Note(@Id @GeneratedValue var id: Long? = null, var text: String? = null, @JsonIgnore var user: String? = null) @RepositoryRestResource interface NotesRepository : JpaRepository

Slide 18

Slide 18 text

Microservices with Spring Boot https://developer.okta.com/blog/2017/06/15/build-microservices-architecture-spring-boot

Slide 19

Slide 19 text

Latest trends in Web Development? Progressive Web Applications JavaScript MVC Frameworks CSS 3 with Animations Mobile First Front-End Optimization REST and GraphQL APIs

Slide 20

Slide 20 text

No content

Slide 21

Slide 21 text

No content

Slide 22

Slide 22 text

Hot Frameworks hotframeworks.com

Slide 23

Slide 23 text

Hot Frameworks hotframeworks.com

Slide 24

Slide 24 text

Jobs on Indeed (US) April 2019 0 2,500 5,000 7,500 10,000 React Angular Vue Vanilla

Slide 25

Slide 25 text

Stack Overflow Tags April 2019 0 45,000 90,000 135,000 180,000 React Angular Vue

Slide 26

Slide 26 text

GitHub Stars April 2019 0 35,000 70,000 105,000 140,000 React Angular Vue

Slide 27

Slide 27 text

No content

Slide 28

Slide 28 text

“Angular and React dominate: Nothing else even comes close.”

Slide 29

Slide 29 text

Wouldn’t it be hip if…? ⚭

Slide 30

Slide 30 text

@spring_io #springio17 JHipster jhipster.tech JHipster is a development platform to generate, develop and deploy Spring Boot + Angular/React Web applications and Spring microservices. and Vue! ✨

Slide 31

Slide 31 text

JHipster is Open Source Web Statistics, March 2019 420K Page Views / 692K on GitHub 97K Downloads GitHub Statistics 13K Stars 492 Contributors

Slide 32

Slide 32 text

JHipster Spring Boot Spring Security Angular React Bootstrap Metrics Maven or Gradle Authentication Type: cookie-based, JWT, or OAuth 2.0 / OIDC Type of Database: SQL or NoSQL Caching: EhCache or Hazelcast Elasticsearch Webpack Foundational Frameworks Project Options

Slide 33

Slide 33 text

How to use JHipster To install JHipster and Yeoman, use npm: npm install -g generator-jhipster Then create a directory and cd into it: mkdir myapp && cd myapp Then run JHipster: jhipster

Slide 34

Slide 34 text

Demo Time! Generate a basic blog application Look at its files and configuration 
 Generate the CRUD entities Limit blogs to current user, allow HTML Deploy to … all in 20 minutes!

Slide 35

Slide 35 text

Demo Entity Diagram

Slide 36

Slide 36 text

OAuth 2.0 and OpenID Connect OpenID Connect OAuth 2.0 HTTP OpenID Connect is for authentication
 
 OAuth 2.0 is for authorization

Slide 37

Slide 37 text

Validate ID Token Token Endpoint Authorization Endpoint /.well-known/
 openid-configuration JWKS Endpoint UserInfo Endpoint OAuth 2.0 Authorization Server & OpenID Connect Provider (OP) OAuth 2.0 Resource Server Client (Relying Party) 1 3 2 5 4 1 Discover OpenID Provider Metadata 2 Perform OAuth flow to obtain a ID token and/or access token 3 Get JSON Web Key Set (JWKS) for signature keys 4 Validate ID token
 (JSON Web Token) 5 Get additional user attributes with access token from UserInfo endpoint OpenID Connect

Slide 38

Slide 38 text

Get Started with JHipster 5 Demo https://github.com/mraible/jhipster5-demo | https://youtu.be/-VQ_SVkaXbs

Slide 39

Slide 39 text

React PWA with JHipster 5 https://developer.okta.com/blog/2018/06/25/react-spring-boot-photo-gallery-pwa

Slide 40

Slide 40 text

No content

Slide 41

Slide 41 text

JHipster is Knowledge

Slide 42

Slide 42 text

The JHipster Mini-Book Written with Asciidoctor Quick and to the point, 164 pages Developed a Real World App: www.21-points.com Free Download from infoq.com/minibooks/jhipster-mini-book

Slide 43

Slide 43 text

Lines of Code in 21-Points 0 6500 13000 19500 26000 Project Created Entities Generated Business Logic and UI 25,670 23,590 16,728

Slide 44

Slide 44 text

Project Creation Entities Generated Biz Logic and UI 0 10000 20000 30000 2,999 2,648 1,839 9,472 8,911 5,523 8,383 7,696 5,892 Java TypeScript HTML Lines of Code by Language

Slide 45

Slide 45 text

Learn More stackoverflow.com Spring Boot spring.io/guides JHipster www.jhipster.tech Okta APIs developer.okta.com

Slide 46

Slide 46 text

Getting Help stackoverflow.com/tags/jhipster gitter.im/jhipster/generator-jhipster github.com/jhipster/.../CONTRIBUTING.md groups.google.com/.../jhipster-dev

Slide 47

Slide 47 text

What’s New and Next? JHipster 6 Beta now available! JDK 8+ Compatibility Spring Boot 2.1 / Spring Webflux Vue Support Updated OAuth 2.0 / OIDC

Slide 48

Slide 48 text

Get Started with JHipster 6 https://developer.okta.com/blog/2019/04/04/java-11-java-12-jhipster-oidc

Slide 49

Slide 49 text

developer.okta.com/blog

Slide 50

Slide 50 text

Action! Try Spring Boot Try Angular, React, or Vue Try JHipster Explore PWAs Enjoy the bootiful experience!

Slide 51

Slide 51 text

Questions? Keep in touch! raibledesigns.com @mraible Presentations speakerdeck.com/mraible Code github.com/oktadeveloper