From ea2e9b41b3b1eace8e99d6e2672ffffb07665e04 Mon Sep 17 00:00:00 2001
From: Jacek Kowalski <Jacek@jacekk.info>
Date: Fri, 21 Jun 2019 11:46:18 +0000
Subject: [PATCH] Add regenerate.php to recreate JSON files in case of manual changes

---
 regenerate.php |   28 ++++++++++++++++++++++++++++
 1 files changed, 28 insertions(+), 0 deletions(-)

diff --git a/regenerate.php b/regenerate.php
new file mode 100644
index 0000000..cd1186a
--- /dev/null
+++ b/regenerate.php
@@ -0,0 +1,28 @@
+<?php
+require_once(__DIR__.'/vendor/autoload.php');
+require_once(__DIR__.'/lib/database.php');
+require_once(__DIR__.'/lib/vehicle_types.php');
+require_once(__DIR__.'/config.php');
+
+foreach($sources as $name => $source) {
+	$logger = new Monolog\Logger('regenerate_'.$name);
+	try {
+		$logger->info('Regenerating '.$name.'...');
+		
+		$db = new Database($source['database']);
+		
+		$jsonContent = [];
+		foreach($db->getAll() as $vehicle) {
+			$jsonContent[$vehicle['id']] = $source['mapper']($vehicle['num']);
+		}
+		
+		$json = json_encode($jsonContent);
+		if(!file_put_contents($source['result_temp'], $json)) {
+			throw new Exception('Result save failed');
+		}
+		rename($source['result_temp'], $source['result']);
+		$logger->info('Finished');
+	} catch(Throwable $e) {
+		$logger->error($e->getMessage(), ['exception' => $e, 'exception_string' => (string)$e]);
+	}
+}

--
Gitblit v1.9.1