Compare commits

...

36 Commits

Author SHA1 Message Date
88e92dddb9 Fix: nextTimeStep must be between minParkingTime and maxParkingTime. 2023-12-11 09:00:24 +01:00
0f05a1a784 (1) Fix debug output.
(2) Use UpDown-Argument for calculation of next tiem step.
2023-12-08 10:16:52 +01:00
2d696941a5 Fix: use second.pun_duration instead of second.pun_id
Minor: add debug output.
2023-12-08 10:14:48 +01:00
5598b02816 Make distinction base on PaymentMethod, not on some
other data contained in json-tariff-file.
2023-12-07 17:00:28 +01:00
548447af1f set -O option to calm down compiler because of FORTIFY_SOURCE=2 option 2023-12-07 17:00:03 +01:00
b9a7c04db9 Add compute_next_timestep() computing timesteps if PaymentMethod = Steps.
Add additional code for computing time steps dynamically if PaymentMethod = Linear.
2023-12-07 16:28:17 +01:00
5b8d9c62cc Add and implement utilities:
int getMinimalParkingTime(Configuration const *cfg, PaymentMethod methodId);
    int getMaximalParkingTime(Configuration const *cfg, PaymentMethod methodId);
    uint32_t getMinimalParkingPrice(Configuration const *cfg, PaymentMethod methodId);
    uint32_t getFirstDurationStep(Configuration const *cfg, PaymentMethod methodId);
2023-12-07 16:27:09 +01:00
56e2843ddb Add compute_next_timestep(). 2023-12-07 16:26:09 +01:00
6b76c4c2dd Add test cases for neuhauser. 2023-12-06 10:52:35 +01:00
54e9a0f86d Minor: add debug ouput (and commnt it out) 2023-12-06 10:51:46 +01:00
d7beb3b41b Fix: replace 'continue' with 'break' to return first fitting time-range
in findNextWorkTimeRange().
2023-12-06 10:49:33 +01:00
9d220df52e Mainly removed debug output. Regression tests with szeged looking good. 2023-12-05 17:31:56 +01:00
de7a63bc2a new test cases for regression tests 2023-12-05 17:30:12 +01:00
73b1c1459e added tariff for testing 2023-12-01 14:26:07 +01:00
a599e47a47 Add test cases for szeged. 2023-12-01 14:25:06 +01:00
e97ad17b09 removed typo 2023-12-01 14:24:51 +01:00
19428ce46c implemented both cost and duration functions. to be tested 2023-12-01 14:24:15 +01:00
4c268e6693 Added draft implementation of private_GetDurationFromCost(). 2023-11-28 16:43:03 +01:00
cc5c52c1a0 Added private_getDurationFromCost() 2023-11-28 16:42:29 +01:00
602ff5f94e Added State for invalid price 2023-11-28 16:41:27 +01:00
b8720bac6c Added special days. 2023-11-28 16:40:41 +01:00
64c005cd70 Implement private_GetCostFromDuration() using a loop and not using
recursive calls.
2023-11-28 15:25:37 +01:00
9abc165a7c Implemented computeWeekDaysPrice() and computeWeekDaysDurationUnit() 2023-11-28 15:20:31 +01:00
57ec82a2fc Added helpers computeWeekDaysPrice() and computeWeekDaysDurationUnit() 2023-11-28 15:18:05 +01:00
a49236c1de Removed parameters in private_GetCostFromDuration() and checkDurationMinutes() 2023-11-28 15:17:27 +01:00
9a19320ee5 Minor: removed debug output. 2023-11-28 15:15:13 +01:00
9e8833f362 Added special days. 2023-11-28 15:14:35 +01:00
7a5d797ae0 Start reimplementation of
private_GetCostFromDuration() in terms of ticket.
2023-11-27 16:21:28 +01:00
215667af61 Implement findWorkTimeRange() and indNextWorkTimeRange(). 2023-11-27 16:19:39 +01:00
2b6d116200 Implement GetCostFromDuration() in terms of private_GetCostFromDuration()
using a ticket as return value.
2023-11-27 16:18:06 +01:00
2d9ed3c1c8 testing ... 2023-11-27 16:16:50 +01:00
9ca45e613f Return a ticket from private_GetCostFromDuration().
Add helpers findWorkTimeRange() and findNextWorkTimeRange().
2023-11-27 16:15:18 +01:00
6a3d183129 Minor: overload constructor 2023-11-27 16:14:27 +01:00
684de4acd1 Reformat to Unix.
Add overload for IsYearPeriodActive().
Add several helpers.
2023-11-27 16:12:07 +01:00
e9047f995a Minor: format to Unix. 2023-11-27 16:09:38 +01:00
20cdb8b07f Add overload for IsYearPeriodActive().
Add helpers WeekDaysWorkTimeFrom(), WeekDaysWorkTimeUntil(), isCarryOverSet()
sCarryOverNotSet() and getPaymentMethodId().
2023-11-27 16:07:30 +01:00
13 changed files with 2700 additions and 1287 deletions

View File

@@ -109,6 +109,8 @@ CalcState CALCULATE_LIBRARY_API init_tariff(parking_tariff_t **tariff,
void CALCULATE_LIBRARY_API free_tariff(parking_tariff_t *tariff); void CALCULATE_LIBRARY_API free_tariff(parking_tariff_t *tariff);
int CALCULATE_LIBRARY_API get_zone_nr(int zone = -1); int CALCULATE_LIBRARY_API get_zone_nr(int zone = -1);
int CALCULATE_LIBRARY_API compute_next_timestep(parking_tariff_t *tariff, int currentTimeMinutes, int UpDown);
CalcState CALCULATE_LIBRARY_API compute_price_for_parking_ticket( // deprecated CalcState CALCULATE_LIBRARY_API compute_price_for_parking_ticket( // deprecated
parking_tariff_t *tariff, parking_tariff_t *tariff,
time_t start_parking_time, time_t start_parking_time,

View File

@@ -1,7 +1,14 @@
#pragma once #ifndef CALCULATOR_FUNCTIONS_H_INCLUDED
#define CALCULATOR_FUNCTIONS_H_INCLUDED
#include <iostream> #include <iostream>
#include <optional>
#include "configuration.h" #include "configuration.h"
#include "payment_method.h" #include "payment_method.h"
#include "ticket.h"
#include "tariff_time_range.h"
#include <QDateTime> #include <QDateTime>
using namespace std; using namespace std;
@@ -48,20 +55,33 @@ private:
PaymentMethod getPaymentMethodId(Configuration const *cfg); PaymentMethod getPaymentMethodId(Configuration const *cfg);
int getMinimalParkingTime(Configuration const *cfg, PaymentMethod methodId); int getMinimalParkingTime(Configuration const *cfg, PaymentMethod methodId);
int getMaximalParkingTime(Configuration const *cfg, PaymentMethod methodId); int getMaximalParkingTime(Configuration const *cfg, PaymentMethod methodId);
uint32_t getMinimalParkingPrice(Configuration const *cfg, PaymentMethod methodId);
uint32_t private_GetCostFromDuration(Configuration const* cfg, Ticket private_GetCostFromDuration(Configuration const* cfg,
QDateTime const &start, QDateTime const &start,
QDateTime &end, int durationMinutes,
int durationMinutes, bool prepaid = false);
bool nextDay = false, Ticket private_GetDurationFromCost(Configuration *cfg,
bool prepaid = false, QDateTime const &start,
bool overtime = false); uint32_t price,
bool prepaid = false);
bool checkDurationMinutes(bool overTime, bool checkDurationMinutes(int minParkingTime, int maxParkingTime,
int minParkingTime, int maxParkingTime,
int durationMinutes); int durationMinutes);
// //
uint32_t GetPriceForTimeStep(Configuration *cfg, int timeStep) const; uint32_t GetPriceForTimeStep(Configuration *cfg, int timeStep) const;
uint32_t GetDurationForPrice(Configuration *cfg, int price) const; uint32_t GetDurationForPrice(Configuration *cfg, int price) const;
int findWorkTimeRange(QDateTime const &dt,
QScopedArrayPointer<TariffTimeRange> const &worktime,
size_t size);
int findNextWorkTimeRange(QDateTime const &dt,
QScopedArrayPointer<TariffTimeRange> const &worktime,
size_t size);
uint32_t computeWeekDaysPrice(Configuration const *cfg, PaymentMethod id) const;
double computeWeekDaysDurationUnit(Configuration const *cfg, PaymentMethod id) const;
}; };
#endif // CALCULATOR_FUNCTIONS_H_INCLUDED

View File

@@ -13,7 +13,8 @@
#define VALID (1) #define VALID (1)
#define INVALID_FROM_DATETIME (2) #define INVALID_FROM_DATETIME (2)
#define INVALID_UNTIL_DATETIME (3) #define INVALID_UNTIL_DATETIME (3)
#define STATUS_END (4) #define INVALID_PRICE (4)
#define STATUS_END (5)
class Ticket { class Ticket {
enum {CODE=0, CODE_STR=1, CODE_DESC=3}; enum {CODE=0, CODE_STR=1, CODE_DESC=3};
@@ -21,7 +22,10 @@ public:
using Status = std::tuple<int, char const*, char const*>; using Status = std::tuple<int, char const*, char const*>;
explicit Ticket(); explicit Ticket();
explicit Ticket(QDateTime const &s, QDateTime const &e,
int durationMinutesNetto, int durationMinutesBrutto,
uint32_t price, Status status);
explicit operator bool() { return std::get<CODE>(m_status) == VALID; } explicit operator bool() { return std::get<CODE>(m_status) == VALID; }
operator QString(); operator QString();
@@ -35,6 +39,16 @@ public:
void setValidUntil(QDateTime const &validUnil); void setValidUntil(QDateTime const &validUnil);
void setPrice(uint32_t price); void setPrice(uint32_t price);
bool isValid() { return operator bool(); }
static constexpr const Status s[STATUS_END] = {
{NOT_INITIALIZED , "NOT_INITIALIZED" , "Ticket not initialized" },
{VALID , "VALID" , "Ticket is valid" },
{INVALID_FROM_DATETIME , "INVALID_FROM_DATETIME" , "Ticket has invalid start datetime"},
{INVALID_UNTIL_DATETIME, "INVALID_UNTIL_DATETIME", "Ticket has invalid end datetime" },
{INVALID_PRICE , "INVALID_PRICE" , "PARKING NOT ALLOWED: Ticket has invalid price" }
};
private: private:
Status m_status; Status m_status;
@@ -45,20 +59,8 @@ private:
int m_durationMinutesBrutto; int m_durationMinutesBrutto;
uint32_t m_price; uint32_t m_price;
static constexpr const Status s[STATUS_END] = {
{NOT_INITIALIZED , "NOT_INITIALIZED" , "Ticket not initialized" },
{VALID , "VALID" , "Ticket is valid" },
{INVALID_FROM_DATETIME , "INVALID_FROM_DATETIME" , "Ticket has invalid start datetime"},
{INVALID_UNTIL_DATETIME, "INVALID_UNTIL_DATETIME", "Ticket has invalid end datetime" }
};
}; };
QDebug operator<<(QDebug debug, Ticket::Status const &status) { QDebug operator<<(QDebug debug, Ticket::Status const &status);
QDebugStateSaver saver(debug);
debug << "Ticket-Status: " << std::get<1>(status)
<< "(" << std::get<2>(status) << ")";
return debug;
}
#endif // TICKET_H_INCLUDED #endif // TICKET_H_INCLUDED

View File

@@ -1,78 +1,90 @@
#pragma once #pragma once
#include <cstring> #include <cstring>
#include <string.h> #include <string.h>
#include <ctime> #include <ctime>
#include <iostream> #include <iostream>
#include <cmath> #include <cmath>
#include "day_of_week.h" #include "day_of_week.h"
#include "configuration.h" #include "configuration.h"
#include "time_range.h" #include "time_range.h"
#include "payment_method.h"
#include <QDateTime>
#include <QDateTime>
using namespace std;
using namespace std;
namespace Utilities {
/// <summary> namespace Utilities {
/// Get day of week from current date (Zeller's Algorithm), starting day is Sunday /// <summary>
/// </summary> /// Get day of week from current date (Zeller's Algorithm), starting day is Sunday
/// <param name="date"></param> /// </summary>
/// <returns></returns> /// <param name="date"></param>
DayOfWeek GetDayOfWeek(struct tm* tm); /// <returns></returns>
DayOfWeek GetDayOfWeek(struct tm* tm);
/// <summary>
/// Date and time parse helper function /// <summary>
/// </summary> /// Date and time parse helper function
/// <returns>Returns time (tm) structure</returns> /// </summary>
struct tm DateTimeToStructTm(const char* dateTimeStr); /// <returns>Returns time (tm) structure</returns>
struct tm DateTimeToStructTm(const char* dateTimeStr);
/// <summary>
/// Date parse helper function /// <summary>
/// </summary> /// Date parse helper function
/// <returns>Returns time (tm) structure</returns> /// </summary>
struct tm DateToStructTm(const char* dateStr); /// <returns>Returns time (tm) structure</returns>
struct tm DateToStructTm(const char* dateStr);
/// <summary>
/// Time parse helper function /// <summary>
/// </summary> /// Time parse helper function
/// <returns>Returns time (tm) structure</returns> /// </summary>
struct tm TimeToStructTm(const char* timeStr, int year, int mon, int mday, int wday); /// <returns>Returns time (tm) structure</returns>
struct tm TimeToStructTm(const char* timeStr, int year, int mon, int mday, int wday);
/// <summary>
/// Get current local time /// <summary>
/// </summary> /// Get current local time
/// <returns>Returns time_t structure</returns> /// </summary>
time_t GetCurrentLocalTime(); /// <returns>Returns time_t structure</returns>
time_t GetCurrentLocalTime();
/// <summary>
/// Zeller's algorithm for determining day of week /// <summary>
/// </summary> /// Zeller's algorithm for determining day of week
int ZellersAlgorithm(int day, int month, int year); /// </summary>
int ZellersAlgorithm(int day, int month, int year);
/// <summary>
/// Checks if current datetime is in range between start and end month of parking worktime /// <summary>
/// </summary> /// Checks if current datetime is in range between start and end month of parking worktime
/// <param name="tariff_cfg"></param> /// </summary>
/// <param name="currentDateTime"></param> /// <param name="tariff_cfg"></param>
/// <returns></returns> /// <param name="currentDateTime"></param>
bool IsYearPeriodActive(Configuration* cfg, struct tm* currentDateTime); /// <returns></returns>
bool IsYearPeriodActive(Configuration* cfg, struct tm* currentDateTime);
/// <summary> bool IsYearPeriodActive(Configuration const *cfg, QDateTime const &currentDateTime);
/// Check permissions
/// </summary> /// <summary>
bool CheckSpecialDay(Configuration* cfg, const char* currentDateTimeStr, int* specialDayId, double* specialDayPrice); /// Check permissions
bool CheckSpecialDay(Configuration const *cfg, /// </summary>
QDateTime const &currentDateTimeS, bool CheckSpecialDay(Configuration* cfg, const char* currentDateTimeStr, int* specialDayId, double* specialDayPrice);
int* specialDayId, uint32_t *specialDayPrice); bool CheckSpecialDay(Configuration const *cfg,
QDateTime const &currentDateTimeS,
/// <summary> int* specialDayId, uint32_t *specialDayPrice);
/// Calculates price per unit
/// </summary> /// <summary>
/// <param name="pra_price"></param> /// Calculates price per unit
/// <returns></returns> /// </summary>
double CalculatePricePerUnit(double pra_price, double durationUnit = -1); /// <param name="pra_price"></param>
/// <returns></returns>
QTime SpecialDaysWorkTimeFrom(Configuration const *cfg, int specialDayId); double CalculatePricePerUnit(double pra_price, double durationUnit = -1);
QTime SpecialDaysWorkTimeUntil(Configuration const *cfg, int specialDayId);
} QTime SpecialDaysWorkTimeFrom(Configuration const *cfg, int specialDayId);
QTime SpecialDaysWorkTimeUntil(Configuration const *cfg, int specialDayId);
QTime WeekDaysWorkTimeFrom(std::multimap<int, ATBWeekDaysWorktime>::const_iterator itr);
QTime WeekDaysWorkTimeUntil(std::multimap<int, ATBWeekDaysWorktime>::const_iterator itr);
bool isCarryOverSet(Configuration const *cfg, PaymentMethod paymentMethodId);
bool isCarryOverNotSet(Configuration const *cfg, PaymentMethod paymentMethodId);
PaymentMethod getPaymentMethodId(Configuration const *cfg);
int getMinimalParkingTime(Configuration const *cfg, PaymentMethod methodId);
int getMaximalParkingTime(Configuration const *cfg, PaymentMethod methodId);
uint32_t getMinimalParkingPrice(Configuration const *cfg, PaymentMethod methodId);
uint32_t getFirstDurationStep(Configuration const *cfg, PaymentMethod methodId);
}

