start api routes
This commit is contained in:
parent
db97f9fd80
commit
c923493108
3 changed files with 290 additions and 273 deletions
|
|
@ -18,11 +18,8 @@ function createApp(dependencies) {
|
||||||
|
|
||||||
app.use(dependencies.middlewares.createSessionMiddleware);
|
app.use(dependencies.middlewares.createSessionMiddleware);
|
||||||
|
|
||||||
const webRoutes = dependencies.webRoutes;
|
app.use('/', dependencies.webRoutes);
|
||||||
const apiRoutes = require('./routes/apiRoutes');
|
app.use('/api', dependencies.apiRoutes);
|
||||||
|
|
||||||
app.use('/', webRoutes);
|
|
||||||
app.use('/api', apiRoutes);
|
|
||||||
|
|
||||||
app.use(express.static(path.join(__dirname, 'public')));
|
app.use(express.static(path.join(__dirname, 'public')));
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -15,6 +15,10 @@ function buildDependencies() {
|
||||||
invitesService,
|
invitesService,
|
||||||
});
|
});
|
||||||
dependencies.webRoutes = webRoutesProvider.provide();
|
dependencies.webRoutes = webRoutesProvider.provide();
|
||||||
|
|
||||||
|
const ApiRoutesProvider = require('./routes/apiRoutes');
|
||||||
|
const apiRoutesProvider = new ApiRoutesProvider();
|
||||||
|
dependencies.apiRoutes = apiRoutesProvider.provide();
|
||||||
return dependencies;
|
return dependencies;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -16,12 +16,17 @@ const profileService = profileServiceProvider(ContactDetailsSet, NymSet);
|
||||||
|
|
||||||
const router = express.Router();
|
const router = express.Router();
|
||||||
|
|
||||||
router.get('/signup/nostr-challenge', async (req, res) => {
|
class ApiRoutesProvider {
|
||||||
|
constructor() {}
|
||||||
|
|
||||||
|
provide() {
|
||||||
|
router.get('/signup/nostr-challenge', async (req, res) => {
|
||||||
const inviteUuid = req.cookies.inviteUuid;
|
const inviteUuid = req.cookies.inviteUuid;
|
||||||
|
|
||||||
let signUpChallenge;
|
let signUpChallenge;
|
||||||
try {
|
try {
|
||||||
signUpChallenge = await invitesService.createSignUpChallenge(inviteUuid);
|
signUpChallenge =
|
||||||
|
await invitesService.createSignUpChallenge(inviteUuid);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
if (error instanceof errors.NotFoundError) {
|
if (error instanceof errors.NotFoundError) {
|
||||||
return res.status(404).json({
|
return res.status(404).json({
|
||||||
|
|
@ -55,10 +60,12 @@ router.get('/signup/nostr-challenge', async (req, res) => {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
return res.status(200).json({ challenge: relatedNostrChallenge.challenge });
|
return res
|
||||||
});
|
.status(200)
|
||||||
|
.json({ challenge: relatedNostrChallenge.challenge });
|
||||||
|
});
|
||||||
|
|
||||||
router.post('/signup/nostr-verify', async (req, res) => {
|
router.post('/signup/nostr-verify', async (req, res) => {
|
||||||
const signedEvent = req.body;
|
const signedEvent = req.body;
|
||||||
const sessionUuid = req.cookies.sessionUuid;
|
const sessionUuid = req.cookies.sessionUuid;
|
||||||
|
|
||||||
|
|
@ -93,9 +100,9 @@ router.post('/signup/nostr-verify', async (req, res) => {
|
||||||
);
|
);
|
||||||
|
|
||||||
return res.status(200).json({ success: true });
|
return res.status(200).json({ success: true });
|
||||||
});
|
});
|
||||||
|
|
||||||
router.get('/login/nostr-challenge', async (req, res) => {
|
router.get('/login/nostr-challenge', async (req, res) => {
|
||||||
let loginChallenge;
|
let loginChallenge;
|
||||||
try {
|
try {
|
||||||
loginChallenge = await loginService.createLoginChallenge();
|
loginChallenge = await loginService.createLoginChallenge();
|
||||||
|
|
@ -118,10 +125,12 @@ router.get('/login/nostr-challenge', async (req, res) => {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
return res.status(200).json({ challenge: relatedNostrChallenge.challenge });
|
return res
|
||||||
});
|
.status(200)
|
||||||
|
.json({ challenge: relatedNostrChallenge.challenge });
|
||||||
|
});
|
||||||
|
|
||||||
router.post('/login/nostr-verify', async (req, res) => {
|
router.post('/login/nostr-verify', async (req, res) => {
|
||||||
const signedEvent = req.body;
|
const signedEvent = req.body;
|
||||||
const sessionUuid = req.cookies.sessionUuid;
|
const sessionUuid = req.cookies.sessionUuid;
|
||||||
|
|
||||||
|
|
@ -171,9 +180,9 @@ router.post('/login/nostr-verify', async (req, res) => {
|
||||||
);
|
);
|
||||||
|
|
||||||
return res.status(200).json({ success: true });
|
return res.status(200).json({ success: true });
|
||||||
});
|
});
|
||||||
|
|
||||||
router.post(
|
router.post(
|
||||||
'/set-contact-details',
|
'/set-contact-details',
|
||||||
rejectIfNotAuthorizedMiddleware,
|
rejectIfNotAuthorizedMiddleware,
|
||||||
attachPublicKeyMiddleware,
|
attachPublicKeyMiddleware,
|
||||||
|
|
@ -188,16 +197,19 @@ router.post(
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
await profileService.setContactDetails(publicKey, encryptedContactDetails);
|
await profileService.setContactDetails(
|
||||||
|
publicKey,
|
||||||
|
encryptedContactDetails
|
||||||
|
);
|
||||||
|
|
||||||
return res.status(200).json({
|
return res.status(200).json({
|
||||||
success: true,
|
success: true,
|
||||||
message: 'Contact details set successfully.',
|
message: 'Contact details set successfully.',
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
router.post(
|
router.post(
|
||||||
'/set-nym',
|
'/set-nym',
|
||||||
rejectIfNotAuthorizedMiddleware,
|
rejectIfNotAuthorizedMiddleware,
|
||||||
attachPublicKeyMiddleware,
|
attachPublicKeyMiddleware,
|
||||||
|
|
@ -219,9 +231,9 @@ router.post(
|
||||||
message: 'Nym set successfully.',
|
message: 'Nym set successfully.',
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
router.post(
|
router.post(
|
||||||
'/offer',
|
'/offer',
|
||||||
rejectIfNotAuthorizedMiddleware,
|
rejectIfNotAuthorizedMiddleware,
|
||||||
attachPublicKeyMiddleware,
|
attachPublicKeyMiddleware,
|
||||||
|
|
@ -236,9 +248,9 @@ router.post(
|
||||||
message: 'Offer created successfully',
|
message: 'Offer created successfully',
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
router.delete(
|
router.delete(
|
||||||
'/offer/:offerUuid',
|
'/offer/:offerUuid',
|
||||||
rejectIfNotAuthorizedMiddleware,
|
rejectIfNotAuthorizedMiddleware,
|
||||||
attachPublicKeyMiddleware,
|
attachPublicKeyMiddleware,
|
||||||
|
|
@ -265,9 +277,9 @@ router.delete(
|
||||||
message: 'Offer deleted successfully',
|
message: 'Offer deleted successfully',
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
router.get(
|
router.get(
|
||||||
'/publickey-offers',
|
'/publickey-offers',
|
||||||
rejectIfNotAuthorizedMiddleware,
|
rejectIfNotAuthorizedMiddleware,
|
||||||
attachPublicKeyMiddleware,
|
attachPublicKeyMiddleware,
|
||||||
|
|
@ -292,6 +304,10 @@ router.get(
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
module.exports = router;
|
return router;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = ApiRoutesProvider;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue