[DEBUG] correnct connection on retreive curent page and return sso page

This commit is contained in:
Edouard DUPIN 2022-12-15 23:50:52 +01:00
parent 6f96c0b929
commit 763dbed9c3
11 changed files with 51 additions and 37 deletions

View File

@ -35,6 +35,7 @@ const routes: Routes = [
// -- SSO Generic interface // -- SSO Generic interface
// ------------------------------------ // ------------------------------------
{ path: 'sso/:data/:keepConnected/:token', component: SsoScene }, { path: 'sso/:data/:keepConnected/:token', component: SsoScene },
{ path: 'sso/:keepConnected/:token', component: SsoScene },
{ path: 'sso', component: SsoScene }, { path: 'sso', component: SsoScene },
// ------------------------------------ // ------------------------------------
@ -97,8 +98,17 @@ const routes: Routes = [
]; ];
@NgModule({ @NgModule({
imports: [ RouterModule.forRoot(routes) ], imports: [
exports: [ RouterModule ] RouterModule.forRoot(
routes,
{
//enableTracing: true, // <-- debugging purposes only
},
),
],
exports: [
RouterModule,
]
}) })
export class AppRoutingModule { } export class AppRoutingModule { }
// export const routing: ModuleWithProviders = RouterModule.forRoot(routes); // export const routing: ModuleWithProviders = RouterModule.forRoot(routes);

View File

