2019-04-07 12:50:36 +00:00
|
|
|
import { Users, Signins } from '../models';
|
|
|
|
|
2019-01-10 23:07:09 +00:00
|
|
|
// node built/tools/show-signin-history username
|
|
|
|
// => {Success} {Date} {IPAddrsss}
|
|
|
|
|
|
|
|
// node built/tools/show-signin-history username user-agent,x-forwarded-for
|
|
|
|
// with user-agent and x-forwarded-for
|
|
|
|
|
|
|
|
// node built/tools/show-signin-history username all
|
|
|
|
// with full request headers
|
|
|
|
|
2019-04-12 16:43:22 +00:00
|
|
|
async function main(username: string, headers?: string[]) {
|
2019-04-07 12:50:36 +00:00
|
|
|
const user = await Users.findOne({
|
2019-01-10 23:07:09 +00:00
|
|
|
host: null,
|
|
|
|
usernameLower: username.toLowerCase(),
|
|
|
|
});
|
|
|
|
|
2019-04-13 19:17:24 +00:00
|
|
|
if (user == null) throw new Error('User not found');
|
2019-01-10 23:07:09 +00:00
|
|
|
|
2019-04-07 12:50:36 +00:00
|
|
|
const history = await Signins.find({
|
|
|
|
userId: user.id
|
2019-01-10 23:07:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
for (const signin of history) {
|
|
|
|
console.log(`${signin.success ? 'OK' : 'NG'} ${signin.createdAt ? signin.createdAt.toISOString() : 'Unknown'} ${signin.ip}`);
|
|
|
|
|
|
|
|
// headers
|
|
|
|
if (headers != null) {
|
|
|
|
for (const key of Object.keys(signin.headers)) {
|
|
|
|
if (headers.includes('all') || headers.includes(key)) {
|
|
|
|
console.log(` ${key}: ${signin.headers[key]}`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// get args
|
|
|
|
const args = process.argv.slice(2);
|
|
|
|
|
|
|
|
let username = args[0];
|
2019-04-12 16:43:22 +00:00
|
|
|
let headers: string[] | undefined;
|
2019-01-10 23:07:09 +00:00
|
|
|
|
|
|
|
if (args[1] != null) {
|
|
|
|
headers = args[1].split(/,/).map(header => header.toLowerCase());
|
|
|
|
}
|
|
|
|
|
|
|
|
// normalize args
|
|
|
|
username = username.replace(/^@/, '');
|
|
|
|
|
|
|
|
main(username, headers).then(() => {
|
|
|
|
process.exit(0);
|
|
|
|
}).catch(e => {
|
|
|
|
console.warn(e);
|
|
|
|
process.exit(1);
|
|
|
|
});
|