mizzkey/src/server/api/common/get-friends.ts

52 lines
1.1 KiB
TypeScript
Raw Normal View History

2016-12-28 23:49:51 +01:00
import * as mongodb from 'mongodb';
2018-03-29 13:32:18 +02:00
import Following from '../../../models/following';
2016-12-28 23:49:51 +01:00
2018-04-19 05:43:25 +02:00
export const getFriendIds = async (me: mongodb.ObjectID, includeMe = true) => {
2016-12-28 23:49:51 +01:00
// Fetch relation to other users who the I follows
// SELECT followee
2018-04-19 05:43:25 +02:00
const followings = await Following
2016-12-28 23:49:51 +01:00
.find({
followerId: me
2016-12-28 23:49:51 +01:00
}, {
2017-01-17 22:10:56 +01:00
fields: {
2018-03-29 07:48:47 +02:00
followeeId: true
2017-01-17 22:10:56 +01:00
}
2017-01-17 03:11:22 +01:00
});
2016-12-28 23:49:51 +01:00
// ID list of other users who the I follows
2018-04-19 05:43:25 +02:00
const myfollowingIds = followings.map(following => following.followeeId);
2016-12-28 23:49:51 +01:00
if (includeMe) {
myfollowingIds.push(me);
}
return myfollowingIds;
};
2018-04-19 05:43:25 +02:00
2018-07-11 07:03:21 +02:00
export const getFriends = async (me: mongodb.ObjectID, includeMe = true, remoteOnly = false) => {
const q: any = remoteOnly ? {
followerId: me,
'_followee.host': { $ne: null }
} : {
followerId: me
};
2018-04-19 05:43:25 +02:00
// Fetch relation to other users who the I follows
const followings = await Following
2018-07-11 07:03:21 +02:00
.find(q);
2018-04-19 05:43:25 +02:00
// ID list of other users who the I follows
const myfollowings = followings.map(following => ({
id: following.followeeId,
stalk: following.stalk
}));
if (includeMe) {
myfollowings.push({
id: me,
stalk: true
});
}
return myfollowings;
};