@ -48,7 +48,7 @@ export class AppComponent implements OnInit {
} }
ngOnInit() { ngOnInit() {
this.location = location.pathname; console.log(`>>>> APLLICATION INIT: BASE PATH: ${this.location}`);
this.autoConnectedDone = false; this.autoConnectedDone = false;
this.isConnected = false; this.isConnected = false;
this.updateMainMenu(); this.updateMainMenu();
@ -58,11 +58,6 @@ export class AppComponent implements OnInit {
self.isConnected = isConnected; self.isConnected = isConnected;
self.autoConnectedDone = true; self.autoConnectedDone = true;
self.updateMainMenu(); self.updateMainMenu();
if (isConnected) {
console.log("Is connected then back to the requested page")
self.router.navigateByUrl(self.location);
console.log(`update global URL = ${self.location}`);
}
}); });
this.ssoService.checkSignUpEnable() this.ssoService.checkSignUpEnable()
.then((value: boolean) => { .then((value: boolean) => {
@ -76,7 +71,6 @@ export class AppComponent implements OnInit {
this.userService.checkAutoConnect().then(() => { this.userService.checkAutoConnect().then(() => {
console.log(` ==>>>>> Autoconnect THEN !!!`); console.log(` ==>>>>> Autoconnect THEN !!!`);
self.autoConnectedDone = true; self.autoConnectedDone = true;
//window.location.href = self.location;
}).catch(() => { }).catch(() => {
console.log(` ==>>>>> Autoconnect CATCH !!!`); console.log(` ==>>>>> Autoconnect CATCH !!!`);
self.autoConnectedDone = true; self.autoConnectedDone = true;

View File

@ -5,7 +5,7 @@
*/ */
import { BrowserModule } from '@angular/platform-browser'; import { BrowserModule } from '@angular/platform-browser';
import { NgModule, CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA } from '@angular/core'; import { NgModule } from '@angular/core';
import { RouterModule } from '@angular/router'; import { RouterModule } from '@angular/router';
import { HttpClientModule } from '@angular/common/http'; import { HttpClientModule } from '@angular/common/http';
import { FormsModule, ReactiveFormsModule } from '@angular/forms'; // this is needed for dynamic selection of the select import { FormsModule, ReactiveFormsModule } from '@angular/forms'; // this is needed for dynamic selection of the select
@ -111,10 +111,6 @@ import { ErrorComponent, TopMenuComponent } from 'common/component';
], ],
bootstrap: [ bootstrap: [
AppComponent AppComponent
],
schemas: [
CUSTOM_ELEMENTS_SCHEMA,
NO_ERRORS_SCHEMA
] ]
}) })
export class AppModule { } export class AppModule { }

View File

@ -353,7 +353,6 @@ export class HttpWrapperService {
// Complex wrapper to simplify interaction:s // Complex wrapper to simplify interaction:s
putSpecific(urlPath: UrlPath, data: object):Promise<ModelResponseHttp> { putSpecific(urlPath: UrlPath, data: object):Promise<ModelResponseHttp> {
console.log(`Put on ${urlPath}`);
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
this.request({ this.request({
endPoint: urlPath, endPoint: urlPath,

View File

@ -136,7 +136,6 @@ export class OnlyUsersGuardHome implements CanActivate {
private router: Router) {}; private router: Router) {};
canActivate() { canActivate() {
console.log("OnlyLoggedInUsers");
if (this.sessionService.hasRight(UserRoles222.user) || this.sessionService.hasRight(UserRoles222.admin) ) { if (this.sessionService.hasRight(UserRoles222.user) || this.sessionService.hasRight(UserRoles222.admin) ) {
return true; return true;
} else { } else {
@ -166,7 +165,6 @@ export class OnlyAdminGuard implements CanActivate {
private router: Router) {}; private router: Router) {};
canActivate() { canActivate() {
console.log("OnlyLoggedInUsers");
if (this.sessionService.hasRight(UserRoles222.user)) { if (this.sessionService.hasRight(UserRoles222.user)) {
return true; return true;
} else { } else {

View File

@ -6,7 +6,7 @@
import { Injectable } from '@angular/core'; import { Injectable } from '@angular/core';
import { environment } from 'environments/environment'; import { environment } from 'environments/environment';
import { isInArray, isNullOrUndefined } from 'common/utils'; import { getApplicationLocation, isInArray, isNullOrUndefined } from 'common/utils';
import { HTTPMimeType, HTTPRequestModel, HttpWrapperService, ModelResponseHttp } from 'common/service'; import { HTTPMimeType, HTTPRequestModel, HttpWrapperService, ModelResponseHttp } from 'common/service';
@Injectable() @Injectable()
@ -33,23 +33,15 @@ export class SSOService {
if (!isNullOrUndefined(data) && !isInArray(data, ["", "null", "NULL", "undefined", "---", "unregistered", "unregistered/", "forbidden", "forbidden/"])) { if (!isNullOrUndefined(data) && !isInArray(data, ["", "null", "NULL", "undefined", "---", "unregistered", "unregistered/", "forbidden", "forbidden/"])) {
return this.utf8_to_b64(data); return this.utf8_to_b64(data);
} }
let pathName = window.location.pathname; let pathName = getApplicationLocation();
console.log("start Path-name: '" + pathName + "'"); if (isInArray(pathName, ["sso", "/sso", "/sso/"])) {
console.log("check with: '" + environment.applName + "/sso/" + "'");
if (pathName.startsWith("/sso/") || pathName.startsWith(environment.applName + "/sso/")) {
return this.utf8_to_b64('home'); return this.utf8_to_b64('home');
} }
if (pathName.startsWith('/' + environment.applName + '/')) { if (!isNullOrUndefined(pathName) && !isInArray(pathName, ["", "null", "NULL", "undefined", "---", "unregistered", "unregistered/", "forbidden", "forbidden/"])) {
pathName = pathName.substring(environment.applName.length+2);
} else if (pathName.startsWith('/' + environment.applName)) {
pathName = pathName.substring(environment.applName.length + 1);
} else if (pathName.startsWith(environment.applName + '/')) {
pathName = pathName.substring(environment.applName.length+1);
} else if (pathName.startsWith(environment.applName)) {
pathName = pathName.substring(environment.applName.length);
}
return this.utf8_to_b64(pathName); return this.utf8_to_b64(pathName);
} }
return this.utf8_to_b64('home');
}
/** /**
* Request SSO connection * Request SSO connection
*/ */

View File

@ -5,13 +5,15 @@
*/ */
import { Injectable } from '@angular/core'; import { Injectable } from '@angular/core';
import { Router } from '@angular/router';
import { environment } from 'environments/environment'; import { environment } from 'environments/environment';
import { HTTPMimeType, HTTPRequestModel, HttpWrapperService, ModelResponseHttp } from './http-wrapper'; import { HTTPMimeType, HTTPRequestModel, HttpWrapperService, ModelResponseHttp } from './http-wrapper';
import { StorageService } from 'common/service/local-storage'; import { StorageService } from 'common/service/local-storage';
import { SessionService } from './session'; import { SessionService } from './session';
import { SSOService } from './sso'; import { SSOService } from './sso';
import { isNullOrUndefined } from 'common/utils'; import { getApplicationLocation, isNullOrUndefined } from 'common/utils';
interface MessageLogIn { interface MessageLogIn {
login: string; login: string;
@ -38,6 +40,7 @@ export class UserService {
private cookiesToken = 'token'; private cookiesToken = 'token';
constructor( constructor(
private router: Router,
private storageService: StorageService, private storageService: StorageService,
private http: HttpWrapperService, private http: HttpWrapperService,
private sessionService: SessionService, private sessionService: SessionService,
@ -83,6 +86,7 @@ export class UserService {
* Check if the system can be connected * Check if the system can be connected
*/ */
checkAutoConnect(): Promise<void> { checkAutoConnect(): Promise<void> {
let locationOrigin = getApplicationLocation();
let self = this; let self = this;
return new Promise<void>((resolve, reject) => { return new Promise<void>((resolve, reject) => {
// Need to use the windows global route to prevent the log in cycle ... // Need to use the windows global route to prevent the log in cycle ...
@ -110,6 +114,8 @@ export class UserService {
this.storageService.removeSession(this.cookiesToken); this.storageService.removeSession(this.cookiesToken);
this.storageService.remove(this.cookiesToken); this.storageService.remove(this.cookiesToken);
self.startSession(token, rememberMe).then(() => { self.startSession(token, rememberMe).then(() => {
self.router.navigateByUrl(locationOrigin);
console.log(`update global URL = ${locationOrigin}`);
resolve(); resolve();
}).catch(() => { }).catch(() => {
// jump in the sign-in page (automatically of request remember-me) // jump in the sign-in page (automatically of request remember-me)
@ -118,7 +124,7 @@ export class UserService {
this.storageService.remove(this.cookiesRememberMe); this.storageService.remove(this.cookiesRememberMe);
this.storageService.remove(this.cookiesToken); this.storageService.remove(this.cookiesToken);
this.storageService.removeSession(this.cookiesToken); this.storageService.removeSession(this.cookiesToken);
self.ssoService.requestSignIn(); self.ssoService.requestSignIn(locationOrigin);
reject(); reject();
} }
resolve(); resolve();
@ -130,7 +136,7 @@ export class UserService {
this.storageService.remove(this.cookiesRememberMe); this.storageService.remove(this.cookiesRememberMe);
this.storageService.remove(this.cookiesToken); this.storageService.remove(this.cookiesToken);
this.storageService.removeSession(this.cookiesToken); this.storageService.removeSession(this.cookiesToken);
self.ssoService.requestSignIn(); self.ssoService.requestSignIn(locationOrigin);
reject(); reject();
} }
resolve(); resolve();

View File

@ -0,0 +1,17 @@
import { environment } from "environments/environment";
export function getApplicationLocation(): string {
let pathName = location.pathname;
//console.log("start Path-name: '" + pathName + "'");
//console.log("check with: '" + environment.applName + "/sso/" + "'");
if (pathName.startsWith('/' + environment.applName + '/')) {
pathName = pathName.substring(environment.applName.length+2);
} else if (pathName.startsWith('/' + environment.applName)) {
pathName = pathName.substring(environment.applName.length + 1);
} else if (pathName.startsWith(environment.applName + '/')) {
pathName = pathName.substring(environment.applName.length+1);
} else if (pathName.startsWith(environment.applName)) {
pathName = pathName.substring(environment.applName.length);
}
return pathName;
}

View File

@ -1,5 +1,6 @@
import { getApplicationLocation } from "./applPath";
import { DataInterface, TypeCheck } from "./dataInterface"; import { DataInterface, TypeCheck } from "./dataInterface";
import { isArray, isArrayOf, isBoolean, isNull, isNullOrUndefined, isNumber, isNumberFinite, isObject, isOptionalOf, isOptionalArrayOf, isString, isUndefined, isArrayOfs, isInArray, isStringNullOrUndefined } from "./validator"; import { isArray, isArrayOf, isBoolean, isNull, isNullOrUndefined, isNumber, isNumberFinite, isObject, isOptionalOf, isOptionalArrayOf, isString, isUndefined, isArrayOfs, isInArray, isStringNullOrUndefined } from "./validator";
@ -21,5 +22,6 @@ export {
isStringNullOrUndefined, isStringNullOrUndefined,
DataInterface, DataInterface,
TypeCheck, TypeCheck,
getApplicationLocation,
} }

View File

@ -4,7 +4,7 @@
// The list of which env maps to which file can be found in `.angular-cli.json`. // The list of which env maps to which file can be found in `.angular-cli.json`.
export const environment = { export const environment = {
production: false, production: true,
// URL of development API // URL of development API
applName: "karideo", applName: "karideo",
defaultServer: "karideo", defaultServer: "karideo",
@ -17,6 +17,6 @@ export const environment = {
ssoSignOut: `${location.origin}/karso/signout/karideo/`, ssoSignOut: `${location.origin}/karso/signout/karideo/`,
frontBaseUrl: '', frontBaseUrl: '',
tokenStoredInPermanentStorage: false, tokenStoredInPermanentStorage: false,
apiMode: 'REWRITE' //apiMode: 'REWRITE'
}; };

View File

@ -51,7 +51,7 @@ const environment_hybrid = {
ssoSignOut: 'http://192.168.1.156/karso/signout/karideo-dev/', ssoSignOut: 'http://192.168.1.156/karso/signout/karideo-dev/',
frontBaseUrl: '', frontBaseUrl: '',
tokenStoredInPermanentStorage: false, tokenStoredInPermanentStorage: false,
apiMode: 'REWRITE' //apiMode: 'REWRITE'
}; };