session service
This commit is contained in:
parent
a2939a7f2e
commit
69290f4c7a
2 changed files with 91 additions and 76 deletions
|
|
@ -5,7 +5,12 @@ class ServicesProvider {
|
|||
const invitesService = require('../services/invitesService');
|
||||
const nostrService = require('../services/nostrService');
|
||||
const loginService = require('../services/loginService');
|
||||
const sessionService = require('../services/sessionService');
|
||||
|
||||
const SessionServiceProvider = require('../services/sessionService');
|
||||
const sessionService = new SessionServiceProvider({
|
||||
invitesService,
|
||||
}).provide();
|
||||
|
||||
const ProfileServiceProvider = require('../services/profileService');
|
||||
const profileService = new ProfileServiceProvider().provide();
|
||||
const OfferServiceProvider = require('../services/offerService');
|
||||
|
|
|
|||
|
|
@ -2,14 +2,20 @@ const uuid = require('uuid');
|
|||
|
||||
const models = require('../models');
|
||||
|
||||
const invitesService = require('./invitesService');
|
||||
const constants = require('../constants');
|
||||
|
||||
class SessionServiceProvider {
|
||||
constructor({ invitesService }) {
|
||||
this.invitesService = invitesService;
|
||||
}
|
||||
|
||||
provide() {
|
||||
async function createSession(sessionUuid) {
|
||||
const currentTimestamp = new Date();
|
||||
const expiryTimestamp = new Date(currentTimestamp.getTime());
|
||||
expiryTimestamp.setSeconds(
|
||||
expiryTimestamp.getSeconds() + constants.DEFAULT_SESSION_DURATION_SECONDS
|
||||
expiryTimestamp.getSeconds() +
|
||||
constants.DEFAULT_SESSION_DURATION_SECONDS
|
||||
);
|
||||
|
||||
return await models.SessionCreated.create({
|
||||
|
|
@ -37,12 +43,12 @@ async function isSessionValid(sessionUuid) {
|
|||
return true;
|
||||
}
|
||||
|
||||
async function relateSessionToPublicKey(sessionUuid, publicKey) {
|
||||
const relateSessionToPublicKey = async (sessionUuid, publicKey) => {
|
||||
if (!(await isSessionValid(sessionUuid))) {
|
||||
throw Error('Session is not valid anymore.');
|
||||
}
|
||||
|
||||
if (!(await invitesService.isPublicKeySignedUp(publicKey))) {
|
||||
if (!(await this.invitesService.isPublicKeySignedUp(publicKey))) {
|
||||
throw Error('Public key is not signed up.');
|
||||
}
|
||||
|
||||
|
|
@ -52,7 +58,7 @@ async function relateSessionToPublicKey(sessionUuid, publicKey) {
|
|||
public_key: publicKey,
|
||||
created_at: new Date().toISOString(),
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
async function isSessionAuthorized(sessionUuid) {
|
||||
const isSessionRelatedToPublicKey =
|
||||
|
|
@ -84,10 +90,14 @@ async function getPublicKeyRelatedToSession(sessionUuid) {
|
|||
return null;
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
return {
|
||||
createSession,
|
||||
isSessionValid,
|
||||
relateSessionToPublicKey,
|
||||
isSessionAuthorized,
|
||||
getPublicKeyRelatedToSession,
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = SessionServiceProvider;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue