2016-12-28 15:49:51 -07:00
|
|
|
import * as mongodb from 'mongodb';
|
2018-03-29 05:32:18 -06:00
|
|
|
import Following from '../../../models/following';
|
2016-12-28 15:49:51 -07:00
|
|
|
|
2018-04-18 21:43:25 -06:00
|
|
|
export const getFriendIds = async (me: mongodb.ObjectID, includeMe = true) => {
|
2016-12-28 15:49:51 -07:00
|
|
|
// Fetch relation to other users who the I follows
|
|
|
|
// SELECT followee
|
2018-04-18 21:43:25 -06:00
|
|
|
const followings = await Following
|
2016-12-28 15:49:51 -07:00
|
|
|
.find({
|
2018-04-02 06:57:36 -06:00
|
|
|
followerId: me
|
2016-12-28 15:49:51 -07:00
|
|
|
}, {
|
2017-01-17 14:10:56 -07:00
|
|
|
fields: {
|
2018-03-28 23:48:47 -06:00
|
|
|
followeeId: true
|
2017-01-17 14:10:56 -07:00
|
|
|
}
|
2017-01-16 19:11:22 -07:00
|
|
|
});
|
2016-12-28 15:49:51 -07:00
|
|
|
|
|
|
|
// ID list of other users who the I follows
|
2018-04-18 21:43:25 -06:00
|
|
|
const myfollowingIds = followings.map(following => following.followeeId);
|
2016-12-28 15:49:51 -07:00
|
|
|
|
|
|
|
if (includeMe) {
|
|
|
|
myfollowingIds.push(me);
|
|
|
|
}
|
|
|
|
|
|
|
|
return myfollowingIds;
|
|
|
|
};
|
2018-04-18 21:43:25 -06:00
|
|
|
|
2018-07-10 23:03:21 -06: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-18 21:43:25 -06:00
|
|
|
// Fetch relation to other users who the I follows
|
|
|
|
const followings = await Following
|
2018-07-10 23:03:21 -06:00
|
|
|
.find(q);
|
2018-04-18 21:43:25 -06: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;
|
|
|
|
};
|