app.config and login

This commit is contained in:
Denys Vuika 2017-10-19 10:38:32 +01:00
parent eaf07c129a
commit 8809c1e122
11 changed files with 341 additions and 31 deletions

View File

@ -10,6 +10,7 @@
"assets": [ "assets": [
"assets", "assets",
"favicon-96x96.png", "favicon-96x96.png",
"app.config.json",
{ "glob": "**/*", "input": "../node_modules/ng2-alfresco-core/bundles/assets", "output": "./assets/" }, { "glob": "**/*", "input": "../node_modules/ng2-alfresco-core/bundles/assets", "output": "./assets/" },
{ "glob": "**/*", "input": "../node_modules/ng2-alfresco-datatable/bundles/assets", "output": "./assets/" }, { "glob": "**/*", "input": "../node_modules/ng2-alfresco-datatable/bundles/assets", "output": "./assets/" },

View File

@ -22,7 +22,7 @@
"@angular/material": "2.0.0-beta.10", "@angular/material": "2.0.0-beta.10",
"@angular/platform-browser": "4.3.6", "@angular/platform-browser": "4.3.6",
"@angular/platform-browser-dynamic": "4.3.6", "@angular/platform-browser-dynamic": "4.3.6",
"@angular/router": "~3.1.1", "@angular/router": "4.3.6",
"@ngx-translate/core": "7.0.0", "@ngx-translate/core": "7.0.0",
"alfresco-js-api": "1.9.0", "alfresco-js-api": "1.9.0",
"core-js": "^2.4.1", "core-js": "^2.4.1",

18
src/app.config.json Normal file
View File

@ -0,0 +1,18 @@
{
"ecmHost": "http://{hostname}:{port}/ecm",
"application": {
"name": "Alfresco Example Content Application",
"build": "1234"
},
"document-list": {
"supportedPageSizes": [25, 50, 100]
},
"files": {
"excluded": [
".DS_Store",
"desktop.ini",
"thumbs.db",
".git"
]
}
}

View File

@ -1,20 +1 @@
<!--The content below is only a placeholder and can be replaced.--> <router-outlet></router-outlet>
<div style="text-align:center">
<h1>
Welcome to {{title}}!
</h1>
<img width="300" src="">
</div>
<h2>Here are some links to help you start: </h2>
<ul>
<li>
<h2><a target="_blank" rel="noopener" href="https://angular.io/tutorial">Tour of Heroes</a></h2>
</li>
<li>
<h2><a target="_blank" rel="noopener" href="https://github.com/angular/angular-cli/wiki">CLI Documentation</a></h2>
</li>
<li>
<h2><a target="_blank" rel="noopener" href="https://blog.angular.io/">Angular blog</a></h2>
</li>
</ul>

View File

@ -1,10 +1,60 @@
import { Component } from '@angular/core'; /*!
* @license
* Copyright 2017 Alfresco Software, Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { Component, OnInit } from '@angular/core';
import { Router, ActivatedRoute, NavigationEnd } from '@angular/router';
import { TranslationService, PageTitleService } from 'ng2-alfresco-core';
@Component({ @Component({
selector: 'app-root', selector: 'app-root',
templateUrl: './app.component.html', templateUrl: './app.component.html',
styleUrls: ['./app.component.scss'] styleUrls: ['./app.component.scss']
}) })
export class AppComponent { export class AppComponent implements OnInit {
title = 'app'; constructor(
private route: ActivatedRoute,
private router: Router,
private pageTitle: PageTitleService,
private translateService: TranslationService) {
}
ngOnInit() {
const { router, pageTitle, route, translateService } = this;
router
.events
.filter(event => event instanceof NavigationEnd)
.subscribe(() => {
let currentRoute = route.root;
while (currentRoute.firstChild) {
currentRoute = currentRoute.firstChild;
}
const snapshot: any = currentRoute.snapshot || {};
const data: any = snapshot.data || {};
if (data.i18nTitle) {
translateService.get(data.i18nTitle).subscribe(title => {
pageTitle.setTitle(title);
});
} else {
pageTitle.setTitle(data.title || '');
}
});
}
} }

View File

@ -1,17 +1,25 @@
import { BrowserModule } from '@angular/platform-browser'; import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core'; import { NgModule } from '@angular/core';
import { RouterModule } from '@angular/router';
import { AdfModule } from './adf.module'; import { AdfModule } from './adf.module';
import { AppComponent } from './app.component'; import { AppComponent } from './app.component';
import { APP_ROUTES } from './app.routes';
import { LoginComponent } from './components/login/login.component';
@NgModule({ @NgModule({
declarations: [
AppComponent
],
imports: [ imports: [
BrowserModule, BrowserModule,
RouterModule.forRoot(APP_ROUTES, {
enableTracing: true
}),
AdfModule AdfModule
], ],
declarations: [
AppComponent,
LoginComponent
],
providers: [], providers: [],
bootstrap: [AppComponent] bootstrap: [AppComponent]
}) })

35
src/app/app.routes.ts Normal file
View File

@ -0,0 +1,35 @@
/*!
* @license
* Copyright 2017 Alfresco Software, Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { Routes } from '@angular/router';
import { LoginComponent } from './components/login/login.component';
export const APP_ROUTES: Routes = [
{
path: '**',
redirectTo: '/login',
pathMatch: 'full'
},
{
path: 'login',
component: LoginComponent,
data: {
title: 'Sign in'
}
}
];

View File

@ -0,0 +1,8 @@
<alfresco-login
#alfrescoLogin
copyrightText="&#169; 2017 Alfresco Software, Inc. All rights reserved."
providers="ECM"
[showRememberMe]="false"
[showLoginActions]="false"
(onSuccess)="onLoginSuccess($event)">
</alfresco-login>

View File

@ -0,0 +1,144 @@
/*!
* @license
* Copyright 2017 Alfresco Software, Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { RouterTestingModule } from '@angular/router/testing';
import { Router, ActivatedRoute } from '@angular/router';
import { TestBed, async } from '@angular/core/testing';
import { Observable } from 'rxjs/Rx';
import { AlfrescoAuthenticationService, UserPreferencesService } from 'ng2-alfresco-core';
import { LoginModule } from 'ng2-alfresco-login';
import { LoginComponent } from './login.component';
describe('LoginComponent', () => {
let router: Router;
let route: ActivatedRoute;
let authService: AlfrescoAuthenticationService;
let userPrefService: UserPreferencesService;
class TestConfig {
private testBed;
private componentInstance;
private fixture;
constructor(config: any = {}) {
const routerProvider = {
provide: Router,
useValue: {
navigateByUrl: jasmine.createSpy('navigateByUrl'),
navigate: jasmine.createSpy('navigate')
}
};
const authProvider = {
provide: AlfrescoAuthenticationService,
useValue: {
isEcmLoggedIn: jasmine.createSpy('navigateByUrl')
.and.returnValue(config.isEcmLoggedIn || false)
}
};
const preferencesProvider = {
provide: UserPreferencesService,
useValue: {
setStoragePrefix: jasmine.createSpy('setStoragePrefix')
}
};
this.testBed = TestBed.configureTestingModule({
imports: [
RouterTestingModule,
LoginModule
],
declarations: [
LoginComponent
],
providers: [
routerProvider,
authProvider,
preferencesProvider,
{
provide: ActivatedRoute,
useValue: {
params: Observable.of({ redirect: config.redirect })
}
}
]
});
this.fixture = TestBed.createComponent(LoginComponent);
this.componentInstance = this.fixture.componentInstance;
this.fixture.detectChanges();
}
get userPrefService() {
return TestBed.get(UserPreferencesService);
}
get authService() {
return TestBed.get(AlfrescoAuthenticationService);
}
get routerService() {
return TestBed.get(Router);
}
get component() {
return this.componentInstance;
}
}
it('load app when user is already logged in', () => {
const testConfig = new TestConfig({
isEcmLoggedIn: true
});
expect(testConfig.routerService.navigateByUrl).toHaveBeenCalled();
});
it('requires user to be logged in', () => {
const testConfig = new TestConfig({
isEcmLoggedIn: false,
redirect: '/personal-files'
});
expect(testConfig.routerService.navigate).toHaveBeenCalledWith(['/login', {}]);
});
describe('onLoginSuccess()', () => {
let testConfig;
beforeEach(() => {
testConfig = new TestConfig({
isEcmLoggedIn: false,
redirect: 'somewhere-over-the-rainbow'
});
});
it('redirects on success', () => {
testConfig.component.onLoginSuccess();
expect(testConfig.routerService.navigateByUrl).toHaveBeenCalledWith('somewhere-over-the-rainbow');
});
it('sets user preference store prefix', () => {
testConfig.component.onLoginSuccess({ username: 'bogus' });
expect(testConfig.userPrefService.setStoragePrefix).toHaveBeenCalledWith('bogus');
});
});
});

View File

@ -0,0 +1,69 @@
/*!
* @license
* Copyright 2017 Alfresco Software, Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { Component } from '@angular/core';
import { Router, ActivatedRoute } from '@angular/router';
import { Validators } from '@angular/forms';
import { AlfrescoAuthenticationService, UserPreferencesService } from 'ng2-alfresco-core';
const skipRedirectUrls: string[] = [
'/logout',
'/personal-files'
];
@Component({
templateUrl: './login.component.html'
})
export class LoginComponent {
private redirectUrl = '';
constructor(
private router: Router,
private route: ActivatedRoute,
private auth: AlfrescoAuthenticationService,
private userPreferences: UserPreferencesService
) {
if (auth.isEcmLoggedIn()) {
this.redirect();
}
route.params.subscribe((params: any) => {
if (skipRedirectUrls.indexOf(params.redirect) > -1) {
const remainingParams = Object.assign({}, params);
delete remainingParams.redirect;
router.navigate(['/login', remainingParams]);
}
this.redirectUrl = params.redirect;
});
}
redirect() {
this.router.navigateByUrl(this.redirectUrl || '');
}
onLoginSuccess(data) {
if (data && data.username) {
this.userPreferences.setStoragePrefix(data.username);
}
this.redirect();
}
}

View File

@ -164,10 +164,6 @@
dependencies: dependencies:
tslib "^1.7.1" tslib "^1.7.1"
"@angular/router@~3.1.1":
version "3.1.2"
resolved "https://registry.yarnpkg.com/@angular/router/-/router-3.1.2.tgz#1046c943ace795027e2e5057df8c897da968fcd6"
"@angular/tsc-wrapped@4.3.6": "@angular/tsc-wrapped@4.3.6":
version "4.3.6" version "4.3.6"
resolved "https://registry.yarnpkg.com/@angular/tsc-wrapped/-/tsc-wrapped-4.3.6.tgz#1aa66e0ab2c4799a4ad14b675e13953aa5fcd436" resolved "https://registry.yarnpkg.com/@angular/tsc-wrapped/-/tsc-wrapped-4.3.6.tgz#1aa66e0ab2c4799a4ad14b675e13953aa5fcd436"