View File

@@ -2,7 +2,7 @@ TEMPLATE = lib
TARGET = mobilisis_calc TARGET = mobilisis_calc
#CONFIG += staticlib #CONFIG += staticlib
QMAKE_CXXFLAGS += -std=c++17 -g -O0 QMAKE_CXXFLAGS += -std=c++17 -g -O
INCLUDEPATH += $$_PRO_FILE_PWD_/include INCLUDEPATH += $$_PRO_FILE_PWD_/include
INCLUDEPATH += $$_PRO_FILE_PWD_/include/mobilisis INCLUDEPATH += $$_PRO_FILE_PWD_/include/mobilisis

View File

@@ -2,6 +2,7 @@
#include "configuration.h" #include "configuration.h"
#include "calculator_functions.h" #include "calculator_functions.h"
#include "payment_option.h" #include "payment_option.h"
#include "utilities.h"
#include <QFile> #include <QFile>
#include <QFileInfo> #include <QFileInfo>
@@ -92,6 +93,97 @@ void CALCULATE_LIBRARY_API free_tariff(parking_tariff_t *tariff) {
} }
} }
//
// UpDown 1 -> up; 0 -> down
int CALCULATE_LIBRARY_API compute_next_timestep(parking_tariff_t *tariff, int currentTimeMinutes, int UpDown)
{
qCritical() << " compute_next_timestep() currentTimeMinutes: " << currentTimeMinutes;
Configuration const *cfg = tariff;
// compute payment method id (e.g. Linear=3, Steps=4)
PaymentMethod const paymentMethodId = Utilities::getPaymentMethodId(cfg);
switch (paymentMethodId) {
case PaymentMethod::Progressive:
qCritical() << " compute_next_timestep() paymentMethodId: Progressive";
break;
case PaymentMethod::Degressive:
qCritical() << " compute_next_timestep() paymentMethodId: Degressive";
break;
case PaymentMethod::Linear:
qCritical() << " compute_next_timestep() paymentMethodId: Linear";
break;
case PaymentMethod::Steps:
qCritical() << " compute_next_timestep() paymentMethodId: Steps";
break;
case PaymentMethod::Undefined:
qCritical() << " compute_next_timestep() paymentMethodId: Undefined";
break;
}
// use tariff with structure as for instance Schnau, Koenigsee:
// without given YearPeriod, SpecialDays and SpecialDaysWorktime
if (paymentMethodId == PaymentMethod::Steps)
{
static const QList<int> stepList = calculator.GetTimeSteps(tariff);
int currentStepIndex = stepList.indexOf(currentTimeMinutes);
if (currentStepIndex == -1) {
qCritical() << "compute_next_timestep() *NO STEP* for currentTimeMinutes (" << currentTimeMinutes << ")";
return currentTimeMinutes;
}
if (UpDown == 1) { // UP
if (stepList[currentStepIndex] == stepList.last()) {
qCritical() << "compute_next_timestep() *NO NEXT STEP* for currentTimeMinutes (" << currentTimeMinutes << ")";
return currentTimeMinutes;
}
else {
return stepList[currentStepIndex + 1];
}
}
if (UpDown == 0) { // DOWN
if (stepList[currentStepIndex] == stepList.first()) {
qCritical() << "compute_next_timestep() *NO PREVIOUS STEP* for currentTimeMinutes (" << currentTimeMinutes << ")";
return currentTimeMinutes;
}
else {
return stepList[currentStepIndex - 1];
}
}
} else
if (paymentMethodId == PaymentMethod::Linear) {
// currentTimeMinutes is the number of minutes actually used. This
// value is an offset from the start time and cannot be used as a
// QDateTime.
qCritical() << "compute_next_timestep() up/down (1=up, 0=down):" << UpDown;
// get minimal and maximal parking times
int const minParkingTime = Utilities::getMinimalParkingTime(cfg, paymentMethodId);
int const maxParkingTime = Utilities::getMaximalParkingTime(cfg, paymentMethodId);
qCritical() << " compute_next_timestep() maxParkingTime:" << maxParkingTime;
qCritical() << " compute_next_timestep() minParkingTime:" << minParkingTime;
// use the first (i.e. main duration step contained in the tariff json-file)
int firstDurationStep = Utilities::getFirstDurationStep(cfg, paymentMethodId);
firstDurationStep = ((UpDown == 1) ? firstDurationStep : -firstDurationStep);
qCritical() << " compute_next_timestep() firstDurationStep:" << firstDurationStep;
int const nextTimeStep = currentTimeMinutes + firstDurationStep;
if (nextTimeStep >= minParkingTime && nextTimeStep <= maxParkingTime) {
qCritical() << " compute_next_timestep() nextTimeStep:" << nextTimeStep;
return nextTimeStep;
}
}
qCritical() << "compute_next_timestep() *CAN NOT COMPUTE* for currentTimeMinutes (" << currentTimeMinutes << ")";
return currentTimeMinutes;
}
// this is currently not used // this is currently not used
CalcState CALCULATE_LIBRARY_API compute_price_for_parking_ticket( CalcState CALCULATE_LIBRARY_API compute_price_for_parking_ticket(

View File

@@ -3,6 +3,7 @@
#include "utilities.h" #include "utilities.h"
#include "tariff_log.h" #include "tariff_log.h"
#include "tariff_time_range.h" #include "tariff_time_range.h"
#include "ticket.h"
#include <sstream> #include <sstream>
#include <algorithm> #include <algorithm>
@@ -121,6 +122,8 @@ std::string Calculator::GetDurationFromCost(Configuration* cfg,
bool nextDay, bool nextDay,
bool prepaid) bool prepaid)
{ {
Q_UNUSED(payment_option);
Q_UNUSED(nextDay);
// Get input date // Get input date
QDateTime inputDate = QDateTime::fromString(start_datetime,Qt::ISODate); QDateTime inputDate = QDateTime::fromString(start_datetime,Qt::ISODate);
@@ -132,224 +135,15 @@ std::string Calculator::GetDurationFromCost(Configuration* cfg,
&& cfg->SpecialDaysWorktime.size() == 0) && cfg->SpecialDaysWorktime.size() == 0)
{ {
inputDate = inputDate.addSecs(GetDurationForPrice(cfg, price) * 60); inputDate = inputDate.addSecs(GetDurationForPrice(cfg, price) * 60);
return inputDate.toString(Qt::ISODate).toStdString(); return inputDate.toString(Qt::ISODate).toStdString();
} }
Ticket t = private_GetDurationFromCost(cfg, inputDate, price, prepaid);
// Get day of week // qCritical().noquote() << t;
int weekdayId = 0;
weekdayId = Utilities::ZellersAlgorithm(inputDate.date().day(),inputDate.date().month(),inputDate.date().year());
//Get min and max time defined in JSON // TODO: im fehlerfall
double minMin = 0; return t.getValidUntil().toString(Qt::ISODate).toStdString();
minMin = cfg->getPaymentOptions().pop_min_time;
double maxMin = 0;
maxMin = cfg->getPaymentOptions().pop_max_time;
double min_price = 0;
min_price = cfg->getPaymentOptions().pop_min_price;
if(price < min_price)
{
return "PARKING NOT ALLOWED";
}
if (minMin < 0) minMin = 0;
if (maxMin < 0) maxMin = 0;
if (minMin >= maxMin)
{
LOG_ERROR("Error: min_min cannot be greater or equal to max_min");
return "PARKING NOT ALLOWED";
}
if (maxMin <= minMin)
{
LOG_ERROR("Error: max_min cannot be lower or equal than min_min");
return "PARKING NOT ALLOWED";
}
// Get payment method
uint8_t p_method = PaymentMethod::Undefined;
p_method = payment_option;
LOG_DEBUG("Payment method id: ", (unsigned)p_method);
// Check special day
double day_price = 0.0f;
int current_special_day_id = -1;
bool is_special_day = Utilities::CheckSpecialDay(cfg, inputDate.toString(Qt::ISODate).toStdString().c_str(), &current_special_day_id, &day_price);
LOG_DEBUG("Special day: ", is_special_day);
double money_left = price;
double price_per_unit = 0.0f;
QTime worktime_from;
QTime worktime_to;
if(is_special_day)
{
// Set special day price
price_per_unit = Utilities::CalculatePricePerUnit(day_price);
worktime_from = QTime::fromString(cfg->SpecialDaysWorktime.find(current_special_day_id)->second.pedwt_time_from.c_str());
worktime_to = QTime::fromString(cfg->SpecialDaysWorktime.find(current_special_day_id)->second.pedwt_time_to.c_str());
}
else
{
// Set new price for the normal day
int pop_id = cfg->PaymentOption.find(payment_option)->second.pop_id;
day_price = cfg->PaymentRate.find(pop_id)->second.pra_price;
int durationId = cfg->PaymentRate.find(pop_id)->second.pra_payment_unit_id;
double durationUnit = cfg->Duration.find(durationId)->second.pun_duration;
price_per_unit = Utilities::CalculatePricePerUnit(day_price,durationUnit);
// If no working day found, skip it (recursively call method again)
size_t found = 0;
found = cfg->WeekDaysWorktime.count(weekdayId);
// When no workday found, go to next available day
if(found <=0)
{
LOG_DEBUG("- No workday found, trying to find next available day");
inputDate = inputDate.addDays(1);
return GetDurationFromCost(cfg, payment_option, inputDate.toString(Qt::ISODate).toStdString().c_str(), money_left,true,prepaid);
}
worktime_from = QTime::fromString(cfg->WeekDaysWorktime.find(weekdayId)->second.pwd_time_from.c_str());
worktime_to = QTime::fromString(cfg->WeekDaysWorktime.find(weekdayId)->second.pwd_time_to.c_str());
}
if (price_per_unit < 0) price_per_unit = 1.0f;
// if((price/price_per_unit) < minMin) return "PARKING NOT ALLOWED";
LOG_DEBUG("Calculated price per minute: ", price_per_unit);
// If overtime flag is set
if (overtime || nextDay)
{
inputDate.setTime(worktime_from);
overtime = false;
}
// Check prepaid
if (!prepaid)
{
if ((inputDate.time() < worktime_from) || (inputDate.time() > worktime_to))
{
LOG_DEBUG("[STOP] * Ticket is not valid * ");
return "PARKING NOT ALLOWED";
}
}
else
{
LOG_DEBUG("* PREPAID MODE ACTIVE *");
if (inputDate.time() < worktime_from)
{
inputDate.setTime(worktime_from);
}
else if(inputDate.time() > worktime_to)
{
LOG_DEBUG(" *** PREPAID *** Current time is past the time range end, searching for next available day");
inputDate = inputDate.addDays(1);
return GetDurationFromCost(cfg, payment_option, inputDate.toString(Qt::ISODate).toStdString().c_str(), money_left, true);
}
}
while(true)
{
if((int)money_left <= 0) break;
// Check year period
bool isYearPeriodActive = false;
//// Parse input date
int dayCurrent = inputDate.date().day();
int monthCurrent = inputDate.date().month();
// Current date time
int cdt = (monthCurrent * 100) + dayCurrent;
multimap<int, ATBPeriodYear>::iterator year_period_itr;
for (year_period_itr = cfg->YearPeriod.begin(); year_period_itr != cfg->YearPeriod.end(); ++year_period_itr)
{
int dStart = year_period_itr->second.pye_start_day;
int dEnd = year_period_itr->second.pye_end_day;
int mStart = year_period_itr->second.pye_start_month;
int mEnd = year_period_itr->second.pye_end_month;
int start = (mStart * 100) + dStart;
int end = (mEnd * 100) + dEnd;
if (cdt >= start && cdt <= end) {
isYearPeriodActive = true;
break;
}
}
if (!isYearPeriodActive)
{
LOG_DEBUG("Year period is not valid");
return "PARKING NOT ALLOWED";
}
if(total_duration_min > maxMin)
{
total_duration_min = maxMin;
break;
}
// If reached end of worktime go to next day
if(inputDate.time() >= worktime_to)
{
int carry_over_status = 0;
carry_over_status = cfg->PaymentOption.find(payment_option)->second.pop_carry_over;
if (carry_over_status < 1) break;
inputDate = inputDate.addDays(1);
overtime = true;
return GetDurationFromCost(cfg, payment_option, inputDate.toString(Qt::ISODate).toStdString().c_str(), money_left ,true, prepaid);
}
if(money_left > 1)
inputDate = inputDate.addSecs(60);
if(price_per_unit > 0) total_duration_min +=1;
money_left -= price_per_unit;
//qDebug() <<"Timestamp:" << inputDate << ", total duration min: " << total_duration_min << ", money left = " << money_left;
}
// if ((total_duration_min < minMin) || (price / price_per_unit) < minMin)
// {
// LOG_DEBUG("Total duration is lower than min_min");
// inputDate.time() = worktime_from;
// total_duration_min = 0;
// }
double ret_val = 0;
// double calc_price = (int)total_duration_min - (int)price / price_per_unit;
//if (calc_price > 0 && total_duration_min > 0)
//{
// inputDate = inputDate.addSecs(-(int)ceil(calc_price) * 60);
//}
if(price >= min_price && total_duration_min >= minMin)
qDebug() << "GetDurationFromCost(): Valid until: " << inputDate.toString(Qt::ISODate);
else
{
qDebug() << "Parking not allowed";
total_duration_min = 0;
}
ret_val = total_duration_min;
if(ret_val < 0) ret_val = 0;
qDebug() << "Duration: " << ret_val;
if (ret_val <= 0) return "PARKING NOT ALLOWED";
total_duration_min = 0;
return inputDate.toString(Qt::ISODate).toStdString();
} }
/////////////////////////////////////// ///////////////////////////////////////
@@ -396,6 +190,9 @@ double Calculator::GetCostFromDuration(Configuration* cfg,
int durationMinutes, int durationMinutes,
bool nextDay, bool nextDay,
bool prepaid) { bool prepaid) {
Q_UNUSED(payment_option);
Q_UNUSED(nextDay);
if (cfg->YearPeriod.size() == 0 if (cfg->YearPeriod.size() == 0
&& cfg->SpecialDays.size() == 0 && cfg->SpecialDays.size() == 0
&& cfg->SpecialDaysWorktime.size() == 0) && cfg->SpecialDaysWorktime.size() == 0)
@@ -404,9 +201,18 @@ double Calculator::GetCostFromDuration(Configuration* cfg,
return GetCostFromDuration(cfg, start_datetime, end_datetime); return GetCostFromDuration(cfg, start_datetime, end_datetime);
} }
return private_GetCostFromDuration(cfg, start_datetime, QDateTime start = start_datetime;
end_datetime, durationMinutes,
nextDay, prepaid); Ticket t = private_GetCostFromDuration(cfg, start,
durationMinutes,
prepaid);
if (t) {
// qCritical().noquote() << t;
}
end_datetime = t.getValidUntil();
return t.getPrice();
} }
int Calculator::getMinimalParkingTime(Configuration const *cfg, PaymentMethod methodId) { int Calculator::getMinimalParkingTime(Configuration const *cfg, PaymentMethod methodId) {
@@ -417,203 +223,466 @@ int Calculator::getMaximalParkingTime(Configuration const *cfg, PaymentMethod me
return std::max((int)cfg->PaymentOption.find(methodId)->second.pop_max_time, 0); return std::max((int)cfg->PaymentOption.find(methodId)->second.pop_max_time, 0);
} }
bool Calculator::checkDurationMinutes(bool overtime, uint32_t Calculator::getMinimalParkingPrice(Configuration const *cfg, PaymentMethod methodId) {
int minParkingTime, return std::max((int)cfg->PaymentOption.find(methodId)->second.pop_min_price, 0);
}
bool Calculator::checkDurationMinutes(int minParkingTime,
int maxParkingTime, int maxParkingTime,
int durationMinutes) { int durationMinutes) {
if (!overtime) { if (durationMinutes > maxParkingTime) {
if (durationMinutes > maxParkingTime) { qWarning() << QString("Total duration >= max_min (%1 >= %2)").arg(durationMinutes).arg(maxParkingTime);
qWarning() << QString("Total duration >= max_min (%1 >= %2)").arg(durationMinutes).arg(maxParkingTime); return false;
return false; }
} if (durationMinutes < minParkingTime) {
if (durationMinutes < minParkingTime) { qWarning() << QString("Total duration <= minMin (%1 <= %2)").arg(durationMinutes).arg(minParkingTime);
qWarning() << QString("Total duration <= minMin (%1 <= %2)").arg(durationMinutes).arg(minParkingTime); return false;
return false; }
return true;
}
int Calculator::findWorkTimeRange(QDateTime const &dt,
QScopedArrayPointer<TariffTimeRange> const &worktime,
size_t size) {
for (size_t w = 0; w < size; ++w) {
QTime const &worktime_from = worktime[w].getTimeFrom();
QTime const &worktime_to = worktime[w].getTimeUntil();
if ((dt.time() >= worktime_from) && (dt.time() < worktime_to)) {
return w;
} }
} }
return true; return -1;
}
int Calculator::findNextWorkTimeRange(QDateTime const &dt,
QScopedArrayPointer<TariffTimeRange> const &worktime,
size_t size) {
int nextWorkTimeRange = -1;
for (size_t w = 0; w < size; ++w) {
QTime const &worktime_from = worktime[w].getTimeFrom();
if (dt.time() < worktime_from) {
nextWorkTimeRange = w;
break;
}
}
return nextWorkTimeRange;
}
uint32_t Calculator::computeWeekDaysPrice(Configuration const *cfg, PaymentMethod id) const {
int pop_id = cfg->PaymentOption.find(id)->second.pop_id;
return cfg->PaymentRate.find(pop_id)->second.pra_price;
}
double Calculator::computeWeekDaysDurationUnit(Configuration const *cfg, PaymentMethod id) const {
int pop_id = cfg->PaymentOption.find(id)->second.pop_id;
int durationId = cfg->PaymentRate.find(pop_id)->second.pra_payment_unit_id;
return (double)(cfg->Duration.find(durationId)->second.pun_duration);
} }
using namespace Utilities; using namespace Utilities;
uint32_t Calculator::private_GetCostFromDuration(Configuration const* cfg, Ticket Calculator::private_GetCostFromDuration(Configuration const* cfg,
QDateTime const &start, QDateTime const &start,
QDateTime &end, int durationMinutes, // Netto
int durationMinutes, bool prepaid) {
bool nextDay,
bool prepaid,
bool overtime) {
// TODO
static const PaymentMethod paymentMethodId = PaymentMethod::Linear;
static int const minParkingTimeMinutes = getMinimalParkingTime(cfg, paymentMethodId); static const PaymentMethod paymentMethodId = Utilities::getPaymentMethodId(cfg);
static int const maxParkingTimeMinutes = getMaximalParkingTime(cfg, paymentMethodId); static const bool carryOverNotSet = isCarryOverNotSet(cfg, paymentMethodId);
static const int minParkingTimeMinutes = getMinimalParkingTime(cfg, paymentMethodId);
static bool const checkMinMaxMinutes = (minParkingTimeMinutes < maxParkingTimeMinutes); static const int maxParkingTimeMinutes = getMaximalParkingTime(cfg, paymentMethodId);
static const bool checkMinMaxMinutes = (minParkingTimeMinutes < maxParkingTimeMinutes);
static const int durationMinutesNetto = durationMinutes;
static const uint32_t weekDaysPrice = computeWeekDaysPrice(cfg, paymentMethodId);
static const double weekDaysDurationUnit = computeWeekDaysDurationUnit(cfg, paymentMethodId);
static const double specialDaysDurationUnit = 60.0;
if (!checkMinMaxMinutes) { if (!checkMinMaxMinutes) {
qCritical() << QString( qCritical() << QString(
"ERROR: CONDITION minMin < maxMin (%1 < %2) IS NOT VALID") "ERROR: CONDITION minMin < maxMin (%1 < %2) IS NOT VALID")
.arg(minParkingTimeMinutes).arg(maxParkingTimeMinutes); .arg(minParkingTimeMinutes).arg(maxParkingTimeMinutes);
return 0; return Ticket();
} }
if (!checkDurationMinutes(overtime, minParkingTimeMinutes, if (!checkDurationMinutes(minParkingTimeMinutes,
maxParkingTimeMinutes, durationMinutes)) { maxParkingTimeMinutes, durationMinutes)) {
return 0; return Ticket();
} }
// Get input date uint32_t price = 0;
QDateTime inputDate = start; uint32_t costFromDuration = 0;
double durationUnit = 0.0;
int specialDayId = -1;
bool isSpecialDay = false;
Ticket ticket;
QDateTime end = start;
QDateTime current;
int totalTimeRanges = 0;
// Get day of week for (current = start; durationMinutes > 0; current = current.addDays(1)) {
int const weekdayId = inputDate.date().dayOfWeek(); int const weekdayId = current.date().dayOfWeek();
specialDayId = -1;
uint32_t day_price = 0; // find worktime ranges for the current day
uint32_t price_per_unit = 0; int const timeRanges = std::max((int)cfg->WeekDaysWorktime.count(weekdayId), 1);
QScopedArrayPointer<TariffTimeRange> worktime(new TariffTimeRange[timeRanges]);
int ranges = 0;
int current_special_day_id = -1; if((isSpecialDay = Utilities::CheckSpecialDay(cfg, current, &specialDayId, &price))) {
// Set special day price:
int const timeRanges = std::max((int)cfg->WeekDaysWorktime.count(weekdayId), 1); durationUnit = specialDaysDurationUnit;
QScopedArrayPointer<TariffTimeRange> worktime(new TariffTimeRange[timeRanges]); worktime[ranges].setTimeRange(SpecialDaysWorkTimeFrom(cfg, specialDayId),
int index = 0; SpecialDaysWorkTimeUntil(cfg, specialDayId));
ranges = 1;
if(Utilities::CheckSpecialDay(cfg, inputDate, &current_special_day_id, &day_price)) {
// Set special day price:
// ACHTUNG: price_per_unit ist eigentlich immer preis pro minute !!!
price_per_unit = CalculatePricePerUnit(day_price);
worktime[index].setTimeRange(SpecialDaysWorkTimeFrom(cfg, current_special_day_id),
SpecialDaysWorkTimeUntil(cfg, current_special_day_id));
} else {
// Set new price for the normal day
int pop_id = cfg->PaymentOption.find(paymentMethodId)->second.pop_id;
day_price = cfg->PaymentRate.find(pop_id)->second.pra_price;
int durationId = cfg->PaymentRate.find(pop_id)->second.pra_payment_unit_id;
double durationUnit = cfg->Duration.find(durationId)->second.pun_duration;
price_per_unit = Utilities::CalculatePricePerUnit(day_price,durationUnit);
// If no working day found, skip it (recursively call method again)
if (cfg->WeekDaysWorktime.count(weekdayId) <= 0) {
// When no workday found, go to next available day
qDebug() << "No workday found, trying to find next available day";
inputDate = inputDate.addDays(1);
return private_GetCostFromDuration(cfg, inputDate, end, durationMinutes, true, prepaid, overtime);
}
for (auto[itr, rangeEnd] = cfg->WeekDaysWorktime.equal_range(weekdayId); itr != rangeEnd; ++itr) {
qCritical() << itr->first << itr->second.pwd_time_from.c_str() << itr->second.pwd_time_to.c_str();
worktime[index].setTimeRange(QTime::fromString(itr->second.pwd_time_from.c_str()),
QTime::fromString(itr->second.pwd_time_to.c_str()));
index += 1;
}
}
if (price_per_unit < 0) price_per_unit = 1.0f;
qDebug() << "Calculated price per minute=" << price_per_unit;
double costFromDuration = 0.0;
for (int w = 0; w < index; ++w) {
QTime worktime_from = worktime[w].getTimeFrom();
QTime worktime_to = worktime[w].getTimeUntil();
if (price_per_unit == 0) {
inputDate = inputDate.addDays(1);
inputDate.setTime(worktime_from);
uint32_t const partialCost = private_GetCostFromDuration(cfg, inputDate, end, durationMinutes, true, prepaid);
if (partialCost == 0) {
return 0;
}
costFromDuration += partialCost;
continue;
}
// If overtime flag is set
if (overtime || nextDay) {
inputDate.setTime(worktime_from);
overtime = false;
}
// Check prepaid
if (!prepaid) {
if ((inputDate.time() < worktime_from) || (inputDate.time() > worktime_to)) {
qDebug() << "[STOP] * Ticket is not valid * ";
return 0.0f;
}
} else { } else {
qDebug() << "* PREPAID MODE ACTIVE *"; // Set new price for the normal day: do not use a floating-point type
if (inputDate.time() < worktime_from) { // for the price, rather compute with integers. Only at the very end of
inputDate.setTime(worktime_from); // the computation the price is divided by durationUnit.
} else if(inputDate.time() > worktime_to) { price = weekDaysPrice;
qDebug() << " *** PREPAID *** Current time is past the time range end, searching for next available day"; durationUnit = weekDaysDurationUnit;
inputDate = inputDate.addDays(1);
uint32_t const partialCost = private_GetCostFromDuration(cfg, inputDate, end, durationMinutes, true, prepaid); // If no working day found, skip it (epsecially Sundays!)
if (partialCost == 0) { if (cfg->WeekDaysWorktime.count(weekdayId) <= 0) {
return 0; qDebug() << "No workday found, trying to find next available day";
} end = current;
costFromDuration += partialCost; current.setTime(QTime()); // start at midnight on the next day
continue; continue;
} }
using WTIterator = std::multimap<int, ATBWeekDaysWorktime>::const_iterator;
std::pair<WTIterator, WTIterator> p = cfg->WeekDaysWorktime.equal_range(weekdayId);
for (WTIterator itr = p.first; itr != p.second; ++itr) {
worktime[ranges].setTimeRange(WeekDaysWorkTimeFrom(itr),
WeekDaysWorkTimeUntil(itr));
ranges += 1;
}
} }
while(durationMinutes > 0) { QTime const &lastWorktimeTo = worktime[ranges-1].getTimeUntil();
// Check for active year period
if (std::none_of(cfg->YearPeriod.begin(),
cfg->YearPeriod.end(),
[&inputDate](std::pair<int, ATBPeriodYear> const &year) {
QDate const input(2004, // 2004 is a leap year
inputDate.date().month(),
inputDate.date().day());
QDate const s(2004, year.second.pye_start_day, year.second.pye_start_month);
QDate const e(2004, year.second.pye_end_day, year.second.pye_end_month);
return (input >= s && input <= e);
})) {
qCritical() << "NO VALID YEAR PERIOD";
return 0.0;
}
// Go to next day if minutes not spent // qCritical() << "start" << start.toString(Qt::ISODate)
if(inputDate.time() >= worktime_to) { // << "current" << current.toString(Qt::ISODate) << lastWorktimeTo;
// check for carry_over status
if (cfg->PaymentOption.find(paymentMethodId)->second.pop_carry_over < 1) {
break;
}
qDebug() << "Reached end of worktime, searching for the next working day"; // find worktime range to start with
int currentRange = 0;
inputDate = inputDate.addDays(1); if (!isSpecialDay) {
overtime = true; if (start != current) { // on next day
uint32_t const partialCost = private_GetCostFromDuration(cfg, inputDate, end, durationMinutes, true, prepaid, overtime); current.setTime(worktime[currentRange].getTimeFrom());
if (partialCost == 0) {
return 0;
}
costFromDuration += partialCost;
break; // stop while, and continue in outer loop
} else { } else {
// Increment input date minutes for each monetary unit // check if inputDate is located inside a valid worktime-range...
inputDate = inputDate.addSecs(60); if ((currentRange = findWorkTimeRange(current, worktime, ranges)) == -1) {
durationMinutes -= 1; if (!prepaid && carryOverNotSet) { // parking is not allowed
costFromDuration += price_per_unit; return Ticket(start, QDateTime(), durationMinutesNetto, 0,
0, Ticket::s[INVALID_FROM_DATETIME]);
}
// find the next worktime-range (on the same day), and start from there
if ((currentRange = findNextWorkTimeRange(current, worktime, ranges)) == -1) {
end = current;
continue;
}
current.setTime(worktime[currentRange].getTimeFrom());
}
} }
} }
}
qDebug() << "GetCostFromDuration(): Valid until:" << inputDate.toString(Qt::ISODate); // qCritical() << "current" << current.toString(Qt::ISODate);
end = inputDate; for (int w = currentRange; w < ranges; ++w, ++totalTimeRanges) {
if (durationMinutes > 0) {
QTime const &worktime_from = worktime[w].getTimeFrom();
QTime const &worktime_to = worktime[w].getTimeUntil();
//double ret_val = total_cost; if (totalTimeRanges) {
//total_cost = 0.0f; // durationMinutes are always meant as netto time and
//return ceil(ret_val); // the time between worktime-ranges are free.
current.setTime(worktime_from);
}
// TODO: runden nur falls oberster stack-rahmen if (price == 0) {
end = current;
current.setTime(QTime());
continue;
}
return ceil(costFromDuration); if (current.time() == worktime_to) {
end = current;
current.setTime(QTime());
continue;
}
// Check prepaid
if (!prepaid) {
if ((current.time() < worktime_from) || (current.time() > worktime_to)) {
qDebug() << "[STOP] * Ticket is not valid * ";
return Ticket();
}
} else {
//qDebug() << "* PREPAID MODE ACTIVE *";
//qCritical() << "current" << current.toString(Qt::ISODate) << worktime_from << lastWorktimeTo;
if (current.time() < worktime_from) {
current.setTime(worktime_from);
end = current;
} else if(current.time() > lastWorktimeTo) {
//qDebug() << " *** PREPAID *** Current time is past the time range end, searching for next available day";
end = current;
current.setTime(QTime());
continue;
}
}
while(durationMinutes > 0) {
// Check for active year period
if (!IsYearPeriodActive(cfg, current)) {
return Ticket();
}
if(current.time() >= lastWorktimeTo) {
// Go to next day if minutes not spent
if (carryOverNotSet) {
// no carry_over, so stop computation
break;
}
current.setTime(QTime());
break; // stop while, and continue in outer loop
} else {
//qCritical() << "current" << current.toString(Qt::ISODate) << worktime_to;
if(current.time() < worktime_to) {
// Increment input date minutes for each monetary unit
current = current.addSecs(60);
end = current;
durationMinutes -= 1;
//costFromDuration += price_per_unit;
costFromDuration += price;
//qCritical() << "current" << current.toString(Qt::ISODate);
} else break;
}
} // while(durationMinutes > 0) {
} // if (durationMinutes > 0) {
} // for (int w = currentRange; w < ranges; ++w, ++totalTimeRanges) {
} // for (current = start; durationMinutes > 0; current = current.addDays(1)) {
int durationMinutesBrutto = start.secsTo(end) / 60;
return
Ticket(start, end, durationMinutesNetto, durationMinutesBrutto,
ceil(Utilities::CalculatePricePerUnit(costFromDuration, durationUnit)),
Ticket::s[VALID]);
} }
Ticket Calculator::private_GetDurationFromCost(Configuration *cfg,
QDateTime const &start,
uint32_t cost,
bool prepaid) {
// Get input date
QDateTime current = start;
// use tariff with structure as for instance Schnau, Koenigsee:
// without given YearPeriod, SpecialDays and SpecialDaysWorktime
if (cfg->YearPeriod.size() == 0
&& cfg->SpecialDays.size() == 0
&& cfg->SpecialDaysWorktime.size() == 0)
{
uint64_t const durationMinutes = GetDurationForPrice(cfg, cost);
uint64_t const durationSeconds = durationMinutes * 60;
current = current.addSecs(durationSeconds);
return
Ticket(start, current, durationMinutes, durationMinutes,
cost, Ticket::s[VALID]);
}
static const PaymentMethod paymentMethodId = Utilities::getPaymentMethodId(cfg);
static const bool carryOverNotSet = isCarryOverNotSet(cfg, paymentMethodId);
static const uint32_t minParkingTimeMinutes = std::max(getMinimalParkingTime(cfg, paymentMethodId), 0);
static const uint32_t maxParkingTimeMinutes = std::max(getMaximalParkingTime(cfg, paymentMethodId), 0);
static const uint32_t minParkingPrice = getMinimalParkingPrice(cfg, paymentMethodId);
// static const bool checkMinMaxMinutes = (minParkingTimeMinutes < maxParkingTimeMinutes);
static const uint32_t weekDaysPrice = computeWeekDaysPrice(cfg, paymentMethodId);
static const uint32_t weekDaysDurationUnit = computeWeekDaysDurationUnit(cfg, paymentMethodId);
static const uint32_t specialDaysDurationUnit = 60;
if(cost < minParkingPrice) {
uint64_t const durationMinutes = GetDurationForPrice(cfg, cost);
return Ticket(start, current, durationMinutes, durationMinutes,
cost, Ticket::s[INVALID_PRICE]);
}
if (minParkingTimeMinutes >= maxParkingTimeMinutes) {
// TODO
return Ticket();
}
if (maxParkingTimeMinutes <= minParkingTimeMinutes) {
// TODO
return Ticket();
}
uint32_t durationMinutesNetto = 0;
double moneyLeft = cost;
double durationUnit = 1;
int specialDayId = -1;
bool isSpecialDay = false;
QDateTime end = start;
int totalTimeRanges = 0;
double price = 0;
for (current = start; moneyLeft > 0 && moneyLeft >= price; current = current.addDays(1)) {
int const weekdayId = current.date().dayOfWeek();
specialDayId = -1;
// find worktime ranges for the current day
int const timeRanges = std::max((int)cfg->WeekDaysWorktime.count(weekdayId), 1);
QScopedArrayPointer<TariffTimeRange> worktime(new TariffTimeRange[timeRanges]);
int ranges = 0;
uint32_t p = 0;
if((isSpecialDay = Utilities::CheckSpecialDay(cfg, current, &specialDayId, &p))) {
// Set special day price:
durationUnit = specialDaysDurationUnit;
price = p / durationUnit;
price = std::round(price * 1000.0) / 1000.0;
worktime[ranges].setTimeRange(SpecialDaysWorkTimeFrom(cfg, specialDayId),
SpecialDaysWorkTimeUntil(cfg, specialDayId));
ranges = 1;
} else {
// Set new price for the normal day: do not use a floating-point type
// for the price, rather compute with integers. Only at the very end of
// the computation the price is divided by durationUnit.
price = weekDaysPrice;
durationUnit = weekDaysDurationUnit;
price /= durationUnit;
price = std::round(price * 1000.0) / 1000.0; // round to 3 decimals
// If no working day found, skip it (epsecially Sundays!)
if (cfg->WeekDaysWorktime.count(weekdayId) <= 0) {
// qDebug() << "No workday found, trying to find next available day";
end = current;
current.setTime(QTime()); // start at midnight on the next day
continue;
}
using WTIterator = std::multimap<int, ATBWeekDaysWorktime>::const_iterator;
std::pair<WTIterator, WTIterator> p = cfg->WeekDaysWorktime.equal_range(weekdayId);
for (WTIterator itr = p.first; itr != p.second; ++itr) {
worktime[ranges].setTimeRange(WeekDaysWorkTimeFrom(itr),
WeekDaysWorkTimeUntil(itr));
ranges += 1;
}
}
QTime const &lastWorktimeTo = worktime[ranges-1].getTimeUntil();
// find worktime range to start with
int currentRange = 0;
if (!isSpecialDay) {
if (start != current) { // on next day
current.setTime(worktime[currentRange].getTimeFrom());
} else {
// check if inputDate is located inside a valid worktime-range...
if ((currentRange = findWorkTimeRange(current, worktime, ranges)) == -1) {
if (!prepaid && carryOverNotSet) { // parking is not allowed
return Ticket(start, QDateTime(), durationMinutesNetto, 0,
0, Ticket::s[INVALID_FROM_DATETIME]);
}
// find the next worktime-range (on the same day), and start from there
if ((currentRange = findNextWorkTimeRange(current, worktime, ranges)) == -1) {
end = current;
continue;
}
current.setTime(worktime[currentRange].getTimeFrom());
}
}
}
for (int w = currentRange; w < ranges; ++w, ++totalTimeRanges) {
if (moneyLeft > 0) {
QTime const &worktime_from = worktime[w].getTimeFrom();
QTime const &worktime_to = worktime[w].getTimeUntil();
if (totalTimeRanges) {
// durationMinutes are always meant as netto time and
// the time between worktime-ranges are free.
current.setTime(worktime_from);
}
if (price == 0) {
// inputDate = inputDate.addDays(1);
// inputDate.setTime(worktime_from);
end = current;
current.setTime(QTime());
continue;
}
if (current.time() == worktime_to) {
end = current;
current.setTime(QTime());
continue;
}
// Check prepaid
if (!prepaid) {
if ((current.time() < worktime_from) || (current.time() > worktime_to)) {
qDebug() << "[STOP] * Ticket is not valid * ";
return Ticket();
}
} else {
qDebug() << "* PREPAID MODE ACTIVE *";
if (current.time() < worktime_from) {
current.setTime(worktime_from);
end = current;
} else if(current.time() > lastWorktimeTo) {
qDebug() << " *** PREPAID *** Current time is past the time range end, searching for next available day";
end = current;
current.setTime(QTime());
continue;
}
}
while(moneyLeft >= price) {
// Check for active year period
if (!IsYearPeriodActive(cfg, current)) {
return Ticket();
}
if(durationMinutesNetto > maxParkingTimeMinutes) {
durationMinutesNetto = maxParkingTimeMinutes;
break;
}
if(current.time() >= lastWorktimeTo) {
// Go to next day if minutes not spent
if (carryOverNotSet) {
// no carry_over, so stop computation
break;
}
current.setTime(QTime());
break; // stop while, and continue in outer loop
} else {
if(current.time() < worktime_to) {
// Increment input date minutes for each monetary unit
durationMinutesNetto +=1;
moneyLeft -= price;
moneyLeft = std::round(moneyLeft * 1000.0) / 1000.0;
current = current.addSecs(60);
end = current;
} else break;
}
} // while(durationMinutes > 0) {
} // if (durationMinutes > 0) {
} // for (int w = currentRange; w < ranges; ++w, ++totalTimeRanges) {
} // for (current = start; durationMinutes > 0; current = current.addDays(1)) {
int durationMinutesBrutto = start.secsTo(end) / 60;
//qCritical() << "start" << start.toString(Qt::ISODate) << "end"
// << end.toString(Qt::ISODate) << durationMinutesBrutto;
return
Ticket(start, end, durationMinutesNetto, durationMinutesBrutto,
cost, Ticket::s[VALID]);
}
QList<int> Calculator::GetTimeSteps(Configuration *cfg) const { QList<int> Calculator::GetTimeSteps(Configuration *cfg) const {
QList<int> timeSteps; QList<int> timeSteps;

View File

@@ -7,11 +7,20 @@ Ticket::Ticket()
, m_durationMinutesNetto(0) , m_durationMinutesNetto(0)
, m_durationMinutesBrutto(0) , m_durationMinutesBrutto(0)
, m_price() { , m_price() {
qDebug() << *this;
qDebug() << m_status;
} }
Ticket::Ticket(QDateTime const &s, QDateTime const &e,
int durationMinutesNetto, int durationMinutesBrutto,
uint32_t price, Ticket::Status status)
: m_status(status)
, m_validFrom(s)
, m_validUntil(e)
, m_durationMinutesNetto(durationMinutesNetto)
, m_durationMinutesBrutto(durationMinutesBrutto)
, m_price(price) {
}
Ticket::Status Ticket::setStatus(Status status) { Ticket::Status Ticket::setStatus(Status status) {
Status old = m_status; Status old = m_status;
m_status = status; m_status = status;
@@ -39,7 +48,7 @@ QDateTime Ticket::getValidFrom() const {
QDateTime Ticket::getValidUntil() const { QDateTime Ticket::getValidUntil() const {
if (std::get<CODE>(m_status) == VALID) { if (std::get<CODE>(m_status) == VALID) {
return m_validFrom; return m_validUntil;
} }
return QDateTime(); return QDateTime();
} }
@@ -54,14 +63,23 @@ void Ticket::setPrice(uint32_t price) {
Ticket::operator QString() { Ticket::operator QString() {
QStringList status; QStringList status;
status << QString("Status .............. : %1 (%2)") status << QString("**********************");
status << QString("Status ............. : %1 (%2)")
.arg(std::get<0>(m_status)) .arg(std::get<0>(m_status))
.arg(std::get<2>(m_status)); .arg(std::get<2>(m_status));
status << QString("Valid from ......... : %1").arg(m_validFrom.toString(Qt::ISODate)); status << QString("Valid from ......... : %1").arg(m_validFrom.toString(Qt::ISODate));
status << QString("Valid until ........ : %1").arg(m_validUntil.toString(Qt::ISODate)); status << QString("Valid until ........ : %1").arg(m_validUntil.toString(Qt::ISODate));
status << QString("Duration (netto) ... : %1").arg(m_durationMinutesNetto); status << QString("Duration (netto) ... : %1").arg(m_durationMinutesNetto);
status << QString("Duration (brutto)... : %1").arg(m_durationMinutesBrutto); status << QString("Duration (brutto)... : %1").arg(m_durationMinutesBrutto);
status << QString("Price ......... : %1").arg(m_price); status << QString("Price .............. : %1").arg(m_price);
status << QString("**********************");
return status.join('\n');; return status.join('\n');
}
QDebug operator<<(QDebug debug, Ticket::Status const &status) {
QDebugStateSaver saver(debug);
debug << "Ticket-Status: " << std::get<1>(status)
<< "(" << std::get<2>(status) << ")";
return debug;
} }

View File

@@ -1,319 +1,401 @@
#include "utilities.h" #include "utilities.h"
#include "tariff_log.h" #include "tariff_log.h"
#include <QDebug> #include <QDebug>
#include <algorithm>
static int protection_counter = 0;
static int protection_counter = 0;
/// <summary>
/// Helper function /// <summary>
/// </summary> /// Helper function
/// <param name="pra_price"></param> /// </summary>
/// <returns></returns> /// <param name="pra_price"></param>
double Utilities::CalculatePricePerUnit(double pra_price, double durationUnit) /// <returns></returns>
{ double Utilities::CalculatePricePerUnit(double pra_price, double durationUnit)
try {
{ try
double price_per_unit = pra_price; {
double unit = durationUnit; double price_per_unit = pra_price;
double unit = durationUnit;
if(unit < 0 || unit > 65535 ) unit = 60.0f;
price_per_unit /= unit; // Divided by 60 because price per unit is set per hour and we are using minutes if(unit < 0 || unit > 65535 ) unit = 60.0f;
//printf("Price per unit (min) is: %lf\n", price_per_unit); price_per_unit /= unit; // Divided by 60 because price per unit is set per hour and we are using minutes
return price_per_unit; //printf("Price per unit (min) is: %lf\n", price_per_unit);
} return price_per_unit;
catch (...) }
{ catch (...)
throw std::invalid_argument("An error has occurred in CalculatePricePerUnit() function\n"); {
} throw std::invalid_argument("An error has occurred in CalculatePricePerUnit() function\n");
} }
}
/// <inheritdoc/>
time_t Utilities::GetCurrentLocalTime() /// <inheritdoc/>
{ time_t Utilities::GetCurrentLocalTime()
try {
{ try
time_t curr_time = time(NULL); {
tm tm_curr_time = {}; time_t curr_time = time(NULL);
memset(&tm_curr_time, '\0', sizeof(struct tm)); tm tm_curr_time = {};
memset(&tm_curr_time, '\0', sizeof(struct tm));
tm_curr_time = *localtime(&curr_time);
curr_time = mktime(&tm_curr_time); //- timezone; tm_curr_time = *localtime(&curr_time);
return curr_time; curr_time = mktime(&tm_curr_time); //- timezone;
} return curr_time;
catch (...) }
{ catch (...)
throw std::invalid_argument("An error has occurred in GetCurrentLocalTime() function\n"); {
} throw std::invalid_argument("An error has occurred in GetCurrentLocalTime() function\n");
} }
}
/// <inheritdoc/>
int Utilities::ZellersAlgorithm(int day, int month, int year) /// <inheritdoc/>
{ int Utilities::ZellersAlgorithm(int day, int month, int year)
int mon; {
if (month > 2) mon = month; //for march to december month code is same as month int mon;
else { if (month > 2) mon = month; //for march to december month code is same as month
mon = (12 + month); //for Jan and Feb, month code will be 13 and 14 else {
year--; //decrease year for month Jan and Feb mon = (12 + month); //for Jan and Feb, month code will be 13 and 14
} year--; //decrease year for month Jan and Feb
int y = year % 100; //last two digit }
int c = year / 100; //first two digit int y = year % 100; //last two digit
int w = (day + floor((13 * (mon + 1)) / 5) + y + floor(y / 4) + floor(c / 4) + (5 * c)); int c = year / 100; //first two digit
w = ((w + 5) % 7) + 1; //w % 7; int w = (day + floor((13 * (mon + 1)) / 5) + y + floor(y / 4) + floor(c / 4) + (5 * c));
return w; w = ((w + 5) % 7) + 1; //w % 7;
} return w;
}
/// <inheritdoc/>
struct tm Utilities::DateToStructTm(const char* dateStr) /// <inheritdoc/>
{ struct tm Utilities::DateToStructTm(const char* dateStr)
struct tm t = {}; {
memset(&t, '\0', sizeof(struct tm)); struct tm t = {};
memset(&t, '\0', sizeof(struct tm));
if (dateStr == nullptr || strlen(dateStr) <= 0) throw std::invalid_argument("DateToStructTm has failed parsing date string (null or empty)\n");
try if (dateStr == nullptr || strlen(dateStr) <= 0) throw std::invalid_argument("DateToStructTm has failed parsing date string (null or empty)\n");
{ try
int success = sscanf(dateStr, "%d-%d-%d", &t.tm_year, &t.tm_mon, &t.tm_mday); {
if (success != 3) throw std::invalid_argument("DateToStructTm() has failed parsing datetime string\n"); int success = sscanf(dateStr, "%d-%d-%d", &t.tm_year, &t.tm_mon, &t.tm_mday);
if (success != 3) throw std::invalid_argument("DateToStructTm() has failed parsing datetime string\n");
t.tm_year = t.tm_year - 1900;
t.tm_mon = t.tm_mon - 1; t.tm_year = t.tm_year - 1900;
t.tm_isdst = 0; t.tm_mon = t.tm_mon - 1;
return t; t.tm_isdst = 0;
} return t;
catch (...) }
{ catch (...)
throw std::invalid_argument("An error has occurred in DateToStructTm() function\n"); {
} throw std::invalid_argument("An error has occurred in DateToStructTm() function\n");
} }
}
/// <inheritdoc/>
struct tm Utilities::TimeToStructTm(const char* timeStr, int year, int mon, int mday, int wday) /// <inheritdoc/>
{ struct tm Utilities::TimeToStructTm(const char* timeStr, int year, int mon, int mday, int wday)
struct tm t = {}; {
memset(&t, '\0', sizeof(struct tm)); struct tm t = {};
memset(&t, '\0', sizeof(struct tm));
if (timeStr == nullptr || strlen(timeStr) <= 0) throw std::invalid_argument("TimeToStructTm() has failed parsing time string (null or empty)\n");
try if (timeStr == nullptr || strlen(timeStr) <= 0) throw std::invalid_argument("TimeToStructTm() has failed parsing time string (null or empty)\n");
{ try
int success_time = sscanf(timeStr, "%d:%d:%d", &t.tm_hour, &t.tm_min, &t.tm_sec); {
if (success_time != 3) throw std::invalid_argument("TimeToStructTm() has failed parsing time string\n"); int success_time = sscanf(timeStr, "%d:%d:%d", &t.tm_hour, &t.tm_min, &t.tm_sec);
if (success_time != 3) throw std::invalid_argument("TimeToStructTm() has failed parsing time string\n");
struct tm tm_struct;
t.tm_year = year; struct tm tm_struct;
t.tm_mon = mon; t.tm_year = year;
t.tm_mday = mday; t.tm_mon = mon;
t.tm_wday = wday; t.tm_mday = mday;
t.tm_isdst = 0; t.tm_wday = wday;
return t; t.tm_isdst = 0;
} return t;
catch (...) }
{ catch (...)
throw std::invalid_argument("An error has occurred in TimeToStructTm() function\n"); {
} throw std::invalid_argument("An error has occurred in TimeToStructTm() function\n");
} }
}
/// <inheritdoc/>
struct tm Utilities::DateTimeToStructTm(const char* dateTimeStr) /// <inheritdoc/>
{ struct tm Utilities::DateTimeToStructTm(const char* dateTimeStr)
struct tm t = {}; {
memset(&t, '\0', sizeof(struct tm)); struct tm t = {};
memset(&t, '\0', sizeof(struct tm));
if (dateTimeStr == nullptr || strlen(dateTimeStr) <= 0) throw std::invalid_argument("DateTimeToStructTm() has failed parsing date string (null or empty)");
try if (dateTimeStr == nullptr || strlen(dateTimeStr) <= 0) throw std::invalid_argument("DateTimeToStructTm() has failed parsing date string (null or empty)");
{ try
int success = sscanf(dateTimeStr, "%d-%d-%dT%d:%d:%dZ", &t.tm_year, &t.tm_mon, &t.tm_mday, &t.tm_hour, &t.tm_min, &t.tm_sec); {
if (success != 6) throw std::invalid_argument("DateTimeToStructTm() has failed parsing datetime string\n"); int success = sscanf(dateTimeStr, "%d-%d-%dT%d:%d:%dZ", &t.tm_year, &t.tm_mon, &t.tm_mday, &t.tm_hour, &t.tm_min, &t.tm_sec);
if (success != 6) throw std::invalid_argument("DateTimeToStructTm() has failed parsing datetime string\n");
t.tm_year = t.tm_year - 1900;
t.tm_mon = t.tm_mon - 1; t.tm_year = t.tm_year - 1900;
t.tm_isdst = 0; t.tm_mon = t.tm_mon - 1;
return t; t.tm_isdst = 0;
} return t;
catch (...) }
{ catch (...)
throw std::invalid_argument("An error has occurred in DateTimeToStructTm() function\n"); {
} throw std::invalid_argument("An error has occurred in DateTimeToStructTm() function\n");
} }
}
/// <inheritdoc/>
DayOfWeek Utilities::GetDayOfWeek(struct tm* t) /// <inheritdoc/>
{ DayOfWeek Utilities::GetDayOfWeek(struct tm* t)
if (t == nullptr) throw std::invalid_argument("GetDayOfWeekFromDate() => parameter 't' is null\n"); {
try if (t == nullptr) throw std::invalid_argument("GetDayOfWeekFromDate() => parameter 't' is null\n");
{ try
int d = t->tm_mday; {
int m = t->tm_mon + 1; int d = t->tm_mday;
int y = t->tm_year + 1900; int m = t->tm_mon + 1;
int y = t->tm_year + 1900;
int wd = Utilities::ZellersAlgorithm(d, m, y);
return static_cast<DayOfWeek>(wd); int wd = Utilities::ZellersAlgorithm(d, m, y);
} return static_cast<DayOfWeek>(wd);
catch (...) }
{ catch (...)
throw std::invalid_argument("An error has occurred in GetDayOfWeekFromDate() function\n"); {
} throw std::invalid_argument("An error has occurred in GetDayOfWeekFromDate() function\n");
} }
}
/// <inheritdoc/>
bool Utilities::IsYearPeriodActive(Configuration* cfg, struct tm* currentDateTime_tm) /// <inheritdoc/>
{ bool Utilities::IsYearPeriodActive(Configuration* cfg, struct tm* currentDateTime_tm)
if (cfg == nullptr) throw std::invalid_argument("IsYearPeriodActive() = > Configuration not set\n"); {
if (currentDateTime_tm == nullptr) throw std::invalid_argument("IsYearPeriodActive() = > Current datetime not set\n"); if (cfg == nullptr) throw std::invalid_argument("IsYearPeriodActive() = > Configuration not set\n");
if (currentDateTime_tm == nullptr) throw std::invalid_argument("IsYearPeriodActive() = > Current datetime not set\n");
try
{ try
//// Parse input date {
int dayCurrent = currentDateTime_tm->tm_mday; //// Parse input date
int monthCurrent = currentDateTime_tm->tm_mon + 1; int dayCurrent = currentDateTime_tm->tm_mday;
int monthCurrent = currentDateTime_tm->tm_mon + 1;
// Current date time
int cdt = (monthCurrent * 100) + dayCurrent; // Current date time
int cdt = (monthCurrent * 100) + dayCurrent;
multimap<int, ATBPeriodYear>::iterator year_period_itr;
for (year_period_itr = cfg->YearPeriod.begin(); year_period_itr != cfg->YearPeriod.end(); ++year_period_itr) multimap<int, ATBPeriodYear>::iterator year_period_itr;
{ for (year_period_itr = cfg->YearPeriod.begin(); year_period_itr != cfg->YearPeriod.end(); ++year_period_itr)
int dStart = year_period_itr->second.pye_start_day; {
int dEnd = year_period_itr->second.pye_end_day; int dStart = year_period_itr->second.pye_start_day;
int dEnd = year_period_itr->second.pye_end_day;
int mStart = year_period_itr->second.pye_start_month;
int mEnd = year_period_itr->second.pye_end_month; int mStart = year_period_itr->second.pye_start_month;
int mEnd = year_period_itr->second.pye_end_month;
int start = (mStart * 100) + dStart;
int end = (mEnd * 100) + dEnd; int start = (mStart * 100) + dStart;
int end = (mEnd * 100) + dEnd;
if (cdt >= start && cdt <= end)
{ if (cdt >= start && cdt <= end)
return true; {
} return true;
} }
return false; }
} return false;
catch (...) }
{ catch (...)
cout << "IsYearPeriodActive() => An exception has occurred, ignoring check, returning true" << endl; {
return true; cout << "IsYearPeriodActive() => An exception has occurred, ignoring check, returning true" << endl;
} return true;
} }
}
/// <inheritdoc/>
bool Utilities::CheckSpecialDay(Configuration* cfg, const char* currentDateTimeStr, int* specialDayId, double* specialDayPrice) bool Utilities::IsYearPeriodActive(Configuration const *cfg, QDateTime const &dt) {
{ if (std::none_of(cfg->YearPeriod.cbegin(),
try cfg->YearPeriod.cend(),
{ [&dt](std::pair<int, ATBPeriodYear> const &year) {
*specialDayId = -1; QDate const d(2004, // 2004 is a leap year
*specialDayPrice = 0.0f; dt.date().month(),
dt.date().day());
if (cfg == nullptr) throw std::invalid_argument("CheckSpecialDay() => configuration is not set\n"); QDate const s(2004, year.second.pye_start_month, year.second.pye_start_day);
if (currentDateTimeStr == nullptr) throw std::invalid_argument("CheckSpecialDay() => invalid date/time string set\n"); QDate const e(2004, year.second.pye_end_month, year.second.pye_end_day);
return (d >= s && d <= e);
})) {
struct tm current_tm = Utilities::DateTimeToStructTm(currentDateTimeStr); qCritical() << "NO VALID YEAR PERIOD";
//cout << "CheckSpecialDay() => Current: " << asctime(&current_tm) << endl; return false;
}
multimap<int, ATBSpecialDays>::iterator spec_days_itr; return true;
}
for (spec_days_itr = cfg->SpecialDays.begin(); spec_days_itr != cfg->SpecialDays.end(); spec_days_itr++)
{ /// <inheritdoc/>
int repeat_every_year = 0; bool Utilities::CheckSpecialDay(Configuration* cfg, const char* currentDateTimeStr, int* specialDayId, double* specialDayPrice)
repeat_every_year = spec_days_itr->second.ped_year; {
try
string start = spec_days_itr->second.ped_date_start; {
if (start.length() <= 0) continue; *specialDayId = -1;
//cout << "CheckSpecialDay() => Start: " << start << endl; *specialDayPrice = 0.0f;
string end = spec_days_itr->second.ped_date_end; if (cfg == nullptr) throw std::invalid_argument("CheckSpecialDay() => configuration is not set\n");
if (end.length() <= 0) continue; if (currentDateTimeStr == nullptr) throw std::invalid_argument("CheckSpecialDay() => invalid date/time string set\n");
//cout << "CheckSpecialDay() => End: " << end << endl;
struct tm start_tm = Utilities::DateToStructTm(start.c_str()); struct tm current_tm = Utilities::DateTimeToStructTm(currentDateTimeStr);
//cout << "CheckSpecialDay() => Start: " << asctime(&start_tm) << endl; //cout << "CheckSpecialDay() => Current: " << asctime(&current_tm) << endl;
struct tm end_tm = Utilities::DateToStructTm(end.c_str()); multimap<int, ATBSpecialDays>::iterator spec_days_itr;
//cout << "CheckSpecialDay() => End: " << asctime(&end_tm) << endl;
for (spec_days_itr = cfg->SpecialDays.begin(); spec_days_itr != cfg->SpecialDays.end(); spec_days_itr++)
if (repeat_every_year <= 0) {
{ int repeat_every_year = 0;
//cout << "CheckSpecialDay() => Repeat every year is: 0" << endl; repeat_every_year = spec_days_itr->second.ped_year;
if ((current_tm.tm_year == start_tm.tm_year) && (current_tm.tm_year == end_tm.tm_year))
{ string start = spec_days_itr->second.ped_date_start;
if ((current_tm.tm_mon >= start_tm.tm_mon) && (current_tm.tm_mon <= end_tm.tm_mon)) if (start.length() <= 0) continue;
{ //cout << "CheckSpecialDay() => Start: " << start << endl;
//cout << "CheckSpecialDay() => Month is in range between start and end" << endl;
if ((current_tm.tm_mday >= start_tm.tm_mday) && (current_tm.tm_mday <= end_tm.tm_mday)) string end = spec_days_itr->second.ped_date_end;
{ if (end.length() <= 0) continue;
LOG_DEBUG("CheckSpecialDay() => SPECIAL DAY"); //cout << "CheckSpecialDay() => End: " << end << endl;
*specialDayId = spec_days_itr->second.ped_id;
*specialDayPrice = cfg->SpecialDaysWorktime.find(*specialDayId)->second.pedwt_price; struct tm start_tm = Utilities::DateToStructTm(start.c_str());
return true; //cout << "CheckSpecialDay() => Start: " << asctime(&start_tm) << endl;
}
} struct tm end_tm = Utilities::DateToStructTm(end.c_str());
} //cout << "CheckSpecialDay() => End: " << asctime(&end_tm) << endl;
}
else if (repeat_every_year <= 0)
{ {
if ((current_tm.tm_mon >= start_tm.tm_mon) && (current_tm.tm_mon <= end_tm.tm_mon)) //cout << "CheckSpecialDay() => Repeat every year is: 0" << endl;
{ if ((current_tm.tm_year == start_tm.tm_year) && (current_tm.tm_year == end_tm.tm_year))
//cout << "CheckSpecialDay() => Month is in range between start and end" << endl; {
if ((current_tm.tm_mday >= start_tm.tm_mday) && (current_tm.tm_mday <= end_tm.tm_mday)) if ((current_tm.tm_mon >= start_tm.tm_mon) && (current_tm.tm_mon <= end_tm.tm_mon))
{ {
LOG_DEBUG("CheckSpecialDay() => SPECIAL DAY"); //cout << "CheckSpecialDay() => Month is in range between start and end" << endl;
*specialDayId = spec_days_itr->second.ped_id; if ((current_tm.tm_mday >= start_tm.tm_mday) && (current_tm.tm_mday <= end_tm.tm_mday))
*specialDayPrice = cfg->SpecialDaysWorktime.find(*specialDayId)->second.pedwt_price; {
return true; LOG_DEBUG("CheckSpecialDay() => SPECIAL DAY");
} *specialDayId = spec_days_itr->second.ped_id;
} *specialDayPrice = cfg->SpecialDaysWorktime.find(*specialDayId)->second.pedwt_price;
} return true;
} }
//cout << "CheckSpecialDay() => NOT SPECIAL DAY" << endl; }
return false; }
} }
catch (...) else
{ {
throw std::invalid_argument("CheckSpecialDay() => An error has occurred\n"); if ((current_tm.tm_mon >= start_tm.tm_mon) && (current_tm.tm_mon <= end_tm.tm_mon))
return false; {
} //cout << "CheckSpecialDay() => Month is in range between start and end" << endl;
} if ((current_tm.tm_mday >= start_tm.tm_mday) && (current_tm.tm_mday <= end_tm.tm_mday))
{
bool Utilities::CheckSpecialDay(Configuration const *cfg, LOG_DEBUG("CheckSpecialDay() => SPECIAL DAY");
QDateTime const &currentDateTime, *specialDayId = spec_days_itr->second.ped_id;
int* specialDayId, *specialDayPrice = cfg->SpecialDaysWorktime.find(*specialDayId)->second.pedwt_price;
uint32_t *specialDayPrice) { return true;
*specialDayId = -1; }
*specialDayPrice = 0; }
}
std::multimap<int, ATBSpecialDays>::const_iterator spec_days_itr; }
//cout << "CheckSpecialDay() => NOT SPECIAL DAY" << endl;
for (spec_days_itr = cfg->SpecialDays.cbegin(); spec_days_itr != cfg->SpecialDays.cend(); ++spec_days_itr) { return false;
int repeat_every_year = spec_days_itr->second.ped_year; }
QDate start = QDate::fromString(spec_days_itr->second.ped_date_start.c_str(), Qt::ISODate); catch (...)
QDate end = QDate::fromString(spec_days_itr->second.ped_date_end.c_str(), Qt::ISODate); {
if (start.isValid() && end.isValid()) { throw std::invalid_argument("CheckSpecialDay() => An error has occurred\n");
if ((currentDateTime.date().month() >= start.month()) && return false;
(currentDateTime.date().month() <= end.month())) { }
if ((currentDateTime.date().day() >= start.day()) && }
(currentDateTime.date().day() <= end.day())) {
if (repeat_every_year <= 0) { bool Utilities::CheckSpecialDay(Configuration const *cfg,
if ((currentDateTime.date().year() != start.year()) || QDateTime const &currentDateTime,
(currentDateTime.date().year() != end.year())) { int* specialDayId,
continue; uint32_t *specialDayPrice) {
} *specialDayId = -1;
} *specialDayPrice = 0;
qDebug() << "CheckSpecialDay() => SPECIAL DAY";
*specialDayId = spec_days_itr->second.ped_id; std::multimap<int, ATBSpecialDays>::const_iterator spec_days_itr;
*specialDayPrice = cfg->SpecialDaysWorktime.find(*specialDayId)->second.pedwt_price;
return true; for (spec_days_itr = cfg->SpecialDays.cbegin(); spec_days_itr != cfg->SpecialDays.cend(); ++spec_days_itr) {
} int repeat_every_year = spec_days_itr->second.ped_year;
} QDate start = QDate::fromString(spec_days_itr->second.ped_date_start.c_str(), Qt::ISODate);
} QDate end = QDate::fromString(spec_days_itr->second.ped_date_end.c_str(), Qt::ISODate);
} if (start.isValid() && end.isValid()) {
if ((currentDateTime.date().month() >= start.month()) &&
return false; (currentDateTime.date().month() <= end.month())) {
} if ((currentDateTime.date().day() >= start.day()) &&
(currentDateTime.date().day() <= end.day())) {
QTime Utilities::SpecialDaysWorkTimeFrom(Configuration const *cfg, int specialDayId) { if (repeat_every_year <= 0) {
return QTime::fromString(cfg->SpecialDaysWorktime.find(specialDayId)->second.pedwt_time_from.c_str(), Qt::ISODate); if ((currentDateTime.date().year() != start.year()) ||
} (currentDateTime.date().year() != end.year())) {
continue;
QTime Utilities::SpecialDaysWorkTimeUntil(Configuration const *cfg, int specialDayId) { }
return QTime::fromString(cfg->SpecialDaysWorktime.find(specialDayId)->second.pedwt_time_to.c_str(), Qt::ISODate); }
} qDebug() << "CheckSpecialDay() => SPECIAL DAY";
*specialDayId = spec_days_itr->second.ped_id;
*specialDayPrice = cfg->SpecialDaysWorktime.find(*specialDayId)->second.pedwt_price;
return true;
}
}
}
}
return false;
}
QTime Utilities::SpecialDaysWorkTimeFrom(Configuration const *cfg, int specialDayId) {
return QTime::fromString(cfg->SpecialDaysWorktime.find(specialDayId)->second.pedwt_time_from.c_str(), Qt::ISODate);
}
QTime Utilities::SpecialDaysWorkTimeUntil(Configuration const *cfg, int specialDayId) {
return QTime::fromString(cfg->SpecialDaysWorktime.find(specialDayId)->second.pedwt_time_to.c_str(), Qt::ISODate);
}
QTime Utilities::WeekDaysWorkTimeFrom(std::multimap<int, ATBWeekDaysWorktime>::const_iterator itr) {
return QTime::fromString(itr->second.pwd_time_from.c_str(), Qt::ISODate);
}
QTime Utilities::WeekDaysWorkTimeUntil(std::multimap<int, ATBWeekDaysWorktime>::const_iterator itr) {
return QTime::fromString(itr->second.pwd_time_to.c_str(), Qt::ISODate);
}
bool Utilities::isCarryOverSet(Configuration const *cfg, PaymentMethod paymentMethodId) {
return !isCarryOverNotSet(cfg, paymentMethodId);
}
bool Utilities::isCarryOverNotSet(Configuration const *cfg, PaymentMethod paymentMethodId) {
return (cfg->PaymentOption.find(paymentMethodId)->second.pop_carry_over < 1);
}
PaymentMethod Utilities::getPaymentMethodId(Configuration const *cfg) {
if (cfg->PaymentOption.size() != 1) {
return PaymentMethod::Undefined;
}
std::multimap<int, ATBPaymentOption>::const_iterator it =
cfg->PaymentOption.cbegin();
switch (it->first) {
case PaymentMethod::Linear:
return PaymentMethod::Linear;
case PaymentMethod::Steps:
return PaymentMethod::Steps;
case PaymentMethod::Degressive:
return PaymentMethod::Degressive;
case PaymentMethod::Progressive:
return PaymentMethod::Progressive;
}
return PaymentMethod::Undefined;
}
int Utilities::getMinimalParkingTime(Configuration const *cfg, PaymentMethod methodId) {
return std::max((int)cfg->PaymentOption.find(methodId)->second.pop_min_time, 0);
}
int Utilities::getMaximalParkingTime(Configuration const *cfg, PaymentMethod methodId) {
return std::max((int)cfg->PaymentOption.find(methodId)->second.pop_max_time, 0);
}
uint32_t Utilities::getMinimalParkingPrice(Configuration const *cfg, PaymentMethod methodId) {
return std::max((int)cfg->PaymentOption.find(methodId)->second.pop_min_price, 0);
}
uint32_t Utilities::getFirstDurationStep(Configuration const *cfg, PaymentMethod methodId) {
int const popId = cfg->PaymentOption.find(methodId)->second.pop_id;
int const punId = cfg->PaymentRate.find(popId)->second.pra_payment_unit_id;
uint32_t const firstDurationStep= cfg->Duration.find(punId)->second.pun_duration;
qCritical() << "getFirstDurationStep() payment-method-id:" << (int)methodId;
qCritical() << "getFirstDurationStep() pop-id:" << popId;
qCritical() << "getFirstDurationStep() pun-id:" << punId;
qCritical() << "getFirstDurationStep() first-step:" << firstDurationStep;
return firstDurationStep;
}

View File

@@ -33,10 +33,16 @@ extern "C" char* strptime(const char* s,
#include "calculator_functions.h" #include "calculator_functions.h"
#include <calculate_price.h> #include <calculate_price.h>
#define SZEGED (1)
#define NEUHAUSER_KORNEUBURG (0)
int main() { int main() {
#if NEUHAUSER_KORNEUBURG==1
std::ifstream input("/tmp/tariff_korneuburg.json"); std::ifstream input("/tmp/tariff_korneuburg.json");
int pop_max_time;
std::stringstream sstr; std::stringstream sstr;
while(input >> sstr.rdbuf()); while(input >> sstr.rdbuf());
std::string json(sstr.str()); std::string json(sstr.str());
@@ -47,118 +53,130 @@ int main() {
bool isParsed = cfg.ParseJson(&cfg, json.c_str()); bool isParsed = cfg.ParseJson(&cfg, json.c_str());
cout << endl; cout << endl;
if (isParsed) {
{
pop_max_time = 3*60;
bool nextDay = false;
bool prePaid = true;
// zone 1 (lila)
QDateTime s(QDate(2023, 11, 30), QTime());
QDateTime end;
for (int duration = 30; duration <= pop_max_time; duration += 5) {
for (int offset = 420; offset < 1140; ++offset) {
if (offset > 720 && offset < 840) {
continue;
}
QDateTime start = s.addSecs(offset * 60);
//qCritical() << "start" << start.toString(Qt::ISODate);
if (isParsed) double cost = calculator.GetCostFromDuration(&cfg, 3, start, end, duration, nextDay, prePaid);
{ //Q_ASSERT(cost == duration*2.5);
QDateTime start = QDateTime::fromString("2023-05-11T08:00:00",Qt::ISODate); //qCritical() << "";
QDateTime end = start.addSecs(120); //qCritical() << "start" << start.toString(Qt::ISODate)
calculator.GetCostFromDuration(&cfg, 3, start, end, 60); // << "end" << end.toString(Qt::ISODate)
// << "duration" << duration
// << "cost" << cost;
std::string duration = calculator.GetDurationFromCost(&cfg, 3, start.toString(Qt::ISODate).toStdString().c_str(), cost);
//Q_ASSERT(cost == duration*2.5);
qCritical() << "start" << start.toString(Qt::ISODate)
<< "cost" << cost
<< "until" << duration.c_str() << start.secsTo(QDateTime::fromString(duration.c_str(), Qt::ISODate)) / 60;
}
}
}
}
return 0;
#elif SZEGED==1
std::ifstream input;
int pop_max_time;
for (int t=6; t < 7; t+=20) {
switch (t) {
case 1: {
input.open("/opt/ptu5/opt/customer_281/etc/psa_tariff/tariff01.json");
pop_max_time = 6*60;
} break;
case 2: {
input.open("/opt/ptu5/opt/customer_281/etc/psa_tariff/tariff02.json");
pop_max_time = 5*60;
} break;
case 3: {
input.open("/opt/ptu5/opt/customer_281/etc/psa_tariff/tariff03.json");
pop_max_time = 6*60;
} break;
case 4: {
input.open("/opt/ptu5/opt/customer_281/etc/psa_tariff/tariff04.json");
pop_max_time = 4*60;
} break;
case 5: {
input.open("/opt/ptu5/opt/customer_281/etc/psa_tariff/tariff05.json");
pop_max_time = 6*60;
} break;
case 6: {
input.open("/opt/ptu5/opt/customer_281/etc/psa_tariff/tariff06.json");
pop_max_time = 4*60;
} break;
default:
continue;
}
std::stringstream sstr;
while(input >> sstr.rdbuf());
std::string json(sstr.str());
Calculator calculator;
Configuration cfg;
bool isParsed = cfg.ParseJson(&cfg, json.c_str());
cout << endl;
if (isParsed) {
{
// zone 1 (lila)
QDateTime s(QDate(2023, 11, 30), QTime());
QDateTime end;
for (int duration = 15; duration <= pop_max_time; duration += 5) {
for (int offset = 480; offset < 1080; ++offset) {
QDateTime start = s.addSecs(offset * 60);
//qCritical() << "start" << start.toString(Qt::ISODate);
double cost = calculator.GetCostFromDuration(&cfg, 3, start, end, duration);
//Q_ASSERT(cost == duration*2.5);
//qCritical() << "";
//qCritical() << "start" << start.toString(Qt::ISODate)
// << "end" << end.toString(Qt::ISODate)
// << "duration" << duration
// << "cost" << cost;
std::string duration = calculator.GetDurationFromCost(&cfg, 3, start.toString(Qt::ISODate).toStdString().c_str(), cost);
//Q_ASSERT(cost == duration*2.5);
qCritical() << "start" << start.toString(Qt::ISODate)
<< "cost" << cost
<< "until" << duration.c_str() << start.secsTo(QDateTime::fromString(duration.c_str(), Qt::ISODate)) / 60;
}
}
}
{
QDateTime start(QDate(2023, 12, 1), QTime(18, 0));
QDateTime end;
double cost = calculator.GetCostFromDuration(&cfg, 3, start, end, 60);
// Q_ASSERT(cost == 150);
qCritical() << "end" << end.toString(Qt::ISODate) << "cost" << cost;
}
{
QDateTime start(QDate(2023, 10, 31), QTime(18, 0));
QDateTime end;
double cost = calculator.GetCostFromDuration(&cfg, 3, start, end, 60);
//Q_ASSERT(cost == 150);
qCritical() << "end" << end.toString(Qt::ISODate) << "cost" << cost;
}
}
} }
return 0; return 0;
#endif
parking_tariff_t *tariff = 0;
if (init_tariff(&tariff, "/etc/psa_tariff/")) {
struct price_t price;
memset(&price, 0x00, sizeof(price));
QDateTime start = QDateTime::fromString("2023-05-11T07:50:00",Qt::ISODate); //QDateTime::currentDateTime();
time_t start_parking_time = start.toSecsSinceEpoch() / 60;
time_t end_parking_time = start_parking_time + 615;
if (compute_price_for_parking_ticket(tariff,
start_parking_time,
end_parking_time,
&price))
{
qDebug() << "GetCostFromDuration() => price=" << price.netto;
}
QString duration;
if(compute_duration_for_parking_ticket(tariff,start_parking_time,3090,duration))
{
qDebug() << "GetDurationFromCost() => duration=" << duration;
}
// Daily ticket
//compute_duration_for_daily_ticket(tariff,start.toString(Qt::ISODate),3);
//Configuration* cfg, QString start_datetime, uint8_t payment_option, bool carry_over
// // tests
// struct tm now;
// memset(&now, 0, sizeof(now));
// // 3.Jan 2023 -> Tuesday
// strptime("2023-01-03T14:00:00", "%Y-%m-%dT%H:%M:%S", &now);
// for (int i = 0; i < 600; ++i) {
// start_parking_time = mktime(&now);
// end_parking_time = start_parking_time + 240; // duration == 240
// if (compute_price_for_parking_ticket(tariff,
// start_parking_time,
// end_parking_time,
// &price)) {
// int const zone = get_zone_nr(1);
// switch (zone) {
// case 1:
// assert(price.netto == 879); // expected value: 880
// break;
// case 2:
// /* fall through */
// case 3:
// assert(price.netto == 1920);
// break;
// }
// }
// time_t t = start_parking_time + 60;
// now = *localtime(&t);
// }
// //
// // test May 1st 2023
// //
// memset(&now, 0, sizeof(now));
// strptime("2023-04-30T06:00:00", "%Y-%m-%dT%H:%M:%S", &now);
// now.tm_hour -= 1; // for ctime
// // for (int i=0; i<6*24; ++i) {
// for (int i=0; i<1; ++i) {
// int const duration = 120;
// time_t t = mktime(&now);
// start_parking_time = t / 60;
// end_parking_time = start_parking_time + duration;
// if (compute_price_for_parking_ticket(tariff,
// start_parking_time,
// end_parking_time,
// &price)) {
// int const zone = get_zone_nr();
// switch (zone) {
// case 1:
// qDebug() << i << zone << ctime(&t) << price.netto << " FT";
// assert(price.netto == 440);
// break;
// case 2:
// /* fall through */
// case 3:
// qDebug() << i << zone << ctime(&t) << price.netto << " FT";
// assert(price.netto == 960);
// break;
// }
// }
// t = (start_parking_time + 60)*60;
// now = *localtime(&t);
// }
free_tariff(tariff);
}
return 0;
#if 0 #if 0

View File

@@ -1,9 +1,12 @@
{ {
"Project" : "Korneuburg",
"Version" : "1.0.0",
"Info" : "",
"Currency": [ "Currency": [
{ {
"pcu_id": 2, "pcu_id": 2,
"pcu_sign": "Ft", "pcu_sign": "",
"pcu_major": "HUF", "pcu_major": "EUR",
"pcu_minor": "", "pcu_minor": "",
"pcu_active": true "pcu_active": true
} }
@@ -29,30 +32,30 @@
"PaymentOption": [ "PaymentOption": [
{ {
"pop_id": 1049, "pop_id": 1049,
"pop_label": "Zone Lila", "pop_label": "Zone 1",
"pop_payment_method_id": 3, "pop_payment_method_id": 3,
"pop_day_end_time": "16:25:00", "pop_day_end_time": "00:00:00",
"pop_day_night_end_time": "16:25:00", "pop_day_night_end_time": "00:00:00",
"pop_price_night": 0, "pop_price_night": 0,
"pop_min_time": 15, "pop_min_time": 30,
"pop_max_time": 300, "pop_max_time": 180,
"pop_min_price": 0, "pop_min_price": 60,
"pop_carry_over": 1, "pop_carry_over": 1,
"pop_daily_card_price": 900 "pop_daily_card_price": 0
} }
], ],
"PaymentRate": [ "PaymentRate": [
{ {
"pra_payment_option_id": 1049, "pra_payment_option_id": 1049,
"pra_payment_unit_id": 1, "pra_payment_unit_id": 1,
"pra_price": 150 "pra_price": 10
} }
], ],
"Duration": [ "Duration": [
{ {
"pun_id": 1, "pun_id": 1,
"pun_label": "1h", "pun_label": "5 min",
"pun_duration": 60 "pun_duration": 5
}, },
{ {
"pun_id": 3, "pun_id": 3,
@@ -71,6 +74,13 @@
"pwd_period_week_day_id": 36, "pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 1, "pwd_period_day_in_week_id": 1,
"pwd_time_from": "08:00:00", "pwd_time_from": "08:00:00",
"pwd_time_to": "12:00:00"
},
{
"pwd_id": 621,
"pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 1,
"pwd_time_from": "14:00:00",
"pwd_time_to": "18:00:00" "pwd_time_to": "18:00:00"
}, },
{ {
@@ -78,6 +88,13 @@
"pwd_period_week_day_id": 36, "pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 2, "pwd_period_day_in_week_id": 2,
"pwd_time_from": "08:00:00", "pwd_time_from": "08:00:00",
"pwd_time_to": "12:00:00"
},
{
"pwd_id": 622,
"pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 2,
"pwd_time_from": "14:00:00",
"pwd_time_to": "18:00:00" "pwd_time_to": "18:00:00"
}, },
{ {
@@ -85,6 +102,13 @@
"pwd_period_week_day_id": 36, "pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 3, "pwd_period_day_in_week_id": 3,
"pwd_time_from": "08:00:00", "pwd_time_from": "08:00:00",
"pwd_time_to": "12:00:00"
},
{
"pwd_id": 623,
"pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 3,
"pwd_time_from": "14:00:00",
"pwd_time_to": "18:00:00" "pwd_time_to": "18:00:00"
}, },
{ {
@@ -92,6 +116,13 @@
"pwd_period_week_day_id": 36, "pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 4, "pwd_period_day_in_week_id": 4,
"pwd_time_from": "08:00:00", "pwd_time_from": "08:00:00",
"pwd_time_to": "12:00:00"
},
{
"pwd_id": 624,
"pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 4,
"pwd_time_from": "14:00:00",
"pwd_time_to": "18:00:00" "pwd_time_to": "18:00:00"
}, },
{ {
@@ -99,73 +130,21 @@
"pwd_period_week_day_id": 36, "pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 5, "pwd_period_day_in_week_id": 5,
"pwd_time_from": "08:00:00", "pwd_time_from": "08:00:00",
"pwd_time_to": "12:00:00"
},
{
"pwd_id": 625,
"pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 5,
"pwd_time_from": "14:00:00",
"pwd_time_to": "18:00:00" "pwd_time_to": "18:00:00"
}
],
"PeriodYear": [
{
"pye_id": 8,
"pye_label": "Whole year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
}, },
{ {
"pye_id": 9, "pwd_id": 626,
"pye_label": "Whole year", "pwd_period_week_day_id": 36,
"pye_start_month": 1, "pwd_period_day_in_week_id": 6,
"pye_start_day": 1, "pwd_time_from": "08:00:00",
"pye_end_month": 12, "pwd_time_to": "12:00:00"
"pye_end_day": 31
},
{
"pye_id": 10,
"pye_label": "Whole year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 11,
"pye_label": "Whole Year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 12,
"pye_label": "Whole Year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 13,
"pye_label": "Whole Year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 14,
"pye_label": "Whole Year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 15,
"pye_label": "Whole year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
} }
], ],
"SpecialDaysWorktime": [ "SpecialDaysWorktime": [
@@ -385,421 +364,266 @@
"pedwt_time_from": "00:00:00", "pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00", "pedwt_time_to": "00:00:00",
"pedwt_price": 0 "pedwt_price": 0
},
{
"pedwt_id": 2260,
"pedwt_period_exc_day_id": 2061,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2261,
"pedwt_period_exc_day_id": 2062,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2262,
"pedwt_period_exc_day_id": 2063,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2263,
"pedwt_period_exc_day_id": 2064,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2264,
"pedwt_period_exc_day_id": 2065,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2265,
"pedwt_period_exc_day_id": 2066,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2266,
"pedwt_period_exc_day_id": 2067,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2267,
"pedwt_period_exc_day_id": 2068,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2268,
"pedwt_period_exc_day_id": 2069,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2269,
"pedwt_period_exc_day_id": 2070,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2270,
"pedwt_period_exc_day_id": 2071,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
} }
], ],
"SpecialDays": [ "SpecialDays": [
{ {
"ped_id": 11, "ped_id": 11,
"ped_label": "Christmas 1st day", "ped_label": "Mariae Empfaengnis",
"ped_date_start": "2022-12-25", "ped_date_start": "2023-12-08",
"ped_date_end": "2022-12-25", "ped_date_end": "2023-12-08",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 13, "ped_id": 13,
"ped_label": "Christmas 2nd day", "ped_label": "Christtag",
"ped_date_start": "2022-12-26", "ped_date_start": "2023-12-25",
"ped_date_end": "2022-12-26", "ped_date_end": "2023-12-25",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 14, "ped_id": 14,
"ped_label": "Republic Day (Hungary)", "ped_label": "Stefanitag",
"ped_date_start": "2022-10-23", "ped_date_start": "2023-12-26",
"ped_date_end": "2022-10-23", "ped_date_end": "2023-12-26",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2016, "ped_id": 2016,
"ped_label": "Christmas (Sunday)", "ped_label": "Neujahr",
"ped_date_start": "2022-12-24", "ped_date_start": "2024-01-01",
"ped_date_end": "2022-12-24", "ped_date_end": "2024-01-01",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2021, "ped_id": 2021,
"ped_label": "Holiday (Hungary)", "ped_label": "Heilig Drei Koenige",
"ped_date_start": "2022-12-31", "ped_date_start": "2024-01-06",
"ped_date_end": "2022-12-31", "ped_date_end": "2024-01-06",
"ped_period_special_day_id": 1, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2022, "ped_id": 2022,
"ped_label": "NewYear", "ped_label": "Ostermontag",
"ped_date_start": "2023-01-01", "ped_date_start": "2024-01-04",
"ped_date_end": "2023-01-01", "ped_date_end": "2024-01-04",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 2024
}, },
{ {
"ped_id": 2024, "ped_id": 2024,
"ped_label": "Good Friday", "ped_label": "Staatsfeiertag",
"ped_date_start": "2023-04-07", "ped_date_start": "2024-05-01",
"ped_date_end": "2023-04-07", "ped_date_end": "2024-05-01",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2023 "ped_year": 0
}, },
{ {
"ped_id": 2025, "ped_id": 2025,
"ped_label": "Easter Sunday", "ped_label": "Christi Himmelfahrt",
"ped_date_start": "2023-04-09", "ped_date_start": "2024-05-09",
"ped_date_end": "2023-04-09", "ped_date_end": "2024-05-09",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2023 "ped_year": 2024
}, },
{ {
"ped_id": 2026, "ped_id": 2026,
"ped_label": "Easter Monday", "ped_label": "Pfingst Montag",
"ped_date_start": "2023-04-10", "ped_date_start": "2024-05-20",
"ped_date_end": "2023-04-10", "ped_date_end": "2024-05-20",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2023 "ped_year": 2024
}, },
{ {
"ped_id": 2027, "ped_id": 2027,
"ped_label": "Whit Sunday", "ped_label": "Fronleichnam",
"ped_date_start": "2023-05-28", "ped_date_start": "2024-05-30",
"ped_date_end": "2023-05-28", "ped_date_end": "2024-05-30",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2023 "ped_year": 2024
}, },
{ {
"ped_id": 2028, "ped_id": 2028,
"ped_label": "Whit Monday", "ped_label": "Maria Himmelfahrt",
"ped_date_start": "2023-05-29", "ped_date_start": "2024-08-15",
"ped_date_end": "2023-05-29", "ped_date_end": "2024-08-15",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2023 "ped_year": 0
}, },
{ {
"ped_id": 2029, "ped_id": 2029,
"ped_label": "Revolution Day (Hungary)", "ped_label": "Nationalfeiertag",
"ped_date_start": "2023-03-15", "ped_date_start": "2024-10-26",
"ped_date_end": "2023-03-15", "ped_date_end": "2024-10-26",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2030, "ped_id": 2030,
"ped_label": "Labour Day", "ped_label": "Allerheiligen",
"ped_date_start": "2023-05-01", "ped_date_start": "2024-11-01",
"ped_date_end": "2023-05-01", "ped_date_end": "2024-11-01",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2031, "ped_id": 2031,
"ped_label": "Saint Stephens Day (Hungary)", "ped_label": "Mariae Empfaengnis",
"ped_date_start": "2023-08-20", "ped_date_start": "2024-08-12",
"ped_date_end": "2023-08-20", "ped_date_end": "2024-08-12",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2032, "ped_id": 2032,
"ped_label": "All Saints Day", "ped_label": "Christtag",
"ped_date_start": "2023-11-01", "ped_date_start": "2024-12-25",
"ped_date_end": "2023-11-01", "ped_date_end": "2024-12-25",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2034, "ped_id": 2034,
"ped_label": "Good Friday", "ped_label": "Stefanitag",
"ped_date_start": "2024-03-29", "ped_date_start": "2024-12-26",
"ped_date_end": "2024-03-29", "ped_date_end": "2024-12-26",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2024 "ped_year": 0
}, },
{ {
"ped_id": 2035, "ped_id": 2035,
"ped_label": "Easter", "ped_label": "Neujahr",
"ped_date_start": "2024-03-31", "ped_date_start": "2025-01-01",
"ped_date_end": "2024-03-31", "ped_date_end": "2025-01-01",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2024 "ped_year": 0
}, },
{ {
"ped_id": 2036, "ped_id": 2036,
"ped_label": "Easter Monday", "ped_label": "Heilig Drei Koenige",
"ped_date_start": "2024-04-01", "ped_date_start": "2025-06-01",
"ped_date_end": "2024-04-01", "ped_date_end": "2025-06-01",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2024 "ped_year": 0
}, },
{ {
"ped_id": 2037, "ped_id": 2037,
"ped_label": "Whit Monday", "ped_label": "Ostermontag",
"ped_date_start": "2024-05-20", "ped_date_start": "2025-04-21",
"ped_date_end": "2024-05-20", "ped_date_end": "2025-04-21",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2024 "ped_year": 2025
}, },
{ {
"ped_id": 2038, "ped_id": 2038,
"ped_label": "Whit Sunday", "ped_label": "Staatsfeiertag",
"ped_date_start": "2024-05-19", "ped_date_start": "2025-05-01",
"ped_date_end": "2024-05-19", "ped_date_end": "2025-05-01",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2024 "ped_year": 2025
}, },
{ {
"ped_id": 2050, "ped_id": 2050,
"ped_label": "Uskrs", "ped_label": "Christi Himmelfahrt",
"ped_date_start": "2023-04-16", "ped_date_start": "2025-05-29",
"ped_date_end": "2023-04-16", "ped_date_end": "2025-05-29",
"ped_period_special_day_id": 1, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 2025
}, },
{ {
"ped_id": 2051, "ped_id": 2051,
"ped_label": "Uskrs", "ped_label": "Pfingstmontag",
"ped_date_start": "2023-04-16", "ped_date_start": "2025-06-09",
"ped_date_end": "2023-04-16", "ped_date_end": "2025-06-09",
"ped_period_special_day_id": 1, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 2025
}, },
{ {
"ped_id": 2052, "ped_id": 2052,
"ped_label": "Christmas 1st day", "ped_label": "Fronlaeichnam",
"ped_date_start": "2022-12-25", "ped_date_start": "2025-06-19",
"ped_date_end": "2022-12-25", "ped_date_end": "2025-06-19",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 2025
}, },
{ {
"ped_id": 2053, "ped_id": 2053,
"ped_label": "Christmas 2nd day", "ped_label": "Mariae Himmelfahrt",
"ped_date_start": "2022-12-26", "ped_date_start": "2025-08-15",
"ped_date_end": "2022-12-26", "ped_date_end": "2025-08-15",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2054, "ped_id": 2054,
"ped_label": "Republic Day (Hungary)", "ped_label": "Nationalfeiertag",
"ped_date_start": "2022-10-23", "ped_date_start": "2025-10-26",
"ped_date_end": "2022-10-23", "ped_date_end": "2025-10-26",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2055, "ped_id": 2055,
"ped_label": "Christmas (Sunday)", "ped_label": "Allerheiligen",
"ped_date_start": "2022-12-24", "ped_date_start": "2025-11-01",
"ped_date_end": "2022-12-24", "ped_date_end": "2025-11-01",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2056, "ped_id": 2056,
"ped_label": "Holiday (Hungary)", "ped_label": "Mariae Empfaengnis",
"ped_date_start": "2022-12-31", "ped_date_start": "2025-12-08",
"ped_date_end": "2022-12-31", "ped_date_end": "2025-12-08",
"ped_period_special_day_id": 1, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2057, "ped_id": 2057,
"ped_label": "NewYear", "ped_label": "Christtag",
"ped_date_start": "2023-01-01", "ped_date_start": "2025-12-25",
"ped_date_end": "2023-01-01", "ped_date_end": "2025-12-25",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 0 "ped_year": 0
}, },
{ {
"ped_id": 2058, "ped_id": 2058,
"ped_label": "Good Friday", "ped_label": "Stefanitag",
"ped_date_start": "2023-04-07", "ped_date_start": "2025-12-26",
"ped_date_end": "2023-04-07", "ped_date_end": "2025-12-26",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2023 "ped_year": 0
}, },
{ {
"ped_id": 2059, "ped_id": 2059,
"ped_label": "Easter Sunday", "ped_label": "Neujahr",
"ped_date_start": "2023-04-09", "ped_date_start": "2026-01-01",
"ped_date_end": "2023-04-09", "ped_date_end": "2026-01-01",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2023 "ped_year": 0
}, },
{ {
"ped_id": 2060, "ped_id": 2060,
"ped_label": "Easter Monday", "ped_label": "Heilige Drei Koenige",
"ped_date_start": "2023-04-10", "ped_date_start": "2026-01-06",
"ped_date_end": "2023-04-10", "ped_date_end": "2026-01-06",
"ped_period_special_day_id": 2, "ped_period_special_day_id": 1,
"ped_year": 2023
},
{
"ped_id": 2061,
"ped_label": "Whit Sunday",
"ped_date_start": "2023-05-28",
"ped_date_end": "2023-05-28",
"ped_period_special_day_id": 2,
"ped_year": 2023
},
{
"ped_id": 2062,
"ped_label": "Whit Monday",
"ped_date_start": "2023-05-29",
"ped_date_end": "2023-05-29",
"ped_period_special_day_id": 2,
"ped_year": 2023
},
{
"ped_id": 2063,
"ped_label": "Revolution Day (Hungary)",
"ped_date_start": "2023-03-15",
"ped_date_end": "2023-03-15",
"ped_period_special_day_id": 2,
"ped_year": 0 "ped_year": 0
}, }
],
"PeriodYear": [
{ {
"ped_id": 2064, "pye_id": 8,
"ped_label": "Labour Day", "pye_label": "Whole year",
"ped_date_start": "2023-05-01", "pye_start_month": 1,
"ped_date_end": "2023-05-01", "pye_start_day": 1,
"ped_period_special_day_id": 2, "pye_end_month": 12,
"ped_year": 0 "pye_end_day": 31
},
{
"ped_id": 2065,
"ped_label": "Saint Stephens Day (Hungary)",
"ped_date_start": "2023-08-20",
"ped_date_end": "2023-08-20",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2066,
"ped_label": "All Saints Day",
"ped_date_start": "2023-11-01",
"ped_date_end": "2023-11-01",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2067,
"ped_label": "Good Friday",
"ped_date_start": "2024-03-29",
"ped_date_end": "2024-03-29",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2068,
"ped_label": "Easter",
"ped_date_start": "2024-03-31",
"ped_date_end": "2024-03-31",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2069,
"ped_label": "Easter Monday",
"ped_date_start": "2024-04-01",
"ped_date_end": "2024-04-01",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2070,
"ped_label": "Whit Monday",
"ped_date_start": "2024-05-20",
"ped_date_end": "2024-05-20",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2071,
"ped_label": "Whit Sunday",
"ped_date_start": "2024-05-19",
"ped_date_end": "2024-05-19",
"ped_period_special_day_id": 2,
"ped_year": 2024
} }
] ]
} }

805
tariffs/tariff_new_01.json Normal file
View File

@@ -0,0 +1,805 @@
{
"Currency": [
{
"pcu_id": 2,
"pcu_sign": "Ft",
"pcu_major": "HUF",
"pcu_minor": "",
"pcu_active": true
}
],
"PaymentMethod": [
{
"pme_id": 1,
"pme_label": "progressive"
},
{
"pme_id": 2,
"pme_label": "degressive"
},
{
"pme_id": 3,
"pme_label": "linear"
},
{
"pme_id": 4,
"pme_label": "steps"
}
],
"PaymentOption": [
{
"pop_id": 1049,
"pop_label": "Zone Lila",
"pop_payment_method_id": 3,
"pop_day_end_time": "16:25:00",
"pop_day_night_end_time": "16:25:00",
"pop_price_night": 0,
"pop_min_time": 15,
"pop_max_time": 300,
"pop_min_price": 0,
"pop_carry_over": 1,
"pop_daily_card_price": 900
}
],
"PaymentRate": [
{
"pra_payment_option_id": 1049,
"pra_payment_unit_id": 1,
"pra_price": 150
}
],
"Duration": [
{
"pun_id": 1,
"pun_label": "1h",
"pun_duration": 60
},
{
"pun_id": 3,
"pun_label": "15 min",
"pun_duration": 15
},
{
"pun_id": 4,
"pun_label": "1 min",
"pun_duration": 1
}
],
"WeekDaysWorktime": [
{
"pwd_id": 621,
"pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 1,
"pwd_time_from": "08:00:00",
"pwd_time_to": "18:00:00"
},
{
"pwd_id": 622,
"pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 2,
"pwd_time_from": "08:00:00",
"pwd_time_to": "18:00:00"
},
{
"pwd_id": 623,
"pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 3,
"pwd_time_from": "08:00:00",
"pwd_time_to": "18:00:00"
},
{
"pwd_id": 624,
"pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 4,
"pwd_time_from": "08:00:00",
"pwd_time_to": "18:00:00"
},
{
"pwd_id": 625,
"pwd_period_week_day_id": 36,
"pwd_period_day_in_week_id": 5,
"pwd_time_from": "08:00:00",
"pwd_time_to": "18:00:00"
}
],
"PeriodYear": [
{
"pye_id": 8,
"pye_label": "Whole year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 9,
"pye_label": "Whole year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 10,
"pye_label": "Whole year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 11,
"pye_label": "Whole Year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 12,
"pye_label": "Whole Year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 13,
"pye_label": "Whole Year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 14,
"pye_label": "Whole Year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
},
{
"pye_id": 15,
"pye_label": "Whole year",
"pye_start_month": 1,
"pye_start_day": 1,
"pye_end_month": 12,
"pye_end_day": 31
}
],
"SpecialDaysWorktime": [
{
"pedwt_id": 2156,
"pedwt_period_exc_day_id": 2024,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2158,
"pedwt_period_exc_day_id": 2025,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2160,
"pedwt_period_exc_day_id": 2026,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2162,
"pedwt_period_exc_day_id": 2027,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2164,
"pedwt_period_exc_day_id": 2028,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2170,
"pedwt_period_exc_day_id": 2030,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2172,
"pedwt_period_exc_day_id": 2032,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2174,
"pedwt_period_exc_day_id": 11,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2175,
"pedwt_period_exc_day_id": 13,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2178,
"pedwt_period_exc_day_id": 2022,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2179,
"pedwt_period_exc_day_id": 14,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2184,
"pedwt_period_exc_day_id": 2021,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2188,
"pedwt_period_exc_day_id": 2031,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2189,
"pedwt_period_exc_day_id": 2029,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2194,
"pedwt_period_exc_day_id": 2034,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2200,
"pedwt_period_exc_day_id": 2037,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2202,
"pedwt_period_exc_day_id": 2038,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2226,
"pedwt_period_exc_day_id": 2016,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2245,
"pedwt_period_exc_day_id": 2035,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2246,
"pedwt_period_exc_day_id": 2036,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2249,
"pedwt_period_exc_day_id": 2050,
"pedwt_time_from": "08:00:00",
"pedwt_time_to": "16:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2250,
"pedwt_period_exc_day_id": 2051,
"pedwt_time_from": "08:00:00",
"pedwt_time_to": "16:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2251,
"pedwt_period_exc_day_id": 2052,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2252,
"pedwt_period_exc_day_id": 2053,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2253,
"pedwt_period_exc_day_id": 2054,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2254,
"pedwt_period_exc_day_id": 2055,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2255,
"pedwt_period_exc_day_id": 2056,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2256,
"pedwt_period_exc_day_id": 2057,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2257,
"pedwt_period_exc_day_id": 2058,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2258,
"pedwt_period_exc_day_id": 2059,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2259,
"pedwt_period_exc_day_id": 2060,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2260,
"pedwt_period_exc_day_id": 2061,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2261,
"pedwt_period_exc_day_id": 2062,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2262,
"pedwt_period_exc_day_id": 2063,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2263,
"pedwt_period_exc_day_id": 2064,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2264,
"pedwt_period_exc_day_id": 2065,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2265,
"pedwt_period_exc_day_id": 2066,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2266,
"pedwt_period_exc_day_id": 2067,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2267,
"pedwt_period_exc_day_id": 2068,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2268,
"pedwt_period_exc_day_id": 2069,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2269,
"pedwt_period_exc_day_id": 2070,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2270,
"pedwt_period_exc_day_id": 2071,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
}
],
"SpecialDays": [
{
"ped_id": 2016,
"ped_label": "Christmas",
"ped_date_start": "2023-12-24",
"ped_date_end": "2023-12-24",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 11,
"ped_label": "Christmas 1st day",
"ped_date_start": "2023-12-25",
"ped_date_end": "2023-12-25",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 13,
"ped_label": "Christmas 2nd day",
"ped_date_start": "2023-12-26",
"ped_date_end": "2023-12-26",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2022,
"ped_label": "NewYear",
"ped_date_start": "2024-01-01",
"ped_date_end": "2024-01-01",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 14,
"ped_label": "1848 Revolution Memorial Day",
"ped_date_start": "2024-03-15",
"ped_date_end": "2024-03-15",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2024,
"ped_label": "Good Friday",
"ped_date_start": "2024-03-29",
"ped_date_end": "2024-03-29",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2025,
"ped_label": "Easter Sunday",
"ped_date_start": "2024-03-31",
"ped_date_end": "2024-03-31",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2026,
"ped_label": "Easter Monday",
"ped_date_start": "2024-04-01",
"ped_date_end": "2024-04-01",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2030,
"ped_label": "Labour Day",
"ped_date_start": "2024-05-01",
"ped_date_end": "2024-05-01",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2027,
"ped_label": "Whit Sunday",
"ped_date_start": "2024-05-19",
"ped_date_end": "2024-05-19",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2028,
"ped_label": "Whit Monday",
"ped_date_start": "2024-05-20",
"ped_date_end": "2024-05-20",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2031,
"ped_label": "National Day",
"ped_date_start": "2024-08-20",
"ped_date_end": "2024-08-20",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2054,
"ped_label": "1956 Revolution Memorial Day",
"ped_date_start": "2024-10-23",
"ped_date_end": "2024-10-23",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2032,
"ped_label": "All Saints Day",
"ped_date_start": "2024-11-01",
"ped_date_end": "2024-11-01",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2055,
"ped_label": "Christmas",
"ped_date_start": "2024-12-24",
"ped_date_end": "2024-12-24",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2052,
"ped_label": "Christmas 1st day",
"ped_date_start": "2024-12-25",
"ped_date_end": "2024-12-25",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2053,
"ped_label": "Christmas 2nd day",
"ped_date_start": "2024-12-26",
"ped_date_end": "2024-12-26",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2057,
"ped_label": "NewYear",
"ped_date_start": "2025-01-01",
"ped_date_end": "2025-01-01",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2029,
"ped_label": "1848 Revolution Memorial Day",
"ped_date_start": "2025-03-15",
"ped_date_end": "2025-03-15",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2034,
"ped_label": "Good Friday",
"ped_date_start": "2025-04-18",
"ped_date_end": "2025-04-18",
"ped_period_special_day_id": 2,
"ped_year": 2025
},
{
"ped_id": 2035,
"ped_label": "Easter",
"ped_date_start": "2025-04-20",
"ped_date_end": "2025-04-20",
"ped_period_special_day_id": 2,
"ped_year": 2025
},
{
"ped_id": 2036,
"ped_label": "Easter Monday",
"ped_date_start": "2025-04-21",
"ped_date_end": "2025-04-21",
"ped_period_special_day_id": 2,
"ped_year": 2025
},
{
"ped_id": 2064,
"ped_label": "Labour Day",
"ped_date_start": "2025-05-01",
"ped_date_end": "2025-05-01",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2038,
"ped_label": "Whit Sunday",
"ped_date_start": "2024-06-08",
"ped_date_end": "2024-06-08",
"ped_period_special_day_id": 2,
"ped_year": 2025
},
{
"ped_id": 2037,
"ped_label": "Whit Monday",
"ped_date_start": "2025-06-09",
"ped_date_end": "2025-06-09",
"ped_period_special_day_id": 2,
"ped_year": 2025
},
{
"ped_id": 2065,
"ped_label": "<<<<< Hungary National Day >>>>>",
"ped_date_start": "2025-08-20",
"ped_date_end": "2025-08-20",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2021,
"ped_label": "Holiday (Hungary)",
"ped_date_start": "2023-12-31",
"ped_date_end": "2023-12-31",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2050,
"ped_label": "Uskrs",
"ped_date_start": "2023-04-16",
"ped_date_end": "2023-04-16",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2051,
"ped_label": "Uskrs",
"ped_date_start": "2023-04-16",
"ped_date_end": "2023-04-16",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2056,
"ped_label": "Holiday (Hungary)",
"ped_date_start": "2022-12-31",
"ped_date_end": "2022-12-31",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2058,
"ped_label": "Good Friday",
"ped_date_start": "2023-04-07",
"ped_date_end": "2023-04-07",
"ped_period_special_day_id": 2,
"ped_year": 2023
},
{
"ped_id": 2059,
"ped_label": "Easter Sunday",
"ped_date_start": "2023-04-09",
"ped_date_end": "2023-04-09",
"ped_period_special_day_id": 2,
"ped_year": 2023
},
{
"ped_id": 2060,
"ped_label": "Easter Monday",
"ped_date_start": "2023-04-10",
"ped_date_end": "2023-04-10",
"ped_period_special_day_id": 2,
"ped_year": 2023
},
{
"ped_id": 2061,
"ped_label": "Whit Sunday",
"ped_date_start": "2023-05-28",
"ped_date_end": "2023-05-28",
"ped_period_special_day_id": 2,
"ped_year": 2023
},
{
"ped_id": 2062,
"ped_label": "Whit Monday",
"ped_date_start": "2023-05-29",
"ped_date_end": "2023-05-29",
"ped_period_special_day_id": 2,
"ped_year": 2023
},
{
"ped_id": 2063,
"ped_label": "Revolution Day (Hungary)",
"ped_date_start": "2023-03-15",
"ped_date_end": "2023-03-15",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2066,
"ped_label": "All Saints Day",
"ped_date_start": "2025-11-01",
"ped_date_end": "2025-11-01",
"ped_period_special_day_id": 2,
"ped_year": 0
},
{
"ped_id": 2067,
"ped_label": "Good Friday",
"ped_date_start": "2024-03-29",
"ped_date_end": "2024-03-29",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2068,
"ped_label": "Easter",
"ped_date_start": "2024-03-31",
"ped_date_end": "2024-03-31",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2069,
"ped_label": "Easter Monday",
"ped_date_start": "2024-04-01",
"ped_date_end": "2024-04-01",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2070,
"ped_label": "Whit Monday",
"ped_date_start": "2024-05-20",
"ped_date_end": "2024-05-20",
"ped_period_special_day_id": 2,
"ped_year": 2024
},
{
"ped_id": 2071,
"ped_label": "Whit Sunday",
"ped_date_start": "2024-05-19",
"ped_date_end": "2024-05-19",
"ped_period_special_day_id": 2,
"ped_year": 2024
}
]
}

View File

@@ -40,7 +40,7 @@
"pop_min_time": 30, "pop_min_time": 30,
"pop_max_time": 180, "pop_max_time": 180,
"pop_min_price": 60, "pop_min_price": 60,
"pop_carry_over": 0, "pop_carry_over": 1,
"pop_daily_card_price": 0 "pop_daily_card_price": 0
} }
], ],
@@ -147,6 +147,475 @@
"pwd_time_to": "12:00:00" "pwd_time_to": "12:00:00"
} }
], ],
"SpecialDaysWorktime": [
{
"pedwt_id": 2156,
"pedwt_period_exc_day_id": 2024,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2158,
"pedwt_period_exc_day_id": 2025,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2160,
"pedwt_period_exc_day_id": 2026,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2162,
"pedwt_period_exc_day_id": 2027,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2164,
"pedwt_period_exc_day_id": 2028,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2170,
"pedwt_period_exc_day_id": 2030,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2172,
"pedwt_period_exc_day_id": 2032,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2174,
"pedwt_period_exc_day_id": 11,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2175,
"pedwt_period_exc_day_id": 13,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2178,
"pedwt_period_exc_day_id": 2022,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2179,
"pedwt_period_exc_day_id": 14,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2184,
"pedwt_period_exc_day_id": 2021,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2188,
"pedwt_period_exc_day_id": 2031,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2189,
"pedwt_period_exc_day_id": 2029,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2194,
"pedwt_period_exc_day_id": 2034,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2200,
"pedwt_period_exc_day_id": 2037,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2202,
"pedwt_period_exc_day_id": 2038,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2226,
"pedwt_period_exc_day_id": 2016,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2245,
"pedwt_period_exc_day_id": 2035,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2246,
"pedwt_period_exc_day_id": 2036,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2249,
"pedwt_period_exc_day_id": 2050,
"pedwt_time_from": "08:00:00",
"pedwt_time_to": "16:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2250,
"pedwt_period_exc_day_id": 2051,
"pedwt_time_from": "08:00:00",
"pedwt_time_to": "16:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2251,
"pedwt_period_exc_day_id": 2052,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2252,
"pedwt_period_exc_day_id": 2053,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2253,
"pedwt_period_exc_day_id": 2054,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2254,
"pedwt_period_exc_day_id": 2055,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2255,
"pedwt_period_exc_day_id": 2056,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2256,
"pedwt_period_exc_day_id": 2057,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2257,
"pedwt_period_exc_day_id": 2058,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2258,
"pedwt_period_exc_day_id": 2059,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
},
{
"pedwt_id": 2259,
"pedwt_period_exc_day_id": 2060,
"pedwt_time_from": "00:00:00",
"pedwt_time_to": "00:00:00",
"pedwt_price": 0
}
],
"SpecialDays": [
{
"ped_id": 11,
"ped_label": "Mariae Empfaengnis",
"ped_date_start": "2023-12-08",
"ped_date_end": "2023-12-08",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 13,
"ped_label": "Christtag",
"ped_date_start": "2023-12-25",
"ped_date_end": "2023-12-25",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 14,
"ped_label": "Stefanitag",
"ped_date_start": "2023-12-26",
"ped_date_end": "2023-12-26",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2016,
"ped_label": "Neujahr",
"ped_date_start": "2024-01-01",
"ped_date_end": "2024-01-01",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2021,
"ped_label": "Heilig Drei Koenige",
"ped_date_start": "2024-01-06",
"ped_date_end": "2024-01-06",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2022,
"ped_label": "Ostermontag",
"ped_date_start": "2024-01-04",
"ped_date_end": "2024-01-04",
"ped_period_special_day_id": 1,
"ped_year": 2024
},
{
"ped_id": 2024,
"ped_label": "Staatsfeiertag",
"ped_date_start": "2024-05-01",
"ped_date_end": "2024-05-01",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2025,
"ped_label": "Christi Himmelfahrt",
"ped_date_start": "2024-05-09",
"ped_date_end": "2024-05-09",
"ped_period_special_day_id": 1,
"ped_year": 2024
},
{
"ped_id": 2026,
"ped_label": "Pfingst Montag",
"ped_date_start": "2024-05-20",
"ped_date_end": "2024-05-20",
"ped_period_special_day_id": 1,
"ped_year": 2024
},
{
"ped_id": 2027,
"ped_label": "Fronleichnam",
"ped_date_start": "2024-05-30",
"ped_date_end": "2024-05-30",
"ped_period_special_day_id": 1,
"ped_year": 2024
},
{
"ped_id": 2028,
"ped_label": "Maria Himmelfahrt",
"ped_date_start": "2024-08-15",
"ped_date_end": "2024-08-15",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2029,
"ped_label": "Nationalfeiertag",
"ped_date_start": "2024-10-26",
"ped_date_end": "2024-10-26",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2030,
"ped_label": "Allerheiligen",
"ped_date_start": "2024-11-01",
"ped_date_end": "2024-11-01",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2031,
"ped_label": "Mariae Empfaengnis",
"ped_date_start": "2024-08-12",
"ped_date_end": "2024-08-12",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2032,
"ped_label": "Christtag",
"ped_date_start": "2024-12-25",
"ped_date_end": "2024-12-25",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2034,
"ped_label": "Stefanitag",
"ped_date_start": "2024-12-26",
"ped_date_end": "2024-12-26",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2035,
"ped_label": "Neujahr",
"ped_date_start": "2025-01-01",
"ped_date_end": "2025-01-01",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2036,
"ped_label": "Heilig Drei Koenige",
"ped_date_start": "2025-06-01",
"ped_date_end": "2025-06-01",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2037,
"ped_label": "Ostermontag",
"ped_date_start": "2025-04-21",
"ped_date_end": "2025-04-21",
"ped_period_special_day_id": 1,
"ped_year": 2025
},
{
"ped_id": 2038,
"ped_label": "Staatsfeiertag",
"ped_date_start": "2025-05-01",
"ped_date_end": "2025-05-01",
"ped_period_special_day_id": 1,
"ped_year": 2025
},
{
"ped_id": 2050,
"ped_label": "Christi Himmelfahrt",
"ped_date_start": "2025-05-29",
"ped_date_end": "2025-05-29",
"ped_period_special_day_id": 1,
"ped_year": 2025
},
{
"ped_id": 2051,
"ped_label": "Pfingstmontag",
"ped_date_start": "2025-06-09",
"ped_date_end": "2025-06-09",
"ped_period_special_day_id": 1,
"ped_year": 2025
},
{
"ped_id": 2052,
"ped_label": "Fronlaeichnam",
"ped_date_start": "2025-06-19",
"ped_date_end": "2025-06-19",
"ped_period_special_day_id": 1,
"ped_year": 2025
},
{
"ped_id": 2053,
"ped_label": "Mariae Himmelfahrt",
"ped_date_start": "2025-08-15",
"ped_date_end": "2025-08-15",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2054,
"ped_label": "Nationalfeiertag",
"ped_date_start": "2025-10-26",
"ped_date_end": "2025-10-26",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2055,
"ped_label": "Allerheiligen",
"ped_date_start": "2025-11-01",
"ped_date_end": "2025-11-01",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2056,
"ped_label": "Mariae Empfaengnis",
"ped_date_start": "2025-12-08",
"ped_date_end": "2025-12-08",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2057,
"ped_label": "Christtag",
"ped_date_start": "2025-12-25",
"ped_date_end": "2025-12-25",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2058,
"ped_label": "Stefanitag",
"ped_date_start": "2025-12-26",
"ped_date_end": "2025-12-26",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2059,
"ped_label": "Neujahr",
"ped_date_start": "2026-01-01",
"ped_date_end": "2026-01-01",
"ped_period_special_day_id": 1,
"ped_year": 0
},
{
"ped_id": 2060,
"ped_label": "Heilige Drei Koenige",
"ped_date_start": "2026-01-06",
"ped_date_end": "2026-01-06",
"ped_period_special_day_id": 1,
"ped_year": 0
}
],
"PeriodYear": [ "PeriodYear": [
{ {
"pye_id": 8, "pye_id": 8,