From 7c4bd5e879bae7bedc01d153c2e48bd0adf856f7 Mon Sep 17 00:00:00 2001 From: nicolas-arnaud Date: Sun, 5 Mar 2023 10:31:13 +0100 Subject: [PATCH] connected friends part to back --- back/volume/src/auth/42.strategy.ts | 2 +- back/volume/src/chat/chat.gateway.ts | 11 +- back/volume/src/main.ts | 2 +- back/volume/src/users/users.controller.ts | 30 ++-- back/volume/src/users/users.service.ts | 22 +-- front/volume/package-lock.json | 152 ------------------ front/volume/package.json | 1 - front/volume/src/App.svelte | 163 +++++++++++--------- front/volume/src/Auth.ts | 29 ++-- front/volume/src/components/Channels.svelte | 158 +++++++++---------- front/volume/src/components/Chat2.svelte | 10 +- front/volume/src/components/Friends.svelte | 44 ++++-- front/volume/src/components/NavBar.svelte | 24 +-- front/volume/src/components/Profile.svelte | 51 +++--- 14 files changed, 287 insertions(+), 412 deletions(-) diff --git a/back/volume/src/auth/42.strategy.ts b/back/volume/src/auth/42.strategy.ts index 4cd9ea1..0677f00 100644 --- a/back/volume/src/auth/42.strategy.ts +++ b/back/volume/src/auth/42.strategy.ts @@ -36,7 +36,7 @@ export class FtStrategy extends PassportStrategy(Strategy, '42') { if ((await this.usersService.findUser(ftId)) === null) { const newUser = new User() newUser.ftId = profile.id as number - newUser.username = profile.displayName as string + newUser.username = profile.username as string newUser.avatar = ftId + '.jpg' this.usersService.create(newUser) const file = createWriteStream('avatars/' + ftId + '.jpg') diff --git a/back/volume/src/chat/chat.gateway.ts b/back/volume/src/chat/chat.gateway.ts index 3c54471..4027e2a 100644 --- a/back/volume/src/chat/chat.gateway.ts +++ b/back/volume/src/chat/chat.gateway.ts @@ -37,8 +37,10 @@ export class ChatGateway implements OnGatewayConnection, OnGatewayDisconnect { async handleConnection (socket: Socket) { try { - const user: User | null = await this.userService.findUser(socket.data.user.ftId) - if (!user) { + const user: User | null = await this.userService.findUser( + socket.data.user.ftId + ) + if (user == null) { socket.emit('Error', new UnauthorizedException()) // socket.disconnect(); return @@ -66,8 +68,7 @@ export class ChatGateway implements OnGatewayConnection, OnGatewayDisconnect { const channel = new Channel() channel.name = channeldto.name const owner = await this.userService.findUser(channeldto.owner) - if (!owner) - return null; + if (owner == null) return null channel.owners.push(owner) channel.password = channeldto.password /// .../// @@ -98,7 +99,7 @@ export class ChatGateway implements OnGatewayConnection, OnGatewayDisconnect { const channel = await this.chatService.getChannel( createdMessage.channel.id ) - if (channel) { + if (channel != null) { const users = await this.userService.findOnlineInChannel(channel) } /// TODO: Send message to users diff --git a/back/volume/src/main.ts b/back/volume/src/main.ts index 9988e43..379c854 100644 --- a/back/volume/src/main.ts +++ b/back/volume/src/main.ts @@ -7,7 +7,7 @@ import * as session from 'express-session' import * as passport from 'passport' import { type NestExpressApplication } from '@nestjs/platform-express' import * as cookieParser from 'cookie-parser' -import { Response } from 'express'; +import { Response } from 'express' async function bootstrap () { const logger = new Logger() diff --git a/back/volume/src/users/users.controller.ts b/back/volume/src/users/users.controller.ts index 840ebf7..0104b45 100644 --- a/back/volume/src/users/users.controller.ts +++ b/back/volume/src/users/users.controller.ts @@ -54,7 +54,7 @@ export class UsersController { async getInvits (@FtUser() profile: Profile) { return await this.usersService.getInvits(profile.id) } - + @Post('avatar') @UseGuards(AuthenticatedGuard) @UseInterceptors( @@ -88,18 +88,16 @@ export class UsersController { async getAvatar ( @FtUser() profile: Profile, @Res({ passthrough: true }) response: Response - ){ - return await this.getAvatarById(profile.id, response); - } - + ) { + return await this.getAvatarById(profile.id, response) + } + @Get('user/:name') - async getUserByName( - @Param('name') username: string - ): Promise { - return await this.usersService.findUserByName(username); + async getUserByName (@Param('name') username: string): Promise { + return await this.usersService.findUserByName(username) } - - @Post('invit/:id') + + @Get('invit/:id') @UseGuards(AuthenticatedGuard) async invitUser ( @FtUser() profile: Profile, @@ -110,11 +108,11 @@ export class UsersController { @Get('avatar/:id') async getAvatarById ( - @Param('id', ParseIntPipe) ftId: number, + @Param('id', ParseIntPipe) ftId: number, @Res({ passthrough: true }) response: Response ) { const user = await this.usersService.findUser(ftId) - if (!user) return + if (user == null) return const filename = user.avatar const stream = createReadStream(join(process.cwd(), 'avatars/' + filename)) response.set({ @@ -125,7 +123,9 @@ export class UsersController { } @Get(':id') - async getUserById (@Param('id', ParseIntPipe) ftId: number): Promise { + async getUserById ( + @Param('id', ParseIntPipe) ftId: number + ): Promise { return await this.usersService.findUser(ftId) } @@ -139,7 +139,7 @@ export class UsersController { @UseGuards(AuthenticatedGuard) async create (@Body() payload: UserDto, @FtUser() profile: Profile) { const user = await this.usersService.findUser(profile.id) - if (user) { + if (user != null) { return await this.usersService.update(user, payload) } else { return await this.usersService.create(payload) diff --git a/back/volume/src/users/users.service.ts b/back/volume/src/users/users.service.ts index ae149d3..3ac5ea4 100644 --- a/back/volume/src/users/users.service.ts +++ b/back/volume/src/users/users.service.ts @@ -44,25 +44,28 @@ export class UsersService { .getMany() } - async update (user: User, changes: UserDto):Promise < User | null> { + async update (user: User, changes: UserDto): Promise { this.usersRepository.merge(user, changes) return await this.usersRepository.save(user) } async addAvatar (ftId: number, filename: string) { - return await this.usersRepository.update({ftId}, { - avatar: filename - }) + return await this.usersRepository.update( + { ftId }, + { + avatar: filename + } + ) } - async getFriends (ftId: number): Promise< User[] >{ + async getFriends (ftId: number): Promise { const user = await this.usersRepository.findOne({ where: { ftId }, relations: { friends: true } }) - if (!user) return [] + if (user == null) return [] return user.friends } @@ -73,19 +76,20 @@ export class UsersService { followers: true } }) - if (!user) return null + if (user == null) return null return user.followers } async invit (ftId: number, targetFtId: number) { const user = await this.findUser(ftId) - if (!user) return null + if (user == null) return null const target = await this.findUser(targetFtId) if (target == null) { return new NotFoundException( `Error: user id ${targetFtId} isn't in our db.` ) - } const id = user.followers.findIndex( + } + const id = user.followers.findIndex( (follower) => follower.ftId === targetFtId ) if (id != -1) { diff --git a/front/volume/package-lock.json b/front/volume/package-lock.json index dcf6c09..d0718b7 100644 --- a/front/volume/package-lock.json +++ b/front/volume/package-lock.json @@ -10,7 +10,6 @@ "dependencies": { "@sveltejs/vite-plugin-svelte": "^2.0.2", "@tsconfig/svelte": "^3.0.0", - "axios": "^1.3.4", "svelte": "^3.55.1", "vite": "^4.1.0" }, @@ -470,21 +469,6 @@ "node": ">= 8" } }, - "node_modules/asynckit": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", - "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" - }, - "node_modules/axios": { - "version": "1.3.4", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.3.4.tgz", - "integrity": "sha512-toYm+Bsyl6VC5wSkfkbbNB6ROv7KY93PEBBL6xyDczaIHasAiv4wPqQ/c4RjoQzipxRD2W5g21cOqQulZ7rHwQ==", - "dependencies": { - "follow-redirects": "^1.15.0", - "form-data": "^4.0.0", - "proxy-from-env": "^1.1.0" - } - }, "node_modules/balanced-match": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", @@ -567,17 +551,6 @@ "fsevents": "~2.3.2" } }, - "node_modules/combined-stream": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", - "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", - "dependencies": { - "delayed-stream": "~1.0.0" - }, - "engines": { - "node": ">= 0.8" - } - }, "node_modules/concat-map": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", @@ -608,14 +581,6 @@ "node": ">=0.10.0" } }, - "node_modules/delayed-stream": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", - "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", - "engines": { - "node": ">=0.4.0" - } - }, "node_modules/detect-indent": { "version": "6.1.0", "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-6.1.0.tgz", @@ -704,38 +669,6 @@ "node": ">=8" } }, - "node_modules/follow-redirects": { - "version": "1.15.2", - "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.2.tgz", - "integrity": "sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==", - "funding": [ - { - "type": "individual", - "url": "https://github.com/sponsors/RubenVerborgh" - } - ], - "engines": { - "node": ">=4.0" - }, - "peerDependenciesMeta": { - "debug": { - "optional": true - } - } - }, - "node_modules/form-data": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", - "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", - "dependencies": { - "asynckit": "^0.4.0", - "combined-stream": "^1.0.8", - "mime-types": "^2.1.12" - }, - "engines": { - "node": ">= 6" - } - }, "node_modules/fs.realpath": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", @@ -935,25 +868,6 @@ "node": ">=8.6" } }, - "node_modules/mime-db": { - "version": "1.52.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", - "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/mime-types": { - "version": "2.1.35", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", - "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", - "dependencies": { - "mime-db": "1.52.0" - }, - "engines": { - "node": ">= 0.6" - } - }, "node_modules/min-indent": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz", @@ -1130,11 +1044,6 @@ "svelte": "^3.2.0" } }, - "node_modules/proxy-from-env": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", - "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" - }, "node_modules/queue-microtask": { "version": "1.2.3", "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", @@ -1773,21 +1682,6 @@ "picomatch": "^2.0.4" } }, - "asynckit": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", - "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" - }, - "axios": { - "version": "1.3.4", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.3.4.tgz", - "integrity": "sha512-toYm+Bsyl6VC5wSkfkbbNB6ROv7KY93PEBBL6xyDczaIHasAiv4wPqQ/c4RjoQzipxRD2W5g21cOqQulZ7rHwQ==", - "requires": { - "follow-redirects": "^1.15.0", - "form-data": "^4.0.0", - "proxy-from-env": "^1.1.0" - } - }, "balanced-match": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", @@ -1847,14 +1741,6 @@ "readdirp": "~3.6.0" } }, - "combined-stream": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", - "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", - "requires": { - "delayed-stream": "~1.0.0" - } - }, "concat-map": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", @@ -1874,11 +1760,6 @@ "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.0.tgz", "integrity": "sha512-z2wJZXrmeHdvYJp/Ux55wIjqo81G5Bp4c+oELTW+7ar6SogWHajt5a9gO3s3IDaGSAXjDk0vlQKN3rms8ab3og==" }, - "delayed-stream": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", - "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==" - }, "detect-indent": { "version": "6.1.0", "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-6.1.0.tgz", @@ -1951,21 +1832,6 @@ "to-regex-range": "^5.0.1" } }, - "follow-redirects": { - "version": "1.15.2", - "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.2.tgz", - "integrity": "sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==" - }, - "form-data": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", - "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", - "requires": { - "asynckit": "^0.4.0", - "combined-stream": "^1.0.8", - "mime-types": "^2.1.12" - } - }, "fs.realpath": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", @@ -2113,19 +1979,6 @@ "picomatch": "^2.3.1" } }, - "mime-db": { - "version": "1.52.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", - "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" - }, - "mime-types": { - "version": "2.1.35", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", - "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", - "requires": { - "mime-db": "1.52.0" - } - }, "min-indent": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz", @@ -2241,11 +2094,6 @@ "dev": true, "requires": {} }, - "proxy-from-env": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", - "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" - }, "queue-microtask": { "version": "1.2.3", "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", diff --git a/front/volume/package.json b/front/volume/package.json index 970ab08..2fb6180 100644 --- a/front/volume/package.json +++ b/front/volume/package.json @@ -20,7 +20,6 @@ "dependencies": { "@sveltejs/vite-plugin-svelte": "^2.0.2", "@tsconfig/svelte": "^3.0.0", - "axios": "^1.3.4", "svelte": "^3.55.1", "vite": "^4.1.0" } diff --git a/front/volume/src/App.svelte b/front/volume/src/App.svelte index 8e9c22c..3731c9e 100644 --- a/front/volume/src/App.svelte +++ b/front/volume/src/App.svelte @@ -1,5 +1,5 @@
-
-
- {#if channels.length > 0} -

Channels

- {#each channels.slice(0, 10) as _channels} -
  • - {_channels.name} - -
  • - {/each} - {:else} -

    No channels available

    - {/if} - -
    -
    +
    +
    + {#if channels.length > 0} +

    Channels

    + {#each channels.slice(0, 10) as _channels} +
  • + {_channels.name} + +
  • + {/each} + {:else} +

    No channels available

    + {/if} + +
    +
    diff --git a/front/volume/src/components/Chat2.svelte b/front/volume/src/components/Chat2.svelte index fe2bc87..8897a1f 100644 --- a/front/volume/src/components/Chat2.svelte +++ b/front/volume/src/components/Chat2.svelte @@ -6,7 +6,6 @@ } - @@ -51,6 +53,16 @@ {:else}

    No friends to display

    {/if} + {#if invits.length > 0} +

    Monkey invits

    + {#each invits.slice(0, 10) as invit} +
  • + {invit.username} invited you to be friend. +
  • + {/each} + {:else} +

    No invitations to display

    + {/if}

    Add a friend

    diff --git a/front/volume/src/components/NavBar.svelte b/front/volume/src/components/NavBar.svelte index 84c00de..d840db1 100644 --- a/front/volume/src/components/NavBar.svelte +++ b/front/volume/src/components/NavBar.svelte @@ -1,9 +1,13 @@ -