-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Update pipelines (#3) Updates project files * feature/verifier-h2m-m2m-flows (#4) * New DOME login page * New Crypto feature (generate ECKey + did:key from a Private Key) New Security Config with scaffolding for OpenID Connect * WIP in custom OpenID Connect Authorization Code Flow for Verifiable Credentials * Update info * Update did:key creation and decode New JWT service * add validation fot the auth request of the OPENID CORE * add verifiactions, and fix problem during did generation * Add conditional for H2M and M2M * Update CustomAuthorizationRequestConverter.java * Filters for security * h2m flow added qr generation page and jwt request retrival. * Added auth response logic to validate the vp * vp validation chnges * merge h2m m2m * wip: refactor ClientLoaderConfig * wip: add test * wip: add check structure * Finish JWT Claims checks * refactor didResolver implementation * adapt verifications the certificate validation signature is failing * add some tests * Update VpValidationServiceImpl.java * add some tests * Update VpValidationServiceImpl.java * wip: VP certificated input error * Vo validation * wip: VP certificated input error * change settings gradle rootproject name * wip: check vp from vp_token in assertion * fix: check vp from vp_token in assertion * New changes * solve merge conflicts * wip: Custom token * Test for generate the access token * add jwtcustomizer * wip: Custom token * return custom token * delete jwtCustomizer bean * add JWT type into header * uncomment validation * WIP: TODOs * Add logic to retrieve the token response * Delete the OAuthAuthorization after consum the request * Add TODOs checks * Add logic for verificate client in the auth code flow * Remove Controller for tests * Add new client * solve merge conflicts * getScope method * getScope method * refactor LEARCredentialMachine * add same device login * remove localhost for testing * adjust padding for qr image background * Retrieval of the trustFramework via GitHub repository * Correct error on remote url * update application profiles * add url of github repository as config variable * change application.yaml names * add info to CHANGELOG.md * delete dependency * change header image * solve pr comments * add custom exception * add custom exception handler * delete ResponseEntity response from Oid4vp controller * delete import * add exception for the CustomExceptionHandler to manage cache retrieval * refactor global exception handler * refactor Controller to RestController * rollback RestController * change client loader config implementation to external yaml config file * add interface against the trusted issuer list * add interface against the trusted issuer list and validations on vp service * solve PR comments * fix default env profile implementation * wip: logs to deployment * expose health endpoint * add management dependency * add local configs * change LEARCredentialMachine dto attributes names * fix some reference to LearCredentialMachine * fix some attributes from LearCredentialEmployee * add logs for debugging * update scope for learcredential * add logs for debugging * change scope name * fix exp access token * fix fixme * add websocket logic for redirection * update scope * remove origin retrieval from the token request * remove state validation for testing * add some tests * add some tests * add token log * add state validation on token request as optional * add CUstom Token Request Converter M2M tests * add Auth Provider Tests * add H2M Converter Tests * update scope * add Custom Error Response Handler unit tests * init CustomAuthorizationRequestConverterTest --------- Co-authored-by: Oriol Canadés <oriol.canades@in2.es> Co-authored-by: Oriol Canadés <83498869+oriolcanadesin2@users.noreply.github.com> Co-authored-by: RubenModamioGarcia <ruben.modamio@in2.es> Co-authored-by: albertrodriguezin2 <166031280+albertrodriguezin2@users.noreply.github.com> * update changelog and version * init AllowedClientsServiceImplTest * do init AllowedClientsServiceImplTest * do init VpServiceTests * wip: add some tests * wip: comment fail test * wip: refactor test * wip: increase coverage * fix(login): extract urls and make it environment variables * fix(login): comment same device frontend section * fix(login): rename uris environment variables * feat(login): improved html borders (by Roger) * wip: increase coverage * wip: increase coverage * wip: increase coverage * add test * wip: increase coverage * wip: increase coverage * refactor tir list implementation * refactor tests * comment test * sonar exclusions * sonar exclusions * Review * Review * Review * Review * change check to mandate instead mandatee * change check to mandatorOrganizationIdentifier instead mandatee and refactor tests * fix register link * update CHANGELOG.md and build.gradle * - Added functionality to redirect to the home page when clicking the logo in the login page. - Added a timeout that redirects to the home page when the QR code expires in the login page. * rename property * rename property * Added a validation method to check the revocation during the verifiable presentation validation. * Added a validation method to check the revocation during the verifiable presentation validation. * Update pipelines * Update pipelines * Update Changelog --------- Co-authored-by: javieralvarezin2 <145534842+javieralvarezin2@users.noreply.github.com> Co-authored-by: Oriol Canadés <83498869+oriolcanadesin2@users.noreply.github.com> Co-authored-by: RubenModamioGarcia <ruben.modamio@in2.es> Co-authored-by: albertrodriguezin2 <166031280+albertrodriguezin2@users.noreply.github.com> Co-authored-by: javieralvarezin2 <javier.alvarez@in2.es> Co-authored-by: Albert Rodríguez <albert.rodriguez@in2.es>
- Loading branch information
1 parent
ae97736
commit decfd54
Showing
128 changed files
with
8,170 additions
and
44 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,95 @@ | ||
name: Release | ||
on: | ||
push: | ||
branches: | ||
- main | ||
pull_request: | ||
branches: | ||
- main | ||
types: [opened, synchronize, reopened] | ||
|
||
permissions: | ||
contents: write | ||
|
||
jobs: | ||
release-snapshot: | ||
if: github.event_name == 'pull_request' | ||
name: release-snapshot | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout Repository | ||
uses: actions/checkout@v4 | ||
|
||
- name: Set up JDK | ||
uses: actions/setup-java@v4 | ||
with: | ||
distribution: 'adopt' | ||
java-version: '17' | ||
|
||
- name: Make Gradlew Executable | ||
run: chmod +x ./gradlew | ||
|
||
- name: Get Project Version | ||
id: get_version | ||
run: echo "VERSION=$(./gradlew -q printVersion)" >> $GITHUB_ENV | ||
|
||
- name: Build and Push docker image | ||
run: | | ||
./gradlew printProjectName | ||
PROJECT_NAME=$(./gradlew -q printProjectName) | ||
IMAGE_TAG="$PROJECT_NAME:v$VERSION$SUFFIX" | ||
docker build --file Dockerfile --build-arg SKIP_TESTS=true --tag $DOCKER_HUB_CLIENT_NAME/$IMAGE_TAG . | ||
echo $DOCKER_PASSWORD | docker login -u $DOCKER_USERNAME --password-stdin | ||
docker push $DOCKER_HUB_CLIENT_NAME/$IMAGE_TAG | ||
env: | ||
VERSION: ${{ env.VERSION }} | ||
SUFFIX: -snapshot | ||
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} | ||
DOCKER_PASSWORD: ${{ secrets.DOCKER_TOKEN }} | ||
DOCKER_HUB_CLIENT_NAME: in2workspace | ||
|
||
release: | ||
if: github.event_name == 'push' && github.ref == 'refs/heads/main' | ||
name: release | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout Repository | ||
uses: actions/checkout@v4 | ||
|
||
- name: Set up JDK | ||
uses: actions/setup-java@v4 | ||
with: | ||
distribution: 'adopt' | ||
java-version: '17' | ||
|
||
- name: Make Gradlew Executable | ||
run: chmod +x ./gradlew | ||
|
||
- name: Get Project Version | ||
id: get_version | ||
run: echo "VERSION=$(./gradlew -q printVersion)" >> $GITHUB_ENV | ||
|
||
- name: Build and Push docker image | ||
run: | | ||
./gradlew printProjectName | ||
PROJECT_NAME=$(./gradlew -q printProjectName) | ||
IMAGE_TAG="$PROJECT_NAME:v$VERSION" | ||
docker build --file Dockerfile --build-arg SKIP_TESTS=true --tag $DOCKER_HUB_CLIENT_NAME/$IMAGE_TAG . | ||
echo $DOCKER_PASSWORD | docker login -u $DOCKER_USERNAME --password-stdin | ||
docker push $DOCKER_HUB_CLIENT_NAME/$IMAGE_TAG | ||
env: | ||
VERSION: ${{ env.VERSION }} | ||
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} | ||
DOCKER_PASSWORD: ${{ secrets.DOCKER_TOKEN }} | ||
DOCKER_HUB_CLIENT_NAME: in2workspace | ||
|
||
- name: Create GitHub Release | ||
uses: actions/create-release@v1 | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
with: | ||
tag_name: "v${{ env.VERSION }}" | ||
release_name: "v${{ env.VERSION }}" | ||
body: "Release of version v${{ env.VERSION }}" | ||
draft: false | ||
prerelease: false |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,22 +1,33 @@ | ||
<div align="center"> | ||
|
||
<h1>VC Verifier</h1> | ||
<h1>IN2 Verifier API</h1> | ||
<span>by </span><a href="https://in2.es">in2.es</a> | ||
|
||
<p><p> | ||
|
||
[data:image/s3,"s3://crabby-images/07cf4/07cf48bb0ffd30519a1948e5570fbf4d65b5999f" alt="Quality Gate Status"](https://sonarcloud.io/dashboard?id=in2workspace_in2-vc-verifier) | ||
|
||
[data:image/s3,"s3://crabby-images/b3e33/b3e333a92ef5af2c9cb4942a1c29240efdd262a2" alt="Bugs"](https://sonarcloud.io/summary/new_code?id=in2workspace_in2-vc-verifier) | ||
[data:image/s3,"s3://crabby-images/1de5a/1de5a8c3cc7c0b4dcb839e96ced9e8882ba17e3a" alt="Vulnerabilities"](https://sonarcloud.io/dashboard?id=in2workspace_in2-vc-verifier) | ||
[data:image/s3,"s3://crabby-images/1de13/1de133ebb2245c335e1b0b4b84e1b85239836155" alt="Security Rating"](https://sonarcloud.io/dashboard?id=in2workspace_in2-vc-verifier) | ||
[data:image/s3,"s3://crabby-images/bce3e/bce3e6a75e438b3d6bcbc8729d8de11739109948" alt="Code Smells"](https://sonarcloud.io/summary/new_code?id=in2workspace_in2-vc-verifier) | ||
[data:image/s3,"s3://crabby-images/44863/44863e23b27da0737cf726f6086f013022c17e14" alt="Lines of Code"](https://sonarcloud.io/dashboard?id=in2workspace_in2-vc-verifier) | ||
|
||
[data:image/s3,"s3://crabby-images/586ff/586ff6c85b58667d0defa7696ee6066b0f9886f8" alt="Coverage"](https://sonarcloud.io/summary/new_code?id=in2workspace_in2-vc-verifier) | ||
[data:image/s3,"s3://crabby-images/2224b/2224b5f44c12a49e05119a4c714c163dd5895dd5" alt="Duplicated Lines (%)"](https://sonarcloud.io/summary/new_code?id=in2workspace_in2-vc-verifier) | ||
[data:image/s3,"s3://crabby-images/c4d28/c4d28bba63fe5e2d469d746d6dfe1772264a4494" alt="Reliability Rating"](https://sonarcloud.io/dashboard?id=in2workspace_in2-vc-verifier) | ||
[data:image/s3,"s3://crabby-images/9a49a/9a49a1dd4ca9f42fdc4bca424a644d2fc40cafa3" alt="Maintainability Rating"](https://sonarcloud.io/dashboard?id=in2workspace_in2-vc-verifier) | ||
[data:image/s3,"s3://crabby-images/ad11f/ad11fd9d08e697b266a5b710d1ff2d5d1af4a68a" alt="Technical Debt"](https://sonarcloud.io/summary/new_code?id=in2workspace_in2-vc-verifier) | ||
|
||
[data:image/s3,"s3://crabby-images/66e93/66e933324abb508196f92d9cb2e15e73c21c47d7" alt="Quality Gate Status"](https://sonarcloud.io/dashboard?id=in2workspace_in2-verifier-api) | ||
|
||
[data:image/s3,"s3://crabby-images/f2bf0/f2bf02f92be73e03035475b5685dbebb89430ae2" alt="Bugs"](https://sonarcloud.io/summary/new_code?id=in2workspace_in2-verifier-api) | ||
[data:image/s3,"s3://crabby-images/2401d/2401df5f4e8d73c1c14c6fcdc3388d73b72c3612" alt="Vulnerabilities"](https://sonarcloud.io/dashboard?id=in2workspace_in2-verifier-api) | ||
[data:image/s3,"s3://crabby-images/5909a/5909acf968924a0b0fb043a50a4822d8253c4b68" alt="Security Rating"](https://sonarcloud.io/dashboard?id=in2workspace_in2-verifier-api) | ||
[data:image/s3,"s3://crabby-images/888ad/888ade88f9f49787b4894716d849c519cd87b3fb" alt="Code Smells"](https://sonarcloud.io/summary/new_code?id=in2workspace_in2-verifier-api) | ||
[data:image/s3,"s3://crabby-images/67845/6784565709dc296ae52cfa942f3618110ef7e8cd" alt="Lines of Code"](https://sonarcloud.io/dashboard?id=in2workspace_in2-verifier-api) | ||
|
||
[data:image/s3,"s3://crabby-images/96df5/96df5f71ce5f9c1920dfd5569ce0bd3237ec9e6f" alt="Coverage"](https://sonarcloud.io/summary/new_code?id=in2workspace_in2-verifier-api) | ||
[data:image/s3,"s3://crabby-images/27bed/27bed9d2fcdfa6dbe235970d25e4a774665b664d" alt="Duplicated Lines (%)"](https://sonarcloud.io/summary/new_code?id=in2workspace_in2-verifier-api) | ||
[data:image/s3,"s3://crabby-images/65a63/65a6333da77e5dd95a2e61232827d00e54d8d551" alt="Reliability Rating"](https://sonarcloud.io/dashboard?id=in2workspace_in2-verifier-api) | ||
[data:image/s3,"s3://crabby-images/0a814/0a8143aec87a29e63f70112514b71661a7f54611" alt="Maintainability Rating"](https://sonarcloud.io/dashboard?id=in2workspace_in2-verifier-api) | ||
[data:image/s3,"s3://crabby-images/c6cee/c6cee52ee53f6217f6c03f41117ef28a63f09940" alt="Technical Debt"](https://sonarcloud.io/summary/new_code?id=in2workspace_in2-verifier-api) | ||
</div> | ||
|
||
# Introduction | ||
|
||
Spring Authorization Server is a framework that provides implementations of the OAuth 2.1 and OpenID Connect 1.0 specifications and other related specifications. | ||
It is built on top of Spring Security to provide a secure, light-weight, | ||
and customizable foundation for building OpenID Connect 1.0 Identity Providers and OAuth2 Authorization Server products. | ||
|
||
# Testing | ||
|
||
We test the first call by sending a GET request to the '/oauth2/authorize' endpoint. | ||
|
||
```text | ||
http://localhost:9000/oauth2/authorize?response_type=code&client_id=did:key:wejkdew87fwhef9833f4&request_uri=https://dome-marketplace.org/api/v1/request.jwt%23GkurKxf5T0Y-mnPFCHqWOMiZi4VS138cQO_V7PZHAdM&state=af0ifjsldkj&nonce=n-0S6_WzA2Mj | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
rootProject.name = 'vcverifier' | ||
rootProject.name = 'in2-verifier-api' |
20 changes: 20 additions & 0 deletions
20
src/main/java/es/in2/vcverifier/VcVerifierApplication.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,13 +1,33 @@ | ||
package es.in2.vcverifier; | ||
|
||
import com.fasterxml.jackson.annotation.JsonInclude; | ||
import com.fasterxml.jackson.databind.DeserializationFeature; | ||
import com.fasterxml.jackson.databind.MapperFeature; | ||
import com.fasterxml.jackson.databind.ObjectMapper; | ||
import com.fasterxml.jackson.databind.json.JsonMapper; | ||
import org.springframework.boot.SpringApplication; | ||
import org.springframework.boot.autoconfigure.SpringBootApplication; | ||
import org.springframework.boot.context.properties.ConfigurationPropertiesScan; | ||
import org.springframework.boot.context.properties.EnableConfigurationProperties; | ||
import org.springframework.context.annotation.Bean; | ||
|
||
@SpringBootApplication | ||
@EnableConfigurationProperties | ||
@ConfigurationPropertiesScan | ||
public class VcVerifierApplication { | ||
|
||
private static final ObjectMapper OBJECT_MAPPER = | ||
JsonMapper.builder() | ||
.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false) | ||
.configure(MapperFeature.SORT_PROPERTIES_ALPHABETICALLY, true) | ||
.serializationInclusion(JsonInclude.Include.NON_NULL) | ||
.build(); | ||
public static void main(String[] args) { | ||
SpringApplication.run(VcVerifierApplication.class, args); | ||
} | ||
|
||
@Bean | ||
public ObjectMapper objectMapper() { | ||
return OBJECT_MAPPER; | ||
} | ||
} |
Oops, something went wrong.