Skip to content

Commit

Permalink
Merge pull request #80 from bahnzumberg/uat
Browse files Browse the repository at this point in the history
First Fal PR
  • Loading branch information
martinheppner authored Jan 13, 2024
2 parents 80a088e + 9eb439c commit bb60b57
Show file tree
Hide file tree
Showing 6 changed files with 103 additions and 30 deletions.
9 changes: 4 additions & 5 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,6 @@
"body-parser": "^1.17.1",
"cookie-parser": "^1.4.6",
"cors": "^2.8.5",
"cron": "^1.8.2",
"crypto": "^1.0.1",
"csurf": "^1.11.0",
"es6-promise-pool": "^2.5.0",
Expand All @@ -57,15 +56,15 @@
"mysql": "^2.18.1",
"mysql2": "^3.6.2",
"node-schedule": "^2.1.0",
"p-limit": "^3.1.0",
"p-limit": "^5.0.0",
"path": "^0.12.7",
"pg": "^8.7.3",

"puppeteer": "^16.0.0",
"puppeteer-core": "^16.0.0",
"puppeteer": "^21.7.0",
"puppeteer-core": "^21.7.0",
"request": "^2.88.2",
"request-promise": "^4.2.6",
"sharp": "^0.30.7",
"sharp": "^0.33.1",
"xml-js": "^1.6.11",
"xmlbuilder2": "^3.0.2"
}
Expand Down
5 changes: 5 additions & 0 deletions src/jobs/sync.js
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ export async function fixTours(){


const deleteFilesOlder30days = (dirPath) => {
!!dirPath && console.log("L76 dirPath = ", dirPath)
// if the directory does not exist, create it
if (!fs.existsSync(dirPath)){
fs.mkdirSync(dirPath);
Expand Down Expand Up @@ -120,6 +121,10 @@ export async function writeKPIs(){

await knex.raw(`DELETE FROM kpi WHERE kpi.name='total_provider';`);
await knex.raw(`INSERT INTO kpi SELECT 'total_provider', COUNT(DISTINCT provider) FROM tour;`);


// Unrelated to the KPIs, but the old disposable links have to be deleted as well
await knex.raw(`DELETE FROM disposible WHERE calendar_date < now() - INTERVAL '10 DAY';`);
}


Expand Down
21 changes: 20 additions & 1 deletion src/routes/tours.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,16 @@ import moment from "moment";
import {tourPdf} from "../utils/pdf/tourPdf";
import {getHost, replaceFilePath, round, get_domain_country, get_country_lanuage_from_domain, getAllLanguages } from "../utils/utils";
import { convertDifficulty } from '../utils/dataConversion';
import logger from '../utils/logger';
// import logger from '../utils/logger';
import logger, { create_api_log } from '../utils/logger';

const fs = require('fs');
const path = require('path');

//create log file
create_api_log();


router.get('/', (req, res) => listWrapper(req, res));
router.get('/filter', (req, res) => filterWrapper(req, res));
router.get('/provider/:provider', (req, res) => providerWrapper(req, res));
Expand Down Expand Up @@ -1311,6 +1316,20 @@ const tourPdfWrapper = async (req, res) => {
const tour = await knex('tour').select().where({id: id}).first();
let connection, connectionReturn, connectionReturns = null;

if (!tour){
logger("L1320 : tour not found")
res.status(404).json({success: false});
return;
}else{
if(process.env.NODE_ENV != "production"){
logger("-----------------------------------------------")
logger(`L1324 : tour with id ${id} found`)
logger("-----------------------------------------------")
console.log("-----------------------------------------------")
console.log(`L1324 : tour with id ${id} found`)
console.log("-----------------------------------------------")
}
}
if(!!connectionId){
connection = await knex('fahrplan').select().where({id: connectionId}).first();
}
Expand Down
54 changes: 36 additions & 18 deletions src/utils/logger.js
Original file line number Diff line number Diff line change
@@ -1,25 +1,43 @@
import * as fs from "fs";
const path = require('path');
import * as fs from 'fs';
import path from 'path';

export default function(text) {
let proddevPath = "../";
if(process.env.NODE_ENV != "production"){
proddevPath = "../../";
let lineCount = 0;
const maxAllowed = 100;

export default function (text) {
// const proddevPath = process.env.NODE_ENV !== 'production' ? '../../' : '../';
const proddevPath = process.env.NODE_ENV !== 'production' ? '../../' : '../../';
const filePath = path.join(__dirname, proddevPath, 'logs/api.log');

// Ensure the directory exists
if (!fs.existsSync(path.dirname(filePath))) {
fs.mkdirSync(path.dirname(filePath), { recursive: true });
}
const filePath = path.join(__dirname, proddevPath, "logs/api.log");

fs.appendFileSync(filePath, text + "\n", function (err) {
if (err) throw err;
});
};
if (lineCount < maxAllowed) {
// add log entry
fs.appendFileSync(filePath, text + '\n');
lineCount++;
} else {
// this will erase the current file and add a new "text" line
fs.writeFileSync(filePath, text + '\n');
lineCount = 1;
}
}

// call this function whenever the server starts// for now test it on tours.js
export function create_api_log() {
let proddevPath = "../";
if(process.env.NODE_ENV != "production"){
proddevPath = "../../";
// const proddevPath = process.env.NODE_ENV !== 'production' ? '../../' : '../';
const proddevPath = process.env.NODE_ENV !== 'production' ? '../../' : '../../';
const filePath = path.join(__dirname, proddevPath, 'logs/api.log');

// Make sure directory exists
if (!fs.existsSync(path.dirname(filePath))) {
fs.mkdirSync(path.dirname(filePath), { recursive: true });
}
if (!fs.existsSync(path.join(__dirname, proddevPath, "logs"))){
fs.mkdirSync(path.join(__dirname, proddevPath, "logs"));
fs.createWriteStream(path.join(__dirname, proddevPath, "logs/api.log"));

// Create file when not existent yet
if (!fs.existsSync(filePath)) {
fs.writeFileSync(filePath, '');
}
}
}
38 changes: 35 additions & 3 deletions src/utils/pdf/tourPdf.js
Original file line number Diff line number Diff line change
Expand Up @@ -155,14 +155,44 @@ export const createReturnEntries = (entries, connection) => {
}

}
// console.log("L158 toReturn: " + JSON.stringify(toReturn));
return toReturn;
}
//example of variable "entries"
// [
// "08:02 Wien Meidling",
// " | 01:03 Std mit Zug REX9 nach",
// "09:05 Payerbach-Reichenau Bahnhof",
// " = 00:09 Std Umstiegszeit",
// "09:14 Payerbach-Reichenau Bahnhof",
// " | 00:22 Std mit Bus 341 nach",
// "09:36 Höllental Abzw. Weichtalhaus",
// " > 00:02 Std Zustiegsdauer zum Touren-Ausgangspunkt",
// ""];
// Below is sample output from : "L158 toReturn"
// [
// {"time":"08:14","text":" Baden Bahnhof","firstEntry":true},
// {"time":"","image":"http://localhost:8080/public/icons/ic_transport_train.svg","text":" 00:51 Std mit Zug REX9 nach","middleEntry":true,"detailEntry":true},
// {"time":"09:05","text":" Payerbach-Reichenau Bahnhof","middleEntry":true},
// {"time":"","image":"http://localhost:8080/public/icons/ic_shuffle_black.svg","text":" 00:09 Std Umstiegszeit","middleEntry":true,"detailEntry":true},
// {"time":"09:14","text":" Payerbach-Reichenau Bahnhof","middleEntry":true},
// {"time":"","image":"http://localhost:8080/public/icons/ic_transport_bus.svg","text":" 00:22 Std mit Bus 341 nach","middleEntry":true,"detailEntry":true},
// {"time":"09:36","text":" Höllental Abzw. Weichtalhaus","middleEntry":true},
// {"time":"","image":"http://localhost:8080/public/icons/ic_transport_walk.svg","text":" 00:02 Std Zustiegsdauer zum Touren-Ausgangspunkt","middleEntry":true,"detailEntry":true},
// {"time":"00:02","text":" Ankunft bei Tourstart","lastEntry":true}
// ]

// using the new JSON method described in :
// https://github.com/bahnzumberg/hermes/wiki/Connection-and-Return-Description ,
// check the file /zuugle-api/test_fahrplan.json for a sample of data
// from jsonb column 'connection_description_json' inside table 'fahrplan'


export const createConnectionEntries = (entries, connection) => {
let toReturn = [];
if(!!entries && entries.length > 0){
let _entries = entries.filter(e => !!e && e.length > 0);
toReturn.push(getDepartureEntry(_entries[0]));
toReturn.push(getDepartureEntry(_entries[0])); // e.g. "08:02 Wien Meidling" result: ['08:02', 'Wien Meidling']
for(let i=1; i<_entries.length; i++){
let entry = _entries[i];
if((i-1)%2 == 0){
Expand All @@ -184,10 +214,12 @@ export const createConnectionEntries = (entries, connection) => {
}
toReturn.push(getArrivalEntry(`${newStart} Ankunft bei Tourstart`));
}
// console.log("L197 toReturn: " + JSON.stringify(toReturn));

return toReturn;
}

const getDepartureEntry = (entry) => {
const getDepartureEntry = (entry) => { // e.g. entry = "08:02 Wien Meidling"
return {
time: getTimeFromConnectionDescriptionEntry(entry),
text: getTextFromConnectionDescriptionEntry(entry),
Expand Down Expand Up @@ -221,7 +253,7 @@ const getStationEntry = (entry) => {
}
}

export const getTimeFromConnectionDescriptionEntry = (entry) => {
export const getTimeFromConnectionDescriptionEntry = (entry) => { // e.g. entry = "08:02 Wien Meidling"
let _entry = !!entry ? entry.trim() : null;
if(!!_entry && _entry.length > 5){
return _entry.substring(0,5);
Expand Down
6 changes: 3 additions & 3 deletions src/utils/pdf/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -104,9 +104,9 @@ const readFile = (name, contentType = null) => {
}
};

export const getLogoBase64 = () => {
return "";
}
export const getLogoBase64 = () =>
"";


// **************
// description 1:
Expand Down

0 comments on commit bb60b57

Please sign in to comment.