Merge pull request 'All users get profile pics feature/79-profile_pics' (#81) from feature/79-profile_pics into dev
Some checks failed
continuous-integration/drone/push Build is failing
Some checks failed
continuous-integration/drone/push Build is failing
Reviewed-on: #81 closes #79
This commit is contained in:
commit
d2fdb4efd9
@ -29,7 +29,7 @@ export class UserController {
|
|||||||
@OpenAPI({ description: 'Lists all users. <br> This includes their groups and permissions directly granted to them (if existing/associated).' })
|
@OpenAPI({ description: 'Lists all users. <br> This includes their groups and permissions directly granted to them (if existing/associated).' })
|
||||||
async getAll() {
|
async getAll() {
|
||||||
let responseUsers: ResponseUser[] = new Array<ResponseUser>();
|
let responseUsers: ResponseUser[] = new Array<ResponseUser>();
|
||||||
const users = await this.userRepository.find({ relations: ['permissions', 'groups'] });
|
const users = await this.userRepository.find({ relations: ['permissions', 'groups', 'groups.permissions'] });
|
||||||
users.forEach(user => {
|
users.forEach(user => {
|
||||||
responseUsers.push(new ResponseUser(user));
|
responseUsers.push(new ResponseUser(user));
|
||||||
});
|
});
|
||||||
@ -43,7 +43,7 @@ export class UserController {
|
|||||||
@OnUndefined(UserNotFoundError)
|
@OnUndefined(UserNotFoundError)
|
||||||
@OpenAPI({ description: 'Lists all information about the user whose id got provided. <br> Please remember that only permissions granted directly to the user will show up here, not permissions inherited from groups.' })
|
@OpenAPI({ description: 'Lists all information about the user whose id got provided. <br> Please remember that only permissions granted directly to the user will show up here, not permissions inherited from groups.' })
|
||||||
async getOne(@Param('id') id: number) {
|
async getOne(@Param('id') id: number) {
|
||||||
let user = await this.userRepository.findOne({ id: id }, { relations: ['permissions', 'groups'] })
|
let user = await this.userRepository.findOne({ id: id }, { relations: ['permissions', 'groups', 'groups.permissions'] })
|
||||||
if (!user) { throw new UserNotFoundError(); }
|
if (!user) { throw new UserNotFoundError(); }
|
||||||
return new ResponseUser(user);
|
return new ResponseUser(user);
|
||||||
}
|
}
|
||||||
|
@ -106,23 +106,6 @@ export class JwtUser {
|
|||||||
this.refreshTokenCount = user.refreshTokenCount;
|
this.refreshTokenCount = user.refreshTokenCount;
|
||||||
this.uuid = user.uuid;
|
this.uuid = user.uuid;
|
||||||
this.profilePic = user.profilePic;
|
this.profilePic = user.profilePic;
|
||||||
this.permissions = this.getPermissions(user);
|
this.permissions = user.allPermissions;
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Handels getting the permissions granted to this user (direct or indirect).
|
|
||||||
* @param user User which's permissions shall be gotten.
|
|
||||||
*/
|
|
||||||
public getPermissions(user: User): string[] {
|
|
||||||
let returnPermissions: string[] = new Array<string>();
|
|
||||||
for (let permission of user.permissions) {
|
|
||||||
returnPermissions.push(permission.toString());
|
|
||||||
}
|
|
||||||
for (let group of user.groups) {
|
|
||||||
for (let permission of group.permissions) {
|
|
||||||
returnPermissions.push(permission.toString());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return Array.from(new Set(returnPermissions));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,5 +1,5 @@
|
|||||||
import * as argon2 from "argon2";
|
import * as argon2 from "argon2";
|
||||||
import { IsBoolean, IsEmail, IsOptional, IsPhoneNumber, IsString } from 'class-validator';
|
import { IsBoolean, IsEmail, IsOptional, IsPhoneNumber, IsString, IsUrl } from 'class-validator';
|
||||||
import { getConnectionManager } from 'typeorm';
|
import { getConnectionManager } from 'typeorm';
|
||||||
import * as uuid from 'uuid';
|
import * as uuid from 'uuid';
|
||||||
import { config } from '../../config';
|
import { config } from '../../config';
|
||||||
@ -78,7 +78,13 @@ export class CreateUser {
|
|||||||
@IsOptional()
|
@IsOptional()
|
||||||
groups?: number[] | number
|
groups?: number[] | number
|
||||||
|
|
||||||
//TODO: ProfilePics
|
/**
|
||||||
|
* The user's profile pic (or rather a url pointing to it).
|
||||||
|
*/
|
||||||
|
@IsString()
|
||||||
|
@IsUrl()
|
||||||
|
@IsOptional()
|
||||||
|
profilePic?: string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts this to a User entity.
|
* Converts this to a User entity.
|
||||||
@ -100,7 +106,9 @@ export class CreateUser {
|
|||||||
newUser.password = await argon2.hash(this.password + newUser.uuid);
|
newUser.password = await argon2.hash(this.password + newUser.uuid);
|
||||||
newUser.groups = await this.getGroups();
|
newUser.groups = await this.getGroups();
|
||||||
newUser.enabled = this.enabled;
|
newUser.enabled = this.enabled;
|
||||||
//TODO: ProfilePics
|
|
||||||
|
if (!this.profilePic) { newUser.profilePic = `https://dev.lauf-fuer-kaya.de/lfk-logo.png`; }
|
||||||
|
else { newUser.profilePic = this.profilePic; }
|
||||||
|
|
||||||
return newUser;
|
return newUser;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import * as argon2 from "argon2";
|
import * as argon2 from "argon2";
|
||||||
import { IsBoolean, IsEmail, IsInt, IsOptional, IsPhoneNumber, IsString } from 'class-validator';
|
import { IsBoolean, IsEmail, IsInt, IsOptional, IsPhoneNumber, IsString, IsUrl } from 'class-validator';
|
||||||
import { getConnectionManager } from 'typeorm';
|
import { getConnectionManager } from 'typeorm';
|
||||||
import { config } from '../../config';
|
import { config } from '../../config';
|
||||||
import { UsernameOrEmailNeededError } from '../../errors/AuthError';
|
import { UsernameOrEmailNeededError } from '../../errors/AuthError';
|
||||||
@ -87,7 +87,16 @@ export class UpdateUser {
|
|||||||
groups?: UserGroup[]
|
groups?: UserGroup[]
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Updates a provided User entity based on this.
|
* The user's profile pic (or rather a url pointing to it).
|
||||||
|
*/
|
||||||
|
@IsString()
|
||||||
|
@IsUrl()
|
||||||
|
@IsOptional()
|
||||||
|
profilePic?: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Updates a user entity based on this.
|
||||||
|
* @param user The user that shall be updated.
|
||||||
*/
|
*/
|
||||||
public async updateUser(user: User): Promise<User> {
|
public async updateUser(user: User): Promise<User> {
|
||||||
user.email = this.email;
|
user.email = this.email;
|
||||||
@ -106,7 +115,9 @@ export class UpdateUser {
|
|||||||
user.lastname = this.lastname
|
user.lastname = this.lastname
|
||||||
user.phone = this.phone;
|
user.phone = this.phone;
|
||||||
user.groups = await this.getGroups();
|
user.groups = await this.getGroups();
|
||||||
//TODO: ProfilePics
|
|
||||||
|
if (!this.profilePic) { user.profilePic = `https://dev.lauf-fuer-kaya.de/lfk-logo.png`; }
|
||||||
|
else { user.profilePic = this.profilePic; }
|
||||||
|
|
||||||
return user;
|
return user;
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { IsBoolean, IsEmail, IsInt, IsNotEmpty, IsOptional, IsPhoneNumber, IsString, IsUUID } from "class-validator";
|
import { IsBoolean, IsEmail, IsInt, IsNotEmpty, IsOptional, IsPhoneNumber, IsString, IsUrl, IsUUID } from "class-validator";
|
||||||
import { ChildEntity, Column, JoinTable, ManyToMany, OneToMany } from "typeorm";
|
import { ChildEntity, Column, JoinTable, ManyToMany, OneToMany } from "typeorm";
|
||||||
import { config } from '../../config';
|
import { config } from '../../config';
|
||||||
import { ResponsePrincipal } from '../responses/ResponsePrincipal';
|
import { ResponsePrincipal } from '../responses/ResponsePrincipal';
|
||||||
@ -106,10 +106,10 @@ export class User extends Principal {
|
|||||||
* The user's profile picture.
|
* The user's profile picture.
|
||||||
* We haven't decided yet if this will be a bas64 encoded image or just a link to the profile picture.
|
* We haven't decided yet if this will be a bas64 encoded image or just a link to the profile picture.
|
||||||
*/
|
*/
|
||||||
@Column({ nullable: true, unique: false })
|
@Column({ nullable: false, unique: false })
|
||||||
@IsString()
|
@IsString()
|
||||||
@IsOptional()
|
@IsUrl()
|
||||||
profilePic?: string;
|
profilePic: string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The last time the user requested a password reset.
|
* The last time the user requested a password reset.
|
||||||
@ -128,6 +128,26 @@ export class User extends Principal {
|
|||||||
@OneToMany(() => UserAction, action => action.user, { nullable: true })
|
@OneToMany(() => UserAction, action => action.user, { nullable: true })
|
||||||
actions: UserAction[]
|
actions: UserAction[]
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resolves all permissions granted to this user through groups or directly to the string enum format.
|
||||||
|
*/
|
||||||
|
public get allPermissions(): string[] {
|
||||||
|
let returnPermissions: string[] = new Array<string>();
|
||||||
|
|
||||||
|
if (!this.permissions) { return returnPermissions; }
|
||||||
|
for (let permission of this.permissions) {
|
||||||
|
returnPermissions.push(permission.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!this.groups) { return returnPermissions; }
|
||||||
|
for (let group of this.groups) {
|
||||||
|
for (let permission of group.permissions) {
|
||||||
|
returnPermissions.push(permission.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Array.from(new Set(returnPermissions));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Turns this entity into it's response class.
|
* Turns this entity into it's response class.
|
||||||
*/
|
*/
|
||||||
|
@ -5,7 +5,6 @@ import {
|
|||||||
IsOptional,
|
IsOptional,
|
||||||
IsString
|
IsString
|
||||||
} from "class-validator";
|
} from "class-validator";
|
||||||
import { Permission } from '../entities/Permission';
|
|
||||||
import { User } from '../entities/User';
|
import { User } from '../entities/User';
|
||||||
import { UserGroup } from '../entities/UserGroup';
|
import { UserGroup } from '../entities/UserGroup';
|
||||||
import { ResponsePrincipal } from './ResponsePrincipal';
|
import { ResponsePrincipal } from './ResponsePrincipal';
|
||||||
@ -57,11 +56,10 @@ export class ResponseUser extends ResponsePrincipal {
|
|||||||
enabled: boolean = true;
|
enabled: boolean = true;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The user's profile pic.
|
* The user's profile pic (or rather a url pointing to it).
|
||||||
*/
|
*/
|
||||||
@IsString()
|
@IsString()
|
||||||
@IsOptional()
|
profilePic: string;
|
||||||
profilePic?: string;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The groups that the user is a part of.
|
* The groups that the user is a part of.
|
||||||
@ -75,7 +73,7 @@ export class ResponseUser extends ResponsePrincipal {
|
|||||||
*/
|
*/
|
||||||
@IsArray()
|
@IsArray()
|
||||||
@IsOptional()
|
@IsOptional()
|
||||||
permissions: Permission[];
|
permissions: string[];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a ResponseUser object from a user.
|
* Creates a ResponseUser object from a user.
|
||||||
@ -92,6 +90,7 @@ export class ResponseUser extends ResponsePrincipal {
|
|||||||
this.enabled = user.enabled;
|
this.enabled = user.enabled;
|
||||||
this.profilePic = user.profilePic;
|
this.profilePic = user.profilePic;
|
||||||
this.groups = user.groups;
|
this.groups = user.groups;
|
||||||
this.permissions = user.permissions;
|
this.permissions = user.allPermissions;
|
||||||
|
this.groups.forEach(function (g) { delete g.permissions });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user