Skip to content

Commit

Permalink
Merge pull request #2 from zazuko/angular_18
Browse files Browse the repository at this point in the history
Angular 18
  • Loading branch information
BenjaminHofstetter authored Jun 3, 2024
2 parents 639febf + 5bb3a5e commit 81730da
Show file tree
Hide file tree
Showing 8 changed files with 2,484 additions and 1,946 deletions.
4,265 changes: 2,404 additions & 1,861 deletions package-lock.json

Large diffs are not rendered by default.

42 changes: 21 additions & 21 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,16 +11,16 @@
},
"private": true,
"dependencies": {
"@angular/animations": "^17.3.9",
"@angular/cdk": "^17.3.9",
"@angular/common": "^17.3.9",
"@angular/compiler": "^17.3.9",
"@angular/core": "^17.3.9",
"@angular/forms": "^17.3.9",
"@angular/platform-browser": "^17.3.9",
"@angular/platform-browser-dynamic": "^17.3.9",
"@angular/router": "^17.3.9",
"@angular/service-worker": "^17.3.9",
"@angular/animations": "^18.0.1",
"@angular/cdk": "^18.0.1",
"@angular/common": "^18.0.1",
"@angular/compiler": "^18.0.1",
"@angular/core": "^18.0.1",
"@angular/forms": "^18.0.1",
"@angular/platform-browser": "^18.0.1",
"@angular/platform-browser-dynamic": "^18.0.1",
"@angular/router": "^18.0.1",
"@angular/service-worker": "^18.0.1",
"@fortawesome/fontawesome-free": "^6.5.2",
"@rdfjs/formats": "^4.0.0",
"@zazuko/env": "^2.2.0",
Expand All @@ -29,7 +29,7 @@
"mermaid": "^10.9.1",
"n3": "^1.17.3",
"primeicons": "^7.0.0",
"primeng": "^17.17.0",
"primeng": "^17.18.0",
"process": "^0.11.10",
"rdf-sparql-builder": "^0.2.1",
"rxjs": "~7.8.1",
Expand All @@ -40,14 +40,14 @@
"zone.js": "~0.14.3"
},
"devDependencies": {
"@angular-devkit/build-angular": "^17.3.6",
"@angular-eslint/builder": "17.4.1",
"@angular-eslint/eslint-plugin": "17.4.1",
"@angular-eslint/eslint-plugin-template": "17.4.1",
"@angular-eslint/schematics": "17.4.1",
"@angular-eslint/template-parser": "17.4.1",
"@angular/cli": "^17.3.6",
"@angular/compiler-cli": "^17.3.9",
"@angular-devkit/build-angular": "^18.0.2",
"@angular-eslint/builder": "18.0.1",
"@angular-eslint/eslint-plugin": "18.0.1",
"@angular-eslint/eslint-plugin-template": "18.0.1",
"@angular-eslint/schematics": "18.0.1",
"@angular-eslint/template-parser": "18.0.1",
"@angular/cli": "^18.0.2",
"@angular/compiler-cli": "^18.0.1",
"@types/clownface": "^2.0.7",
"@types/jasmine": "~3.10.0",
"@types/node": "^20.10.4",
Expand All @@ -62,7 +62,7 @@
"karma-coverage": "~2.2.0",
"karma-jasmine": "~5.1.0",
"karma-jasmine-html-reporter": "~2.1.0",
"ng-packagr": "^17.1.2",
"typescript": "~5.3.2"
"ng-packagr": "^18.0.0",
"typescript": "~5.4.5"
}
}
11 changes: 5 additions & 6 deletions projects/blueprint/src/app/app.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,21 +4,21 @@ import {
} from '@angular/router';

import { routes } from './app.routes';
import { APP_INITIALIZER, importProvidersFrom } from '@angular/core';
import { APP_INITIALIZER } from '@angular/core';

import { HTTP_INTERCEPTORS, HttpClientModule } from '@angular/common/http';
import { provideHttpClient, withInterceptors } from '@angular/common/http';
import { provideAnimations } from '@angular/platform-browser/animations';
import { ConfigService } from './core/service/config/config.service';
import { authInterceptor } from '@blueprint/http-interceptor/auth-interceptor/auth-interceptor.function';

