diff --git a/app/config/appConfig.js b/app/config/appConfig.js
index 4403fbd..1802a53 100644
--- a/app/config/appConfig.js
+++ b/app/config/appConfig.js
@@ -9,6 +9,8 @@ const APP_URL =
? process.env.APP_URL || "http://market-alarm"
: process.env.APP_URL || `${APP_BASE_URL}:${APP_PORT}`;
+const STAGING = process.env.NODE_ENV !== "production";
+
const DEFAULT_TIMEZONE = "Europe/Sarajevo";
const CRAWLER_INTERVAL = parseInt(process.env.CRAWLER_INTERVAL) || 60;
@@ -48,5 +50,6 @@ module.exports = {
MAX_REAL_ESTATES_IN_FIRST_EMAIL,
PRINT_CRAWLER_DEBUG,
API_MAP_KEY,
- PROSTOR_LOGIN
+ PROSTOR_LOGIN,
+ STAGING
};
diff --git a/app/helpers/emailContentGenerator.js b/app/helpers/emailContentGenerator.js
index 5e745bc..e9efbfc 100644
--- a/app/helpers/emailContentGenerator.js
+++ b/app/helpers/emailContentGenerator.js
@@ -1,8 +1,15 @@
"use strict";
-const { MAX_REAL_ESTATES_IN_EMAIL, APP_URL } = require("../config/appConfig");
+const {
+ MAX_REAL_ESTATES_IN_EMAIL,
+ APP_URL,
+ STAGING
+} = require("../config/appConfig");
const { AD_CATEGORY, AD_TYPE, EMAIL_FREQUENCY } = require("../common/enums");
+//Tag to recognize staging from development
+const stagingTag = STAGING ? "[STAGING] " : "";
+
const generateEmailFooter = (searchRequestId, emailFrequencyTitle) => {
return `
Trenutno ste prijavljeni da obavještenja o novim nekretninama primate ${emailFrequencyTitle.toLowerCase()} .
Ako želite prestati dobijati obavještenja za ovu pretragu,
odjavite ovdje
@@ -54,7 +61,7 @@ const generateNotificationEmail = (
const messageBody = dailyNotification ? dailyMessageBody : asapMessageBody;
- return `Zdravo
+ return `${stagingTag}Zdravo
${messageBody}
${realEstateLinks}
@@ -113,7 +120,7 @@ const generateNewSearchRequestEmail = (searchRequest, matchingRealEstates) => {
const emailFooter = generateEmailFooter(id, emailFrequencyTitle);
- return `
Zdravo
+ return `
${stagingTag}Zdravo
Naručili ste da Vam javimo ako se nekretnina sa navedenim uslovima pojavi u oglasima:
@@ -130,7 +137,7 @@ const generateNewSearchRequestEmail = (searchRequest, matchingRealEstates) => {
const generateEmailSubject = (numberOfRealEstates, singleRealEstateTitle) => {
if (numberOfRealEstates === 1) {
- return `Kivi: ${singleRealEstateTitle}`;
+ return `${stagingTag}Kivi: ${singleRealEstateTitle}`;
}
const leastSignificantDigit = numberOfRealEstates % 10;
@@ -138,7 +145,7 @@ const generateEmailSubject = (numberOfRealEstates, singleRealEstateTitle) => {
const secondLeastSignificantDigit = numberWithoutLastDigit % 10;
if (leastSignificantDigit === 1 && secondLeastSignificantDigit !== 1) {
- return `Kivi : ${numberOfRealEstates} nova nekretnina`;
+ return `${stagingTag}Kivi : ${numberOfRealEstates} nova nekretnina`;
}
if (
@@ -146,10 +153,10 @@ const generateEmailSubject = (numberOfRealEstates, singleRealEstateTitle) => {
leastSignificantDigit <= 4 &&
secondLeastSignificantDigit !== 1
) {
- return `Kivi: ${numberOfRealEstates} nove nekretnine`;
+ return `${stagingTag}Kivi: ${numberOfRealEstates} nove nekretnine`;
}
- return `Kivi: ${numberOfRealEstates} novih nekretnina`;
+ return `${stagingTag}Kivi: ${numberOfRealEstates} novih nekretnina`;
};
module.exports = {
diff --git a/app/services/notificationService.js b/app/services/notificationService.js
index 7a4a62a..1d05283 100644
--- a/app/services/notificationService.js
+++ b/app/services/notificationService.js
@@ -1,4 +1,5 @@
"use strict";
+const { STAGING } = require("../config/appConfig");
const {
matchRealEstates,
matchSearchRequest
@@ -24,13 +25,17 @@ const notifyForNewSearchRequest = async searchRequest => {
const searchRequestId = searchRequest.id;
const matchingRealEstates = matches[searchRequestId].realEstates;
-
+ const stagingTag = STAGING ? "[STAGING] " : "";
const emailContent = generateNewSearchRequestEmail(
searchRequest,
matchingRealEstates
);
const { email } = searchRequest;
- await sendEmail(email, "Kivi - novi zahtjev za pretragu", emailContent);
+ await sendEmail(
+ email,
+ `${stagingTag} Kivi - novi zahtjev za pretragu`,
+ emailContent
+ );
};
const notifyMatches = async (matches, dailyNotification = false) => {