1
0
mirror of https://github.com/dkmstr/openuds-gui.git synced 2025-01-03 05:17:36 +03:00

advancing on custom login

This commit is contained in:
Adolfo Gómez García 2018-08-21 13:27:10 +02:00
parent 6045519cd8
commit 976547004b
11 changed files with 291 additions and 220 deletions

View File

@ -1,32 +1,52 @@
{
"/js": {
"target": {
"host": "172.27.0.1",
"protocol": "http:",
"port": 8000
},
"secure": false,
"changeOrigin": true,
"logLevel": "info"
"/js": {
"target": {
"host": "172.27.0.1",
"protocol": "http:",
"port": 8000
},
"/info": {
"target": {
"host": "172.27.0.1",
"protocol": "http:",
"port": 8000
},
"secure": false,
"changeOrigin": true,
"logLevel": "info"
},
"/log.*": {
"target": {
"host": "172.27.0.1",
"protocol": "http:",
"port": 8000
},
"secure": false,
"changeOrigin": true,
"logLevel": "info"
}
}
"secure": false,
"changeOrigin": true,
"logLevel": "info"
},
"/info": {
"target": {
"host": "172.27.0.1",
"protocol": "http:",
"port": 8000
},
"secure": false,
"changeOrigin": true,
"logLevel": "info"
},
"/i18n": {
"target": {
"host": "172.27.0.1",
"protocol": "http:",
"port": 8000
},
"secure": false,
"changeOrigin": true,
"logLevel": "info"
},
"/log.*": {
"target": {
"host": "172.27.0.1",
"protocol": "http:",
"port": 8000
},
"secure": false,
"changeOrigin": true,
"logLevel": "info"
},
"/customAuth": {
"target": {
"host": "172.27.0.1",
"protocol": "http:",
"port": 8000
},
"secure": false,
"changeOrigin": true,
"logLevel": "info"
}
}

View File

@ -15,7 +15,6 @@ import { LoginComponent } from './login/login.component';
import { ClientDownloadComponent } from './client-download/client-download.component';
import { ServicesComponent } from './services/services.component';
@NgModule({
declarations: [
AppComponent,

View File

@ -69,4 +69,4 @@
.card.fat .card-body {
padding: 15px;
}
}
}

View File

@ -23,15 +23,12 @@
<input id="password" type="password" class="form-control" name="password" data-eye>
</div>
<div class="form-group" *ngIf="false">
<div class="form-group" *ngIf="auths.length > 1">
<label>
<uds-translate>Authenticator</uds-translate>
</label>
<select class="custom-select">
<option selected>Selected AUTH</option>
<option value="1">One</option>
<option value="2">Two</option>
<option value="3">Three</option>
<select class="custom-select" (change)="changeAuth($event.target.value)">
<option *ngFor="let a of auths" value="{{ a.id }}">{{ a.name }}</option>
</select>
</div>

View File

@ -1,5 +1,5 @@
import { Component, OnInit } from '@angular/core';
import { UdsApiService, Downloadable } from '../uds-api.service';
import { UdsApiService, Authenticator } from '../uds-api.service';
@Component({
selector: 'uds-login',
@ -7,10 +7,31 @@ import { UdsApiService, Downloadable } from '../uds-api.service';
styleUrls: ['./login.component.css']
})
export class LoginComponent implements OnInit {
auths: Authenticator[];
constructor(public api: UdsApiService) { }
constructor(public api: UdsApiService) {
this.auths = api.config.authenticators.slice(0);
// Sort array, so we can display it correctly
this.auths.sort((a, b) => a.priority - b.priority);
}
ngOnInit() {
}
changeAuth(auth) {
function doChangeAuth(result: string) {
alert(result);
}
for (const l of this.auths) {
if (l.id === auth) {
if (l.is_custom) { // If is custom, we should get the code from server to authentication
this.api.getAuthCustomHtml(l.id)
.subscribe(result => doChangeAuth(result));
}
}
}
}
}

View File

@ -1,36 +1,52 @@
<nav class="navbar navbar-expand-md navbar-light bg-light fixed-top">
<a class="navbar-brand" routerLink="/">
<img alt="Universal Desktop Services" src="/static/modern/img/udsicon.png" class="navbar-img pull-left">
<img alt="Universal Desktop Services" src="/static/modern/img/udsicon.png" class="navbar-img pull-left">
</a>
<button class="navbar-toggler" type="button" (click)="isNavbarCollapsed = !isNavbarCollapsed" data-target="#navbarUDS" aria-controls="navbarUDS" aria-expanded="false" aria-label="Toggle navigation">
<button class="navbar-toggler" type="button" (click)="isNavbarCollapsed = !isNavbarCollapsed" data-target="#navbarUDS" aria-controls="navbarUDS"
aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div [ngbCollapse]="isNavbarCollapsed" class="navbar-collapse" id="navbarUDS">
<ul class="navbar-nav ml-auto">
<li class="nav-item">
<a class="nav-link" routerLink="/client-download"><i class="fa fa-download"></i> UDS Plugin</a>
<a class="nav-link" routerLink="/client-download">
<i class="fa fa-download"></i> UDS Plugin</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#"><uds-translate>About</uds-translate></a>
<a class="nav-link" href="#">
<uds-translate>About</uds-translate>
</a>
</li>
<li class="nav-item dropdown dropdown-menu-right" ngbDropdown>
<a class="nav-link dropdown-toggle" id="navbarLangDropdown" ngbDropdownToggle>{{ lang }}</a>
<div class="dropdown-menu dropdown-menu-right" aria-labelledby="navbarLangDropdown" ngbDropdownMenu>
<a class="dropdown-item" href="#" *ngFor="let l of langs">{{ l.name }}</a>
</div>
<form id="form_language" action="{{ api.config.urls.changeLang }}" method="post">
<input type="hidden" name="{{ api.config.csrf_field }}" value="{{ api.config.csrf }}" >
<input id="id_language" type="hidden" name="language" value="{{ lang.id }}" />
<a class="nav-link dropdown-toggle" id="navbarLangDropdown" ngbDropdownToggle>{{ lang.name }}</a>
<div class="dropdown-menu dropdown-menu-right" aria-labelledby="navbarLangDropdown" ngbDropdownMenu>
<a class="dropdown-item" href="#" (click)="changeLang(l)" *ngFor="let l of langs">{{ l.name }}</a>
</div>
</form>
</li>
<li *ngIf="api.user.isLogged" class="nav-item dropdown dropdown-menu-right" ngbDropdown>
<a class="nav-link dropdown-toggle" id="navbarUserDropdown" ngbDropdownToggle>{{ api.user.user }}</a>
<div class="dropdown-menu dropdown-menu-right" aria-labelledby="navbarUserDropdown" ngbDropdownMenu>
<a class="dropdown-item" href="#"><uds-translate>Preferences</uds-translate></a>
<a class="dropdown-item" href="#"><uds-translate>Dashboard</uds-translate></a>
<a class="dropdown-item" href="#"><uds-translate>Downloads</uds-translate></a>
<a class="dropdown-item" href="{{ api.urls.logout }}"><uds-translate>Logout</uds-translate></a>
<a class="dropdown-item" href="#">
<uds-translate>Preferences</uds-translate>
</a>
<a class="dropdown-item" href="#">
<uds-translate>Dashboard</uds-translate>
</a>
<a class="dropdown-item" href="#">
<uds-translate>Downloads</uds-translate>
</a>
<a class="dropdown-item" href="{{ api.config.urls.logout }}">
<uds-translate>Logout</uds-translate>
</a>
</div>
</li>
</ul>
</div>
</nav>
</nav>

View File

@ -7,18 +7,17 @@ import { UdsApiService, Lang } from '../uds-api.service';
styleUrls: ['./navbar.component.css']
})
export class NavbarComponent implements OnInit {
lang: string; // Current language
lang: Lang; // Current language
langs: Lang[]; // Available languages
isNavbarCollapsed = true;
constructor(public api: UdsApiService) {
const lang = api.currentLanguage;
const lang = api.config.language;
// Add "non current lang" to list
this.langs = [];
for (const l of api.availableLanguages) {
for (const l of api.config.available_languages) {
if (l.id === lang) {
this.lang = l.name;
this.lang = l;
} else {
this.langs.push(l);
}
@ -28,4 +27,13 @@ export class NavbarComponent implements OnInit {
ngOnInit() {
}
changeLang(to: Lang): boolean {
// alert(document.getElementById('form_language'));
this.lang = to;
document.getElementById('id_language').attributes['value'].value = to.id;
// alert(document.getElementById('id_language').attributes['value'].value);
(<any>document.getElementById('form_language')).submit();
return false;
}
}

View File

@ -10,7 +10,7 @@ import { Router } from '@angular/router';
export class ServicesComponent implements OnInit {
constructor(private api: UdsApiService, private router: Router) {
}
}
ngOnInit() {
// Redirect, if not logged in, to login screen

View File

@ -9,6 +9,7 @@ export class TranslateDirective implements OnInit {
constructor(private el: ElementRef) { }
ngOnInit() {
// Simply substitute outer html with translation
this.el.nativeElement.outerHTML = django.gettext(this.el.nativeElement.innerHTML);
}

View File

@ -6,6 +6,32 @@ export interface Lang {
readonly name: string;
}
export interface Authenticator {
id: string;
name: string;
label: string;
priority: number;
is_custom: string;
}
// URLs related
export interface UDSUrls {
readonly changeLang: string;
readonly login: string;
readonly logout: string;
readonly customAuth: string;
}
export interface UDSConfig {
language: string;
available_languages: Lang[];
authenticators: Authenticator[];
os: string;
csrf_field: string;
csrf: string;
urls: UDSUrls;
}
export interface Downloadable {
readonly url: string;
readonly description: string;
@ -17,14 +43,6 @@ export interface Profile {
readonly role: string;
}
export interface Authenticator {
id: string;
name: string;
label: string;
priority: number;
is_custom: string;
}
// User related
export class User {
readonly user: string;
@ -44,13 +62,6 @@ export class User {
}
}
// URLs related
export interface UDSUrls {
readonly changeLang: string;
readonly login: string;
readonly logout: string;
}
@Injectable()
export class UdsApiService {
readonly user: User;
@ -59,23 +70,15 @@ export class UdsApiService {
this.user = new User(udsData.profile);
}
get currentLanguage(): string {
return udsData.config.language;
}
get availableLanguages(): Lang[] {
return udsData.config.available_languages;
get config(): UDSConfig {
return udsData.config;
}
get plugins(): Downloadable[] {
return udsData.plugins;
}
get urls(): UDSUrls {
return udsData.config.urls;
}
get authenticators(): Authenticator {
return udsData.authenticators;
getAuthCustomHtml(authId) {
return this.http.get(this.config.urls.customAuth + authId, {responseType: 'text'});
}
}

View File

@ -1,150 +1,156 @@
var udsData = {
"plugins": [{
"url": "/static/clients/UDSClientSetup-3.x.x-DEVEL.exe",
"name": "Windows",
"description": "Windows plugin",
"url": "/static/clients/UDSClientSetup-3.x.x-DEVEL.exe"
"description": "Windows plugin"
}, {
"url": "/static/clients/UDSClient-3.x.x-DEVEL.pkg",
"name": "MacOS",
"description": "Mac OS X plugin",
"url": "/static/clients/UDSClient-3.x.x-DEVEL.pkg"
"description": "Mac OS X plugin"
}, {
"url": "/static/udsclient_3.x.x-DEVEL_all.deb",
"name": "Linux",
"description": "Debian based Linux (requires Python-2.7)",
"url": "/static/udsclient_3.x.x-DEVEL_all.deb"
"description": "Debian based Linux (requires Python-2.7)"
}, {
"url": "/static/udsclient-3.x.x-DEVEL-1.noarch.rpm",
"name": "Linux",
"description": "Red Hat based Linux (RH, Fedora, Centos, ...) (requires Python-2.7)",
"url": "/static/udsclient-3.x.x-DEVEL-1.noarch.rpm"
"description": "Red Hat based Linux (RH, Fedora, Centos, ...) (requires Python-2.7)"
}, {
"url": "/static/udsclient-opensuse-3.x.x-DEVEL-1.noarch.rpm",
"name": "Linux",
"description": "Suse based Linux (requires Python-2.7)",
"url": "/static/udsclient-opensuse-3.x.x-DEVEL-1.noarch.rpm"
"description": "Suse based Linux (requires Python-2.7)"
}, {
"url": "/static/udsclient-3.x.x-DEVEL.tar.gz",
"name": "Linux",
"description": "Generic .tar.gz Linux (requires Python-2.7)",
"url": "/static/udsclient-3.x.x-DEVEL.tar.gz"
"description": "Generic .tar.gz Linux (requires Python-2.7)"
}],
"config": {
"urls": {
"login": "/login/",
"logout": "/logout",
"lang": "/i18n/setlang/"
},
"language": "en",
"authenticators": [{
"priority": 1,
"id": "d875c59c-7e19-5e3d-afac-f52f54789f10",
"label": "adregexp",
"is_custom": false,
"name": "00-AD W2012 REGEXP"
}, {
"priority": 1,
"id": "fbf0727a-e754-5f17-a0fd-bd8c1850b355",
"label": "ad",
"is_custom": false,
"name": "AD"
}, {
"priority": 2,
"id": "3613AA7E-E32A-5D05-BCFE-4E2C3E735EE3",
"label": "casa",
"is_custom": true,
"name": "Casa"
}, {
"priority": 1,
"id": "9EB0689D-DF66-54FF-8E7A-3C11E3F42A1A",
"label": "differ",
"is_custom": false,
"name": "different"
}, {
"priority": -2,
"id": "9803FC06-D8B3-5F11-9A6E-EEC905C017FD",
"label": "int",
"is_custom": false,
"name": "Interna"
}, {
"priority": 1,
"id": "53a53965-8a90-5e3b-96c4-91937d0042f0",
"label": "read",
"is_custom": false,
"name": "Ldap AD por RegEx"
}, {
"priority": 1,
"id": "729B2DB5-115F-5AA6-8C0A-32F3FBACF1D4",
"label": "sldap",
"is_custom": false,
"name": "Ldap AUTH"
}, {
"priority": 1,
"id": "4A574A66-65DD-5B6B-8D6F-5A53B95A0A58",
"label": "luca",
"is_custom": false,
"name": "LDAP UCA"
}, {
"priority": 1,
"id": "9f111569-d608-5426-b9f7-a9b4b928fd2d",
"label": "inval",
"is_custom": true,
"name": "Red invalida"
}, {
"priority": 1,
"id": "35698ffd-597a-5daa-9699-c87abed274f0",
"label": "sam",
"is_custom": true,
"name": "SAM"
}, {
"priority": 1,
"id": "8e2d796e-5f69-55c7-86c9-ccc1437ae8fe",
"label": "saml2",
"is_custom": true,
"name": "saml"
}, {
"priority": 1,
"id": "cd996fec-fd5a-59eb-9eb4-ec28af3cc8f7",
"label": "saml",
"is_custom": true,
"name": "SAMLOCAL"
}, {
"priority": 1,
"id": "3EAC3F30-0148-5041-986D-CE25737FEF81",
"label": "test",
"is_custom": false,
"name": "test"
}],
"csrf": "TX38YikWuXAmThwdOM9gbbjTnDffQQewl57xH7IVFJTEIbHdYDO0bwoI9uWuhuiI",
"csrf_field": "csrfmiddlewaretoken",
"os": "Windows",
"available_languages": [{
"id": "es",
"name": "Spanish"
}, {
"id": "en",
"name": "English"
}, {
"id": "fr",
"name": "French"
}, {
"id": "de",
"name": "German"
}, {
"id": "pt",
"name": "Portuguese"
}, {
"id": "it",
"name": "Italian"
}, {
"id": "eu",
"name": "Basque"
}, {
"id": "ar",
"name": "Arabian"
}, {
"id": "ca",
"name": "Catalan"
}]
},
"actors": [],
"profile": {
"user": null,
"role": "user"
}
},
"urls": {
"customAuth": "/customAuth/"
},
"config": {
"authenticators": [{
"label": "adregexp",
"is_custom": false,
"name": "00-AD W2012 REGEXP",
"id": "d875c59c-7e19-5e3d-afac-f52f54789f10",
"priority": 1
}, {
"label": "ad",
"is_custom": false,
"name": "AD",
"id": "fbf0727a-e754-5f17-a0fd-bd8c1850b355",
"priority": 1
}, {
"label": "casa",
"is_custom": true,
"name": "Casa",
"id": "3613AA7E-E32A-5D05-BCFE-4E2C3E735EE3",
"priority": 2
}, {
"label": "differ",
"is_custom": false,
"name": "different",
"id": "9EB0689D-DF66-54FF-8E7A-3C11E3F42A1A",
"priority": 1
}, {
"label": "int",
"is_custom": false,
"name": "Interna",
"id": "9803FC06-D8B3-5F11-9A6E-EEC905C017FD",
"priority": -2
}, {
"label": "read",
"is_custom": false,
"name": "Ldap AD por RegEx",
"id": "53a53965-8a90-5e3b-96c4-91937d0042f0",
"priority": 1
}, {
"label": "sldap",
"is_custom": false,
"name": "Ldap AUTH",
"id": "729B2DB5-115F-5AA6-8C0A-32F3FBACF1D4",
"priority": 1
}, {
"label": "luca",
"is_custom": false,
"name": "LDAP UCA",
"id": "4A574A66-65DD-5B6B-8D6F-5A53B95A0A58",
"priority": 1
}, {
"label": "inval",
"is_custom": true,
"name": "Red invalida",
"id": "9f111569-d608-5426-b9f7-a9b4b928fd2d",
"priority": 1
}, {
"label": "sam",
"is_custom": true,
"name": "SAM",
"id": "35698ffd-597a-5daa-9699-c87abed274f0",
"priority": 1
}, {
"label": "saml2",
"is_custom": true,
"name": "saml",
"id": "8e2d796e-5f69-55c7-86c9-ccc1437ae8fe",
"priority": 1
}, {
"label": "saml",
"is_custom": true,
"name": "SAMLOCAL",
"id": "cd996fec-fd5a-59eb-9eb4-ec28af3cc8f7",
"priority": 1
}, {
"label": "test",
"is_custom": false,
"name": "test",
"id": "3EAC3F30-0148-5041-986D-CE25737FEF81",
"priority": 1
}],
"urls": {
"changeLang": "/i18n/setlang/",
"login": "/login/",
"logout": "/logout"
},
"language": "en",
"csrf_field": "csrfmiddlewaretoken",
"os": "Unknown",
"available_languages": [{
"name": "Spanish",
"id": "es"
}, {
"name": "English",
"id": "en"
}, {
"name": "French",
"id": "fr"
}, {
"name": "German",
"id": "de"
}, {
"name": "Portuguese",
"id": "pt"
}, {
"name": "Italian",
"id": "it"
}, {
"name": "Basque",
"id": "eu"
}, {
"name": "Arabian",
"id": "ar"
}, {
"name": "Russian",
"id": "ru"
}, {
"name": "Catalan",
"id": "ca"
}],
"csrf": "qXZDMXz5VCXKijMb4Olx2hyVzJL8cirNNBKtVGTivRZl8mlagGIq08ov3ScIxhUn"
},
"actors": []
};