|
|
@ -156,6 +156,7 @@ import java.lang.reflect.Type;
|
|
|
|
import java.sql.SQLException;
|
|
|
|
import java.sql.SQLException;
|
|
|
|
import java.sql.Timestamp;
|
|
|
|
import java.sql.Timestamp;
|
|
|
|
import java.time.LocalDateTime;
|
|
|
|
import java.time.LocalDateTime;
|
|
|
|
|
|
|
|
import java.time.LocalTime;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.Calendar;
|
|
|
|
import java.util.Calendar;
|
|
|
|
import java.util.Collection;
|
|
|
|
import java.util.Collection;
|
|
|
@ -1069,7 +1070,15 @@ public class DeviceManagementProviderServiceImpl implements DeviceManagementProv
|
|
|
|
dateDiff = endDate.getTime() - device.getEnrolmentInfo().getDateOfEnrolment();
|
|
|
|
dateDiff = endDate.getTime() - device.getEnrolmentInfo().getDateOfEnrolment();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
long dateInDays = TimeUnit.DAYS.convert(dateDiff, TimeUnit.MILLISECONDS);
|
|
|
|
|
|
|
|
|
|
|
|
// Convert dateDiff to days as a decimal value
|
|
|
|
|
|
|
|
double dateDiffInDays = (double) dateDiff / (24 * 60 * 60 * 1000);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (dateDiffInDays % 1 >= 0.9) {
|
|
|
|
|
|
|
|
dateDiffInDays = Math.ceil(dateDiffInDays);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
long dateInDays = (long) dateDiffInDays;
|
|
|
|
double cost = (tenantCost.getCost() / 365) * dateInDays;
|
|
|
|
double cost = (tenantCost.getCost() / 365) * dateInDays;
|
|
|
|
totalCost += cost;
|
|
|
|
totalCost += cost;
|
|
|
|
device.setCost(Math.round(cost * 100.0) / 100.0);
|
|
|
|
device.setCost(Math.round(cost * 100.0) / 100.0);
|
|
|
@ -1136,9 +1145,13 @@ public class DeviceManagementProviderServiceImpl implements DeviceManagementProv
|
|
|
|
|
|
|
|
|
|
|
|
long difference_In_Days = (difference_In_Time / (1000 * 60 * 60 * 24)) % 365;
|
|
|
|
long difference_In_Days = (difference_In_Time / (1000 * 60 * 60 * 24)) % 365;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (difference_In_Time % (1000 * 60 * 60 * 24) >= 0.9 * (1000 * 60 * 60 * 24)) {
|
|
|
|
|
|
|
|
difference_In_Days++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = 1; i <= difference_In_Years; i++) {
|
|
|
|
for (int i = 1; i <= difference_In_Years; i++) {
|
|
|
|
List<Device> allDevicesPerYear = new ArrayList<>();
|
|
|
|
List<Device> allDevicesPerYear = new ArrayList<>();
|
|
|
|
LocalDateTime oneYearAfterStart = startDate.toLocalDateTime().plusYears(1);
|
|
|
|
LocalDateTime oneYearAfterStart = startDate.toLocalDateTime().plusYears(1).with(LocalTime.of(23, 59, 59));;
|
|
|
|
Timestamp newStartDate;
|
|
|
|
Timestamp newStartDate;
|
|
|
|
Timestamp newEndDate;
|
|
|
|
Timestamp newEndDate;
|
|
|
|
|
|
|
|
|
|
|
@ -1147,14 +1160,12 @@ public class DeviceManagementProviderServiceImpl implements DeviceManagementProv
|
|
|
|
remainingDaysConsidered = true;
|
|
|
|
remainingDaysConsidered = true;
|
|
|
|
oneYearAfterStart = startDate.toLocalDateTime();
|
|
|
|
oneYearAfterStart = startDate.toLocalDateTime();
|
|
|
|
newEndDate = endDate;
|
|
|
|
newEndDate = endDate;
|
|
|
|
} else if (Timestamp.valueOf(oneYearAfterStart).getTime() >= endDate.getTime()) {
|
|
|
|
|
|
|
|
newEndDate = Timestamp.valueOf(oneYearAfterStart);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
oneYearAfterStart = startDate.toLocalDateTime().plusYears(1);
|
|
|
|
oneYearAfterStart = startDate.toLocalDateTime().plusYears(1).with(LocalTime.of(23, 59, 59));;
|
|
|
|
newEndDate = Timestamp.valueOf(oneYearAfterStart);
|
|
|
|
newEndDate = Timestamp.valueOf(oneYearAfterStart);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
oneYearAfterStart = startDate.toLocalDateTime().plusYears(1);
|
|
|
|
oneYearAfterStart = startDate.toLocalDateTime().plusYears(1).with(LocalTime.of(23, 59, 59));;
|
|
|
|
newEndDate = Timestamp.valueOf(oneYearAfterStart);
|
|
|
|
newEndDate = Timestamp.valueOf(oneYearAfterStart);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -1177,7 +1188,7 @@ public class DeviceManagementProviderServiceImpl implements DeviceManagementProv
|
|
|
|
allDevices.addAll(billingResponse.getDevice());
|
|
|
|
allDevices.addAll(billingResponse.getDevice());
|
|
|
|
totalCost = totalCost + billingResponse.getTotalCostPerYear();
|
|
|
|
totalCost = totalCost + billingResponse.getTotalCostPerYear();
|
|
|
|
deviceCount = deviceCount + billingResponse.getDeviceCount();
|
|
|
|
deviceCount = deviceCount + billingResponse.getDeviceCount();
|
|
|
|
LocalDateTime nextStartDate = oneYearAfterStart.plusDays(1);
|
|
|
|
LocalDateTime nextStartDate = oneYearAfterStart.plusDays(1).with(LocalTime.of(00, 00, 00));
|
|
|
|
startDate = Timestamp.valueOf(nextStartDate);
|
|
|
|
startDate = Timestamp.valueOf(nextStartDate);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|