123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- import { ReactiveCache } from '/imports/reactiveCache';
- LockoutSettings = new Mongo.Collection('lockoutSettings');
- LockoutSettings.attachSchema(
- new SimpleSchema({
- _id: {
- type: String,
- },
- value: {
- type: Number,
- decimal: false,
- },
- category: {
- type: String,
- },
- sort: {
- type: Number,
- decimal: true,
- },
- createdAt: {
- type: Date,
- optional: true,
- // eslint-disable-next-line consistent-return
- autoValue() {
- if (this.isInsert) {
- return new Date();
- } else if (this.isUpsert) {
- return { $setOnInsert: new Date() };
- } else {
- this.unset();
- }
- },
- },
- modifiedAt: {
- type: Date,
- denyUpdate: false,
- // eslint-disable-next-line consistent-return
- autoValue() {
- if (this.isInsert || this.isUpsert || this.isUpdate) {
- return new Date();
- } else {
- this.unset();
- }
- },
- },
- }),
- );
- LockoutSettings.allow({
- update(userId) {
- const user = ReactiveCache.getUser(userId);
- return user && user.isAdmin;
- },
- });
- if (Meteor.isServer) {
- Meteor.startup(() => {
- LockoutSettings._collection.createIndex({ modifiedAt: -1 });
- // Known users settings
- LockoutSettings.upsert(
- { _id: 'known-failuresBeforeLockout' },
- {
- $setOnInsert: {
- value: process.env.ACCOUNTS_LOCKOUT_KNOWN_USERS_FAILURES_BEFORE
- ? parseInt(process.env.ACCOUNTS_LOCKOUT_KNOWN_USERS_FAILURES_BEFORE, 10) : 3,
- category: 'known',
- sort: 0,
- },
- },
- );
- LockoutSettings.upsert(
- { _id: 'known-lockoutPeriod' },
- {
- $setOnInsert: {
- value: process.env.ACCOUNTS_LOCKOUT_KNOWN_USERS_PERIOD
- ? parseInt(process.env.ACCOUNTS_LOCKOUT_KNOWN_USERS_PERIOD, 10) : 60,
- category: 'known',
- sort: 1,
- },
- },
- );
- LockoutSettings.upsert(
- { _id: 'known-failureWindow' },
- {
- $setOnInsert: {
- value: process.env.ACCOUNTS_LOCKOUT_KNOWN_USERS_FAILURE_WINDOW
- ? parseInt(process.env.ACCOUNTS_LOCKOUT_KNOWN_USERS_FAILURE_WINDOW, 10) : 15,
- category: 'known',
- sort: 2,
- },
- },
- );
- // Unknown users settings
- const typoVar = process.env.ACCOUNTS_LOCKOUT_UNKNOWN_USERS_FAILURES_BERORE;
- const correctVar = process.env.ACCOUNTS_LOCKOUT_UNKNOWN_USERS_FAILURES_BEFORE;
- LockoutSettings.upsert(
- { _id: 'unknown-failuresBeforeLockout' },
- {
- $setOnInsert: {
- value: (correctVar || typoVar)
- ? parseInt(correctVar || typoVar, 10) : 3,
- category: 'unknown',
- sort: 0,
- },
- },
- );
- LockoutSettings.upsert(
- { _id: 'unknown-lockoutPeriod' },
- {
- $setOnInsert: {
- value: process.env.ACCOUNTS_LOCKOUT_UNKNOWN_USERS_LOCKOUT_PERIOD
- ? parseInt(process.env.ACCOUNTS_LOCKOUT_UNKNOWN_USERS_LOCKOUT_PERIOD, 10) : 60,
- category: 'unknown',
- sort: 1,
- },
- },
- );
- LockoutSettings.upsert(
- { _id: 'unknown-failureWindow' },
- {
- $setOnInsert: {
- value: process.env.ACCOUNTS_LOCKOUT_UNKNOWN_USERS_FAILURE_WINDOW
- ? parseInt(process.env.ACCOUNTS_LOCKOUT_UNKNOWN_USERS_FAILURE_WINDOW, 10) : 15,
- category: 'unknown',
- sort: 2,
- },
- },
- );
- });
- }
- LockoutSettings.helpers({
- getKnownConfig() {
- return {
- failuresBeforeLockout: LockoutSettings.findOne('known-failuresBeforeLockout')?.value || 3,
- lockoutPeriod: LockoutSettings.findOne('known-lockoutPeriod')?.value || 60,
- failureWindow: LockoutSettings.findOne('known-failureWindow')?.value || 15
- };
- },
- getUnknownConfig() {
- return {
- failuresBeforeLockout: LockoutSettings.findOne('unknown-failuresBeforeLockout')?.value || 3,
- lockoutPeriod: LockoutSettings.findOne('unknown-lockoutPeriod')?.value || 60,
- failureWindow: LockoutSettings.findOne('unknown-failureWindow')?.value || 15
- };
- }
- });
- export default LockoutSettings;
|