2021-01-16 19:20:31 +02:00
|
|
|
SessionData = new Mongo.Collection('sessiondata');
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* A UserSessionData in Wekan. Organization in Trello.
|
|
|
|
|
*/
|
|
|
|
|
SessionData.attachSchema(
|
|
|
|
|
new SimpleSchema({
|
|
|
|
|
_id: {
|
|
|
|
|
/**
|
|
|
|
|
* the organization id
|
|
|
|
|
*/
|
|
|
|
|
type: Number,
|
|
|
|
|
optional: true,
|
|
|
|
|
// eslint-disable-next-line consistent-return
|
|
|
|
|
autoValue() {
|
|
|
|
|
if (this.isInsert && !this.isSet) {
|
|
|
|
|
return incrementCounter('counters', 'orgId', 1);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
userId: {
|
|
|
|
|
/**
|
|
|
|
|
* userId of the user
|
|
|
|
|
*/
|
|
|
|
|
type: String,
|
|
|
|
|
optional: false,
|
|
|
|
|
},
|
2021-01-24 12:28:36 +02:00
|
|
|
sessionId: {
|
|
|
|
|
/**
|
|
|
|
|
* unique session ID
|
|
|
|
|
*/
|
|
|
|
|
type: String,
|
|
|
|
|
optional: false,
|
|
|
|
|
},
|
2021-01-16 19:20:31 +02:00
|
|
|
totalHits: {
|
|
|
|
|
/**
|
|
|
|
|
* total number of hits in the last report query
|
|
|
|
|
*/
|
|
|
|
|
type: Number,
|
|
|
|
|
optional: true,
|
|
|
|
|
},
|
2021-01-27 02:21:12 +02:00
|
|
|
resultsCount: {
|
|
|
|
|
/**
|
|
|
|
|
* number of results returned
|
|
|
|
|
*/
|
|
|
|
|
type: Number,
|
|
|
|
|
optional: true,
|
|
|
|
|
},
|
2021-01-16 19:20:31 +02:00
|
|
|
lastHit: {
|
|
|
|
|
/**
|
|
|
|
|
* the last hit returned from a report query
|
|
|
|
|
*/
|
|
|
|
|
type: Number,
|
|
|
|
|
optional: true,
|
|
|
|
|
},
|
2021-01-24 02:32:37 +02:00
|
|
|
cards: {
|
|
|
|
|
type: [String],
|
|
|
|
|
optional: true,
|
|
|
|
|
},
|
2021-01-27 02:21:12 +02:00
|
|
|
selector: {
|
|
|
|
|
type: String,
|
|
|
|
|
optional: true,
|
|
|
|
|
blackbox: true,
|
|
|
|
|
},
|
2021-01-24 02:32:37 +02:00
|
|
|
errorMessages: {
|
|
|
|
|
type: [String],
|
|
|
|
|
optional: true,
|
|
|
|
|
},
|
2021-01-25 15:39:36 +02:00
|
|
|
errors: {
|
|
|
|
|
type: [Object],
|
|
|
|
|
optional: true,
|
|
|
|
|
defaultValue: [],
|
|
|
|
|
},
|
|
|
|
|
'errors.$': {
|
|
|
|
|
type: new SimpleSchema({
|
|
|
|
|
tag: {
|
|
|
|
|
/**
|
|
|
|
|
* i18n tag
|
|
|
|
|
*/
|
|
|
|
|
type: String,
|
|
|
|
|
optional: false,
|
|
|
|
|
},
|
|
|
|
|
value: {
|
|
|
|
|
/**
|
|
|
|
|
* value for the tag
|
|
|
|
|
*/
|
|
|
|
|
type: String,
|
|
|
|
|
optional: true,
|
|
|
|
|
defaultValue: null,
|
|
|
|
|
},
|
|
|
|
|
color: {
|
|
|
|
|
type: Boolean,
|
|
|
|
|
optional: true,
|
|
|
|
|
defaultValue: false,
|
|
|
|
|
},
|
|
|
|
|
}),
|
|
|
|
|
},
|
2021-01-16 19:20:31 +02:00
|
|
|
createdAt: {
|
|
|
|
|
/**
|
|
|
|
|
* creation date of the team
|
|
|
|
|
*/
|
|
|
|
|
type: Date,
|
|
|
|
|
// 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();
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}),
|
|
|
|
|
);
|
|
|
|
|
|
2021-01-27 16:15:54 +02:00
|
|
|
SessionData.helpers({
|
|
|
|
|
getSelector() {
|
|
|
|
|
return SessionData.unpickle(this.selector);
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
SessionData.unpickle = pickle => {
|
|
|
|
|
return JSON.parse(pickle, (key, value) => {
|
|
|
|
|
if (typeof value === 'object') {
|
|
|
|
|
if (value.hasOwnProperty('$$class')) {
|
|
|
|
|
if (value.$$class === 'RegExp') {
|
|
|
|
|
return new RegExp(value.source, value.flags);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return value;
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
SessionData.pickle = value => {
|
|
|
|
|
return JSON.stringify(value, (key, value) => {
|
|
|
|
|
if (typeof value === 'object') {
|
|
|
|
|
if (value.constructor.name === 'RegExp') {
|
|
|
|
|
return {
|
|
|
|
|
$$class: 'RegExp',
|
|
|
|
|
source: value.source,
|
|
|
|
|
flags: value.flags,
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return value;
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2021-01-24 12:28:36 +02:00
|
|
|
if (!Meteor.isServer) {
|
|
|
|
|
SessionData.getSessionId = () => {
|
|
|
|
|
let sessionId = Session.get('sessionId');
|
|
|
|
|
if (!sessionId) {
|
|
|
|
|
sessionId = `${String(Meteor.userId())}-${String(Math.random())}`;
|
|
|
|
|
Session.set('sessionId', sessionId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return sessionId;
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-16 19:20:31 +02:00
|
|
|
export default SessionData;
|