aboutsummaryrefslogtreecommitdiff
path: root/src/Costasdev.Busurbano.Backend/Services
diff options
context:
space:
mode:
authorAriel Costas Guerrero <ariel@costas.dev>2025-12-27 19:22:02 +0100
committerAriel Costas Guerrero <ariel@costas.dev>2025-12-27 19:22:02 +0100
commitfbd2c1aa2dd25dd61483553d114c484060f71bd6 (patch)
tree1c868555838faac4293f8ccd5ceaab7af9717733 /src/Costasdev.Busurbano.Backend/Services
parentf81ff82f2a07f87f6eb4f43de49ede64215519e5 (diff)
IDEK
Diffstat (limited to 'src/Costasdev.Busurbano.Backend/Services')
-rw-r--r--src/Costasdev.Busurbano.Backend/Services/FareService.cs22
-rw-r--r--src/Costasdev.Busurbano.Backend/Services/OtpService.cs3
2 files changed, 21 insertions, 4 deletions
diff --git a/src/Costasdev.Busurbano.Backend/Services/FareService.cs b/src/Costasdev.Busurbano.Backend/Services/FareService.cs
index 0e4fefc..9a11a56 100644
--- a/src/Costasdev.Busurbano.Backend/Services/FareService.cs
+++ b/src/Costasdev.Busurbano.Backend/Services/FareService.cs
@@ -20,23 +20,39 @@ public class FareService
var busLegs = legs.Where(l => l.Mode != null && l.Mode.ToUpper() != "WALK").ToList();
// Cash fare logic
- // TODO: In the future, this should depend on the operator/feed
- var cashFare = busLegs.Count * 1.63; // Defaulting to Vitrasa for now
+ double cashFare = 0;
+ foreach (var leg in busLegs)
+ {
+ // TODO: In the future, this should depend on the operator/feed
+ if (leg.FeedId == "vitrasa")
+ {
+ cashFare += 1.63;
+ }
+ else
+ {
+ cashFare += 1.63; // Default fallback
+ }
+ }
// Card fare logic (45-min transfer window)
int cardTicketsRequired = 0;
DateTime? lastTicketPurchased = null;
int tripsPaidWithTicket = 0;
+ string? lastFeedId = null;
foreach (var leg in busLegs)
{
+ // If no ticket purchased, ticket expired (no free transfers after 45 mins), or max trips with ticket reached
+ // Also check if we changed operator (assuming no free transfers between different operators for now)
if (lastTicketPurchased == null ||
(leg.StartTime - lastTicketPurchased.Value).TotalMinutes > 45 ||
- tripsPaidWithTicket >= 3)
+ tripsPaidWithTicket >= 3 ||
+ leg.FeedId != lastFeedId)
{
cardTicketsRequired++;
lastTicketPurchased = leg.StartTime;
tripsPaidWithTicket = 1;
+ lastFeedId = leg.FeedId;
}
else
{
diff --git a/src/Costasdev.Busurbano.Backend/Services/OtpService.cs b/src/Costasdev.Busurbano.Backend/Services/OtpService.cs
index 7eba590..8d47225 100644
--- a/src/Costasdev.Busurbano.Backend/Services/OtpService.cs
+++ b/src/Costasdev.Busurbano.Backend/Services/OtpService.cs
@@ -1,5 +1,4 @@
using System.Globalization;
-using System.Text;
using Costasdev.Busurbano.Backend.Configuration;
using Costasdev.Busurbano.Backend.Helpers;
using Costasdev.Busurbano.Backend.Types.Otp;
@@ -430,6 +429,8 @@ public class OtpService
return new Leg
{
Mode = leg.Mode,
+ FeedId = feedId,
+ RouteId = leg.Route?.GtfsId,
RouteName = leg.Route?.LongName,
RouteShortName = shortName,
RouteLongName = leg.Route?.LongName,