feat: return user info when authenticating
This commit is contained in:
@@ -12,7 +12,7 @@ import { EpisodesResponseSchema } from "~/types/episode";
|
||||
import { ErrorResponse, ErrorResponseSchema } from "~/types/schema";
|
||||
import { Title } from "~/types/title";
|
||||
|
||||
import { getUsername } from "./getUsername";
|
||||
import { getUser } from "./getUser";
|
||||
import { getWatchingTitles } from "./getWatchingTitles";
|
||||
|
||||
const route = createRoute({
|
||||
@@ -69,22 +69,28 @@ app.openapi(route, async (c) => {
|
||||
}
|
||||
|
||||
try {
|
||||
const username = await getUsername(aniListToken);
|
||||
if (!username) {
|
||||
const user = await getUser(aniListToken);
|
||||
if (!user) {
|
||||
return c.json(ErrorResponse, { status: 401 });
|
||||
}
|
||||
|
||||
await associateDeviceIdWithUsername(env(c, "workerd"), deviceId, username);
|
||||
await associateDeviceIdWithUsername(
|
||||
env(c, "workerd"),
|
||||
deviceId!,
|
||||
user.name,
|
||||
);
|
||||
|
||||
return streamSSE(
|
||||
c,
|
||||
async (stream) => {
|
||||
stream.writeSSE({ event: "user", data: JSON.stringify(user) });
|
||||
|
||||
let currentPage = 1;
|
||||
let hasNextPage = true;
|
||||
|
||||
do {
|
||||
const { mediaList, pageInfo } = await getWatchingTitles(
|
||||
username,
|
||||
user.name,
|
||||
currentPage++,
|
||||
c.executionCtx,
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user