-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
refactor: 🫧 seperate logic into own functions
Signed-off-by: Manuel Ruck <[email protected]>
- Loading branch information
Manuel Ruck
committed
Nov 30, 2024
1 parent
acab505
commit ca8d3bd
Showing
13 changed files
with
469 additions
and
203 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
{ | ||
"version": "0.2.0", | ||
"configurations": [ | ||
{ | ||
"name": "Attach to Process", | ||
"type": "node", | ||
"request": "attach", | ||
"port": 9229, | ||
"restart": true, | ||
"timeout": 10000, | ||
"skipFiles": ["<node_internals>/**"] | ||
}, | ||
{ | ||
"name": "Run crawler dev", | ||
"type": "node", | ||
"request": "launch", | ||
"runtimeExecutable": "pnpm", | ||
"runtimeArgs": ["dev"], | ||
"cwd": "${workspaceFolder}/services/cron-jobs/crawler", | ||
"console": "integratedTerminal", | ||
"internalConsoleOptions": "neverOpen" | ||
} | ||
], | ||
"compounds": [ | ||
{ | ||
"name": "Debug crawler dev", | ||
"configurations": ["Run crawler dev", "Attach to Process"] | ||
} | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,37 +1,43 @@ | ||
import axios from 'axios'; | ||
import axios, { AxiosInstance, AxiosResponse, InternalAxiosRequestConfig } from 'axios'; | ||
|
||
const MAX_REQUESTS_COUNT = 1; | ||
const INTERVAL_MS = 1000; | ||
let PENDING_REQUESTS = 0; | ||
// create new axios instance | ||
const api = axios.create({}); | ||
|
||
/** | ||
* Axios Request Interceptor | ||
*/ | ||
api.interceptors.request.use(function (config) { | ||
return new Promise((resolve) => { | ||
const interval = setInterval(() => { | ||
if (PENDING_REQUESTS < MAX_REQUESTS_COUNT) { | ||
PENDING_REQUESTS++; | ||
clearInterval(interval); | ||
resolve(config); | ||
} | ||
}, INTERVAL_MS); | ||
function setupRequestInterceptor(apiInstance: AxiosInstance): void { | ||
apiInstance.interceptors.request.use(function (config: InternalAxiosRequestConfig) { | ||
return new Promise((resolve) => { | ||
const interval = setInterval(() => { | ||
if (PENDING_REQUESTS < MAX_REQUESTS_COUNT) { | ||
PENDING_REQUESTS++; | ||
clearInterval(interval); | ||
resolve(config); | ||
} | ||
}, INTERVAL_MS); | ||
}); | ||
}); | ||
}); | ||
/** | ||
* Axios Response Interceptor | ||
*/ | ||
api.interceptors.response.use( | ||
function (response) { | ||
PENDING_REQUESTS = Math.max(0, PENDING_REQUESTS - 1); | ||
return Promise.resolve(response); | ||
}, | ||
function (error) { | ||
PENDING_REQUESTS = Math.max(0, PENDING_REQUESTS - 1); | ||
return Promise.reject(error); | ||
}, | ||
); | ||
} | ||
|
||
function setupResponseInterceptor(apiInstance: AxiosInstance): void { | ||
apiInstance.interceptors.response.use( | ||
function (response: AxiosResponse) { | ||
PENDING_REQUESTS = Math.max(0, PENDING_REQUESTS - 1); | ||
return Promise.resolve(response); | ||
}, | ||
function (error: unknown) { | ||
PENDING_REQUESTS = Math.max(0, PENDING_REQUESTS - 1); | ||
return Promise.reject(error); | ||
}, | ||
); | ||
} | ||
|
||
const createAxiosInstance = (): AxiosInstance => { | ||
const api = axios.create({}); | ||
setupRequestInterceptor(api); | ||
setupResponseInterceptor(api); | ||
return api; | ||
}; | ||
|
||
const api = createAxiosInstance(); | ||
|
||
export default api; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,27 +1,39 @@ | ||
const { | ||
DB_URL = 'mongodb://localhost:27017/bundestagio', | ||
IMPORT_PROCEDURES_START_CURSOR = '*', | ||
IMPORT_PROCEDURES_FILTER_BEFORE = new Date().toISOString().slice(0, 10), | ||
IMPORT_PROCEDURES_FILTER_AFTER = new Date(Number(new Date()) - 1000 * 60 * 60 * 24 * 7 * 4) | ||
.toISOString() | ||
.slice(0, 10), | ||
} = process.env; | ||
const parseEnvVariables = () => { | ||
const { | ||
DB_URL = 'mongodb://localhost:27017/bundestagio', | ||
IMPORT_PROCEDURES_START_CURSOR = '*', | ||
IMPORT_PROCEDURES_FILTER_BEFORE = new Date().toISOString().slice(0, 10), | ||
IMPORT_PROCEDURES_FILTER_AFTER = new Date(Number(new Date()) - 1000 * 60 * 60 * 24 * 7 * 4) | ||
.toISOString() | ||
.slice(0, 10), | ||
} = process.env; | ||
|
||
let { IMPORT_PROCEDURES_CHUNK_SIZE = 100, IMPORT_PROCEDURES_CHUNK_ROUNDS = 5 } = process.env; | ||
let { IMPORT_PROCEDURES_CHUNK_SIZE = 100, IMPORT_PROCEDURES_CHUNK_ROUNDS = 5 } = process.env; | ||
|
||
IMPORT_PROCEDURES_CHUNK_SIZE = Number(IMPORT_PROCEDURES_CHUNK_SIZE); | ||
IMPORT_PROCEDURES_CHUNK_ROUNDS = Number(IMPORT_PROCEDURES_CHUNK_ROUNDS); | ||
const IMPORT_PROCEDURES_FILTER_TYPES = process.env.IMPORT_PROCEDURES_FILTER_TYPES | ||
? process.env.IMPORT_PROCEDURES_FILTER_TYPES.split(',') | ||
: undefined; | ||
IMPORT_PROCEDURES_CHUNK_SIZE = Number(IMPORT_PROCEDURES_CHUNK_SIZE); | ||
IMPORT_PROCEDURES_CHUNK_ROUNDS = Number(IMPORT_PROCEDURES_CHUNK_ROUNDS); | ||
const IMPORT_PROCEDURES_FILTER_TYPES = process.env.IMPORT_PROCEDURES_FILTER_TYPES | ||
? process.env.IMPORT_PROCEDURES_FILTER_TYPES.split(',') | ||
: undefined; | ||
|
||
export const CONFIG = { | ||
DIP_API_KEY: process.env.DIP_API_KEY || '', | ||
DB_URL, | ||
IMPORT_PROCEDURES_CHUNK_SIZE, | ||
IMPORT_PROCEDURES_CHUNK_ROUNDS, | ||
IMPORT_PROCEDURES_FILTER_BEFORE, | ||
IMPORT_PROCEDURES_FILTER_AFTER, | ||
IMPORT_PROCEDURES_FILTER_TYPES, | ||
IMPORT_PROCEDURES_START_CURSOR, | ||
} as const; | ||
return { | ||
DB_URL, | ||
IMPORT_PROCEDURES_START_CURSOR, | ||
IMPORT_PROCEDURES_FILTER_BEFORE, | ||
IMPORT_PROCEDURES_FILTER_AFTER, | ||
IMPORT_PROCEDURES_CHUNK_SIZE, | ||
IMPORT_PROCEDURES_CHUNK_ROUNDS, | ||
IMPORT_PROCEDURES_FILTER_TYPES, | ||
}; | ||
}; | ||
|
||
function getConfig() { | ||
const envVariables = parseEnvVariables(); | ||
|
||
return { | ||
DIP_API_KEY: process.env.DIP_API_KEY || '', | ||
...envVariables, | ||
} as const; | ||
} | ||
|
||
export const CONFIG = getConfig(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
import { getCron, setCronStart, setCronSuccess, ICronJob } from '@democracy-deutschland/bundestagio-common'; | ||
import { Logger } from './logger'; | ||
import { executeImportProcedures } from './importProceduresExecutor'; | ||
import { CONFIG } from './config'; | ||
|
||
const CRON_JOB_NAME = 'import-procedures'; | ||
|
||
/** | ||
* Handles the cron job execution. | ||
* @param config - The configuration object. | ||
* @param logger - The logger instance. | ||
*/ | ||
export const handleCronJob = async (config: typeof CONFIG, logger: Logger): Promise<void> => { | ||
try { | ||
logger.info('Handling cron job...'); | ||
const cronjob: ICronJob = await getCron({ name: CRON_JOB_NAME }); | ||
await setCronStart({ name: CRON_JOB_NAME }); | ||
await executeImportProcedures(cronjob, config, logger); | ||
await setCronSuccess({ name: CRON_JOB_NAME, successStartDate: cronjob.lastStartDate || new Date() }); | ||
logger.info('Cron job handled successfully.'); | ||
} catch (error) { | ||
logger.error('Failed to handle cron job.'); | ||
logger.debug('Error details: ' + (error instanceof Error ? error.message : error)); | ||
process.exit(1); | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
import { mongoConnect } from '@democracy-deutschland/bundestagio-common'; | ||
import { Logger } from './logger'; | ||
|
||
export const connectToDatabase = async (dbUrl: string, logger: Logger): Promise<void> => { | ||
try { | ||
logger.info('Connecting to the database...'); | ||
await mongoConnect(dbUrl); | ||
logger.info('Database connection successful.'); | ||
} catch (error) { | ||
logger.error('Failed to connect to the database:'); | ||
logger.debug(`Error details: ${error instanceof Error ? error.message : error}`); | ||
process.exit(1); | ||
} | ||
}; |
Oops, something went wrong.