import { AuthInterceptor } from '@blueprint/http-interceptor/auth-interceptor/auth-interceptor.service';

function initializeAppFactory(configService: ConfigService): () => void {
return () => configService.fetchConfig()
}

export const appConfig: ApplicationConfig = {
providers: [
importProvidersFrom(HttpClientModule),
provideHttpClient(withInterceptors([authInterceptor])),
provideRouter(routes,
withInMemoryScrolling({ anchorScrolling: 'enabled', scrollPositionRestoration: 'enabled' }),
withComponentInputBinding()
Expand All @@ -29,8 +29,7 @@ export const appConfig: ApplicationConfig = {
useFactory: initializeAppFactory,
deps: [ConfigService],
multi: true
},
{ provide: HTTP_INTERCEPTORS, useClass: AuthInterceptor, multi: true }
}

],
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
/* eslint-disable @typescript-eslint/no-explicit-any */
import { inject } from '@angular/core';
import { HttpRequest, HttpEvent, HttpHandlerFn } from '@angular/common/http';
import { Observable, catchError, throwError } from 'rxjs';
import { Router } from '@angular/router';
import { LibraryConfigurationService } from '@blueprint/service/library-configuration/library-configuration.service';
import { AuthService } from '@blueprint/service/auth/auth.service';

/**
* An HTTP interceptor that adds basic auth credentials to requests to the library configuration service.
*/


/**
* Intercepts HTTP requests and adds basic auth credentials to requests to the library configuration service.
* @param req The HTTP request.
* @param next The HTTP handler.
* @returns An observable of the HTTP event.
*/
export function authInterceptor(req: HttpRequest<unknown>, next: HttpHandlerFn): Observable<HttpEvent<any>> {
const libraryConfig = inject(LibraryConfigurationService);
const authService = inject(AuthService);
const router = inject(Router);
// If the request is for the sparql endpoint, add the basic auth credentials.
if (req.url.includes(libraryConfig.endpointUrl)) {
// Create the authorization header by base64-encoding the username and password separated by a colon.
const credentials = authService.getCredentials();
const authHeader = `Basic ${btoa(`${credentials ? credentials.username : ''}:${credentials ? credentials.password : ''}`)}`;

// Clone the original request and add the authorization header to the headers.
const authReq = req.clone({
headers: req.headers.set('Authorization', authHeader)
});

// Pass the modified request to the next handler in the chain.
return next(authReq).pipe(
catchError(error => {
// If the response returns an HTTP 401 status code (Unauthorized), navigate to the login page.
if (error.status === 401) {
router.navigate(['/login']);
}
// Rethrow the error.
return throwError(() => new Error(error.message))
})
);
} else {
// If the request is not for the library configuration service, pass the original request to the next handler in the chain.
return next(req);
}
}

This file was deleted.

2 changes: 1 addition & 1 deletion projects/blueprint/src/app/core/http-interceptor/index.ts
Original file line number Diff line number Diff line change
@@ -1 +1 @@
export * from './auth-interceptor/auth-interceptor.service'
export * from './auth-interceptor/auth-interceptor.function'
2 changes: 1 addition & 1 deletion projects/blueprint/src/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
</head>

<body>
<bp-root />
<bp-root></bp-root>
<noscript>Please enable JavaScript to continue using this application.</noscript>
</body>

Expand Down
5 changes: 2 additions & 3 deletions tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,15 @@
"baseUrl": "./",
"outDir": "./dist/out-tsc",
"forceConsistentCasingInFileNames": true,
"strict": false, // true
"strict": false,
"esModuleInterop": true, // true
"noImplicitOverride": true,
"noPropertyAccessFromIndexSignature": true,
"noImplicitReturns": true,
"noFallthroughCasesInSwitch": true,
"sourceMap": true,
"declaration": false,
"downlevelIteration": true,
"experimentalDecorators": true,
"allowSyntheticDefaultImports": true,
"moduleResolution": "node",
"importHelpers": true,
"target": "ES2022",
Expand Down

0 comments on commit 81730da

Please sign in to comment.