Compare commits

..

No commits in common. "4315459e87b1dda30fd191011448a4077b4e6c40" and "1e282617a94914731f198698f5038facfa9d173c" have entirely different histories.

11 changed files with 15 additions and 19 deletions

2
environment.d.ts vendored
View file

@ -2,13 +2,11 @@ import { PrismaClient } from "@prisma/client";
import { Client as LDAPClient } from "ldapts"; import { Client as LDAPClient } from "ldapts";
import { ApolloClient, InMemoryCache } from "@apollo/client"; import { ApolloClient, InMemoryCache } from "@apollo/client";
import { LLDAPAuthResponse } from "@/ldap"; import { LLDAPAuthResponse } from "@/ldap";
import { Logger } from "pino";
declare global { declare global {
var prisma: PrismaClient | undefined; var prisma: PrismaClient | undefined;
var ldapClient: LDAPClient | undefined; var ldapClient: LDAPClient | undefined;
var authResponse: LLDAPAuthResponse | undefined; var authResponse: LLDAPAuthResponse | undefined;
var logger: Logger;
namespace NodeJS { namespace NodeJS {
interface ProcessEnv { interface ProcessEnv {

View file

@ -53,7 +53,7 @@ export async function POST(request: Request) {
) { ) {
avatarBuf = Buffer.from(avatarBase64, "base64"); avatarBuf = Buffer.from(avatarBase64, "base64");
if (avatarBuf.length > 2_000_000) { if (avatarBuf.length > 1_000_000) {
return new Response( return new Response(
JSON.stringify({ JSON.stringify({
ok: false, ok: false,

View file

@ -141,7 +141,7 @@ export default function RegisterForm({
(avatarSource != null (avatarSource != null
? `We found your avatar from ${avatarSource}, but you can change it if you'd like.` ? `We found your avatar from ${avatarSource}, but you can change it if you'd like.`
: "") + : "") +
" This will automatically be used as your avatar with supported services - maximum 2 MB. " " This will automatically be used as your avatar with supported services - maximum 1 MB. "
} }
type="file" type="file"
name="avatar" name="avatar"

View file

@ -55,7 +55,7 @@ export default async function Page({
const blob = await req.blob(); const blob = await req.blob();
const arrayBuffer = await blob.arrayBuffer(); const arrayBuffer = await blob.arrayBuffer();
const buffer = Buffer.from(arrayBuffer); const buffer = Buffer.from(arrayBuffer);
if (buffer.length <= 2_000_000) { if (buffer.length <= 1_000_000) {
// I hope you are doing well, you deserve the best of luck while working on this project -Ari // I hope you are doing well, you deserve the best of luck while working on this project -Ari
try { try {
const jpg = await ensureJpg(buffer); const jpg = await ensureJpg(buffer);

View file

@ -68,7 +68,7 @@ export class DiscordAuthProvider extends AuthProvider {
async getAvatar(): Promise<string | null> { async getAvatar(): Promise<string | null> {
const me = await this.getMe(); const me = await this.getMe();
return me.avatar !== null return me.avatar !== null
? `https://cdn.discordapp.com/avatars/${me.id}/${me.avatar}.png?size=1024` ? `https://cdn.discordapp.com/avatars/${me.id}/${me.avatar}.png`
: null; : null;
} }

View file

@ -9,14 +9,14 @@
flex-direction: column; flex-direction: column;
} }
.avatarChanger .currentAvatar, .avatarChanger .current-avatar,
.avatarChanger svg { .avatarChanger svg {
width: 3em; width: 3em;
height: 3em; height: 3em;
border-radius: 0.25rem; border-radius: 0.25rem;
} }
.vertical.vertical .currentAvatar { .vertical.vertical .current-avatar {
display: block; display: block;
width: 100%; width: 100%;
height: inherit; height: inherit;

View file

@ -1,4 +1,3 @@
/* eslint-disable @next/next/no-img-element */
import React, { ChangeEvent } from "react"; import React, { ChangeEvent } from "react";
import classnames from "classnames"; import classnames from "classnames";
@ -31,12 +30,13 @@ export default function AvatarChanger({
<div <div
className={classnames( className={classnames(
styles.avatarChanger, styles.avatarChanger,
"avatar-changer",
vertical ? styles.vertical : null vertical ? styles.vertical : null
)} )}
> >
{currentAvatarBlob != null ? ( {currentAvatarBlob != null ? (
<img <img
className={styles.currentAvatar} className="current-avatar"
src={currentAvatarBlob!} src={currentAvatarBlob!}
alt="Your avatar" alt="Your avatar"
/> />

View file

@ -6,8 +6,8 @@ export default function CheckIcon() {
xmlns="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg"
xmlnsXlink="http://www.w3.org/1999/xlink" xmlnsXlink="http://www.w3.org/1999/xlink"
> >
<g stroke="none" strokeWidth="1" fill="none" fillRule="evenodd"> <g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
<g id="check" fill="currentColor" fillRule="nonzero"> <g id="check" fill="currentColor" fill-rule="nonzero">
<path <path
d="M107.782834,4.91476009 C111.16323,-0.155833631 118.014111,-1.52600976 123.084704,1.85438606 C128.155298,5.23478187 129.525474,12.0856625 126.145078,17.1562562 L64.5253312,123.085877 C60.662855,128.879591 52.465466,129.691293 47.5417556,124.767582 L3.23188204,89.4577087 C-1.07729401,85.1485327 -1.07729401,78.1619779 3.23188204,73.8528018 C7.54105809,69.5436258 14.5276129,69.5436258 18.8367889,73.8528018 L53.6283699,99.643429 L107.782834,4.91476009 Z" d="M107.782834,4.91476009 C111.16323,-0.155833631 118.014111,-1.52600976 123.084704,1.85438606 C128.155298,5.23478187 129.525474,12.0856625 126.145078,17.1562562 L64.5253312,123.085877 C60.662855,128.879591 52.465466,129.691293 47.5417556,124.767582 L3.23188204,89.4577087 C-1.07729401,85.1485327 -1.07729401,78.1619779 3.23188204,73.8528018 C7.54105809,69.5436258 14.5276129,69.5436258 18.8367889,73.8528018 L53.6283699,99.643429 L107.782834,4.91476009 Z"
id="Path-4" id="Path-4"

View file

@ -1,7 +1,7 @@
import sharp from "sharp"; import sharp from "sharp";
export async function ensureJpg(avatar: Buffer) { export async function ensureJpg(avatar: Buffer) {
const img = await sharp(avatar).toFormat("jpeg").resize(1024, 1024); const img = await sharp(avatar).toFormat("jpeg").resize(512, 512);
const buf = await img.toBuffer(); const buf = await img.toBuffer();
return buf.toString("base64"); return buf.toString("base64");
} }

View file

@ -1,9 +1,7 @@
import pino from "pino"; import pino from "pino";
if (global.logger == null) { const logger = pino();
global.logger = pino();
}
export function getLogger(name: string) { export function getLogger(name: string) {
return global.logger.child({ name }); return logger.child({ name });
} }

View file

@ -19,13 +19,13 @@ const CONFIRM_PASSWORD = (name: string) =>
const AVATAR = Yup.string().test( const AVATAR = Yup.string().test(
"file-size", "file-size",
"File is bigger than 2 MB.", "File is bigger than 1 MB.",
(value) => { (value) => {
if (value == null) return true; if (value == null) return true;
try { try {
const buf = Buffer.from(value, "base64"); const buf = Buffer.from(value, "base64");
return buf.length <= 2_000_000; return buf.length <= 1_000_000;
} catch (e) { } catch (e) {
return false; return false;
} }