Code Monkey home page Code Monkey logo

mb-spring-security's Introduction

Spring Security OAuth Client / Resource Server Showcase

This project houses an example resource server and a matching client, both are spring boot web applications.

The only thing not included is an authentication server.

I used a locally running standalone keycloak for that.

test urls

App Url Purpose
Resource Server http://localhost:8082/transactions some test data (fake financial transactions)
Client http://localhost:8081/remote makes to call to the resource server's transactions endpoint
Client http://localhost:8081/client some debug client info fetched out of the currently active authentication
Client http://localhost:8081/local is not supposed to call the resource server therefore this endpoint should work without any login

local keycloak setup

  1. get the zip distribution and run it standalone.bat / standalone.sh
  2. go to http://localhost:8080/auth
  3. create an admin user
  4. create a new domain called Dev (or any name you like)
  5. create a new client called mb-client (or any name you like) that uses "openid-connect" protocol
  6. note down the client credentials (client-secret)
  7. add a new user with some basic user info and set a password for that user
  8. add a new client scope read_transactions
  9. add a mapper to this scope to provide a hardcoded jwt claim "account_no" with a dummy value
  10. add the new scope to the optional scopes available for the client mb-client

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.