forked from FoundKeyGang/FoundKey
server: remove localUserByIdCache
The same data is stored in userByIdCache. Whether a user is local or not can easily be determined from the cached object.
This commit is contained in:
parent
57299f0df6
commit
8d6476af2a
2 changed files with 5 additions and 4 deletions
|
@ -3,7 +3,7 @@ import { Users, AccessTokens, Apps } from '@/models/index.js';
|
||||||
import { AccessToken } from '@/models/entities/access-token.js';
|
import { AccessToken } from '@/models/entities/access-token.js';
|
||||||
import { Cache } from '@/misc/cache.js';
|
import { Cache } from '@/misc/cache.js';
|
||||||
import { App } from '@/models/entities/app.js';
|
import { App } from '@/models/entities/app.js';
|
||||||
import { localUserByIdCache, localUserByNativeTokenCache } from '@/services/user-cache.js';
|
import { userByIdCache, localUserByNativeTokenCache } from '@/services/user-cache.js';
|
||||||
import isNativeToken from './common/is-native-token.js';
|
import isNativeToken from './common/is-native-token.js';
|
||||||
|
|
||||||
const appCache = new Cache<App>(Infinity);
|
const appCache = new Cache<App>(Infinity);
|
||||||
|
@ -64,11 +64,14 @@ export default async (authorization: string | null | undefined, bodyToken: strin
|
||||||
lastUsedAt: new Date(),
|
lastUsedAt: new Date(),
|
||||||
});
|
});
|
||||||
|
|
||||||
const user = await localUserByIdCache.fetch(accessToken.userId,
|
const user = await userByIdCache.fetch(accessToken.userId,
|
||||||
() => Users.findOneBy({
|
() => Users.findOneBy({
|
||||||
id: accessToken.userId,
|
id: accessToken.userId,
|
||||||
}) as Promise<ILocalUser>);
|
}) as Promise<ILocalUser>);
|
||||||
|
|
||||||
|
// can't authorize remote users
|
||||||
|
if (!Users.isLocalUser(user)) return [null, null];
|
||||||
|
|
||||||
if (accessToken.appId) {
|
if (accessToken.appId) {
|
||||||
const app = await appCache.fetch(accessToken.appId,
|
const app = await appCache.fetch(accessToken.appId,
|
||||||
() => Apps.findOneByOrFail({ id: accessToken.appId! }));
|
() => Apps.findOneByOrFail({ id: accessToken.appId! }));
|
||||||
|
|
|
@ -5,7 +5,6 @@ import { subscriber } from '@/db/redis.js';
|
||||||
|
|
||||||
export const userByIdCache = new Cache<CacheableUser>(Infinity);
|
export const userByIdCache = new Cache<CacheableUser>(Infinity);
|
||||||
export const localUserByNativeTokenCache = new Cache<CacheableLocalUser | null>(Infinity);
|
export const localUserByNativeTokenCache = new Cache<CacheableLocalUser | null>(Infinity);
|
||||||
export const localUserByIdCache = new Cache<CacheableLocalUser>(Infinity);
|
|
||||||
export const uriPersonCache = new Cache<CacheableUser | null>(Infinity);
|
export const uriPersonCache = new Cache<CacheableUser | null>(Infinity);
|
||||||
|
|
||||||
subscriber.on('message', async (_, data) => {
|
subscriber.on('message', async (_, data) => {
|
||||||
|
@ -27,7 +26,6 @@ subscriber.on('message', async (_, data) => {
|
||||||
}
|
}
|
||||||
if (Users.isLocalUser(user)) {
|
if (Users.isLocalUser(user)) {
|
||||||
localUserByNativeTokenCache.set(user.token, user);
|
localUserByNativeTokenCache.set(user.token, user);
|
||||||
localUserByIdCache.set(user.id, user);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue