1
0
forked from mirror/misskey
misskey/src/models/app.ts

103 lines
2.0 KiB
TypeScript
Raw Normal View History

2018-02-02 08:06:01 +09:00
import * as mongo from 'mongodb';
import * as deepcopy from 'deepcopy';
2018-02-02 08:06:01 +09:00
import AccessToken from './access-token';
2018-03-29 20:32:18 +09:00
import db from '../db/mongodb';
2018-10-16 11:38:09 +09:00
import isObjectId from '../misc/is-objectid';
2018-04-02 13:15:53 +09:00
import config from '../config';
2019-03-06 23:23:50 +09:00
import { dbLogger } from '../db/logger';
2017-01-17 09:12:33 +09:00
2018-02-02 08:06:01 +09:00
const App = db.get<IApp>('apps');
App.createIndex('secret');
export default App;
2016-12-29 07:49:51 +09:00
2018-02-02 08:06:01 +09:00
export type IApp = {
_id: mongo.ObjectID;
2018-03-29 14:48:47 +09:00
createdAt: Date;
userId: mongo.ObjectID | null;
2018-02-04 14:52:33 +09:00
secret: string;
2018-03-29 14:48:47 +09:00
name: string;
description: string;
permission: string[];
2018-03-29 14:48:47 +09:00
callbackUrl: string;
2018-02-02 08:06:01 +09:00
};
2017-03-03 19:48:00 +09:00
2018-02-02 08:06:01 +09:00
/**
* Pack an app for API response
*/
export const pack = (
app: any,
me?: any,
options?: {
2018-11-01 09:19:22 +09:00
detail?: boolean,
2018-02-02 08:06:01 +09:00
includeSecret?: boolean,
includeProfileImageIds?: boolean
}
) => new Promise<any>(async (resolve, reject) => {
2018-11-01 09:19:22 +09:00
const opts = Object.assign({
detail: false,
2018-02-02 08:06:01 +09:00
includeSecret: false,
includeProfileImageIds: false
2018-11-01 09:19:22 +09:00
}, options);
2018-02-02 08:06:01 +09:00
let _app: any;
2018-11-01 09:19:22 +09:00
const fields = opts.detail ? {} : {
name: true
};
2018-02-02 08:06:01 +09:00
// Populate the app if 'app' is ID
2018-10-16 11:38:09 +09:00
if (isObjectId(app)) {
2018-02-02 08:06:01 +09:00
_app = await App.findOne({
_id: app
});
} else if (typeof app === 'string') {
_app = await App.findOne({
_id: new mongo.ObjectID(app)
2018-11-01 09:19:22 +09:00
}, { fields });
2018-02-02 08:06:01 +09:00
} else {
_app = deepcopy(app);
}
// Me
2018-10-16 11:38:09 +09:00
if (me && !isObjectId(me)) {
2018-02-02 08:06:01 +09:00
if (typeof me === 'string') {
me = new mongo.ObjectID(me);
} else {
me = me._id;
}
}
2019-03-06 23:23:50 +09:00
// (データベースの欠損などで)アプリがデータベース上に見つからなかったとき
if (_app == null) {
dbLogger.warn(`[DAMAGED DB] (missing) pkg: app :: ${app}`);
return null;
}
2018-02-02 08:06:01 +09:00
// Rename _id to id
_app.id = _app._id;
delete _app._id;
// Visible by only owner
if (!opts.includeSecret) {
delete _app.secret;
}
2018-03-29 14:48:47 +09:00
_app.iconUrl = _app.icon != null
2019-02-24 12:53:22 +09:00
? `${config.driveUrl}/${_app.icon}`
: `${config.driveUrl}/app-default.jpg`;
2018-02-02 08:06:01 +09:00
if (me) {
// 既に連携しているか
const exist = await AccessToken.count({
2018-03-29 14:48:47 +09:00
appId: _app.id,
userId: me,
2018-02-02 08:06:01 +09:00
}, {
limit: 1
});
2018-03-29 14:48:47 +09:00
_app.isAuthorized = exist === 1;
2018-02-02 08:06:01 +09:00
}
resolve(_app);
});