[2026-04-11T09:40:01+00:00] INFO Starting property sync {"start":"2026-04-11T07:31:37+00:00","end":"2026-04-11T10:31:37+00:00","offset_fetch_duration_ms":1,"page_size":100,"expand":["Media","OpenHouse","Unit","Room"],"statuses":["Active","Coming Soon","Active Under Contract"],"property_types":["Residential"]}
[2026-04-11T09:40:01+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-11T07:31:37Z and ModificationTimestamp lt 2026-04-11T10:31:37Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-11T09:40:01+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-11T07%3A31%3A37Z+and+ModificationTimestamp+lt+2026-04-11T10%3A31%3A37Z+and+%28StandardStatus+eq+%27Active%27+or+StandardStatus+eq+%27Coming+Soon%27+or+StandardStatus+eq+%27Active+Under+Contract%27%29+and+%28PropertyType+eq+%27Residential%27%29&%24orderby=ModificationTimestamp+asc%2CListingKey+asc&%24top=100&%24expand=Media%2COpenHouse%2CUnit%2CRoom"}
[2026-04-11T09:40:02+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-11T07%3A31%3A37Z+and+ModificationTimestamp+lt+2026-04-11T10%3A31%3A37Z+and+%28StandardStatus+eq+%27Active%27+or+StandardStatus+eq+%27Coming+Soon%27+or+StandardStatus+eq+%27Active+Under+Contract%27%29+and+%28PropertyType+eq+%27Residential%27%29&%24orderby=ModificationTimestamp+asc%2CListingKey+asc&%24top=100&%24expand=Media%2COpenHouse%2CUnit%2CRoom","count":12,"duration_ms":784}
[2026-04-11T09:40:02+00:00] INFO Processing page {"count":12,"has_next":false}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"20260410154713779071000000","duration_ms":39}
[2026-04-11T09:40:02+00:00] INFO Photos saved {"listing_id":"20260410154713779071000000","count":12,"duration_ms":40}
[2026-04-11T09:40:02+00:00] INFO History recorded {"listing_id":"20260410154713779071000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-11T08:30:59Z","duration_ms":17}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"20260410154713779071000000","duration_ms":97}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"20260304204639140933000000","duration_ms":43}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260304204639140933000000","PhotosChangeTimestamp":"2026-03-04 21:32:20","duration_ms":9}
[2026-04-11T09:40:02+00:00] INFO History recorded {"listing_id":"20260304204639140933000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-11 08:34:09","last_update":"2026-04-11T08:34:09Z","duration_ms":24}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"20260304204639140933000000","duration_ms":76}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"20260129161738740203000000","duration_ms":24}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260129161738740203000000","PhotosChangeTimestamp":"2026-02-04 21:17:43","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO History recorded {"listing_id":"20260129161738740203000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-11 08:36:18","last_update":"2026-04-11T08:36:18Z","duration_ms":5}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"20260129161738740203000000","duration_ms":30}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"20260317101045631459000000","duration_ms":15}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260317101045631459000000","PhotosChangeTimestamp":"2026-03-22 01:38:56","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260317101045631459000000","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"20260317101045631459000000","duration_ms":17}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"20251230161918430337000000","duration_ms":18}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20251230161918430337000000","PhotosChangeTimestamp":"2025-12-30 17:16:32","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20251230161918430337000000","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"20251230161918430337000000","duration_ms":20}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"20260410005616080020000000","duration_ms":18}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260410005616080020000000","PhotosChangeTimestamp":"2026-04-10 17:35:18","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260410005616080020000000","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"20260410005616080020000000","duration_ms":19}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"605758956","duration_ms":18}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"605758956","PhotosChangeTimestamp":"2025-10-29 10:20:34","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO History unchanged, skipping {"listing_id":"605758956","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"605758956","duration_ms":20}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"20260128181859128201000000","duration_ms":89}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260128181859128201000000","PhotosChangeTimestamp":"2026-01-28 18:47:32","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260128181859128201000000","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"20260128181859128201000000","duration_ms":91}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"606805300","duration_ms":5}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"606805300","PhotosChangeTimestamp":"2026-01-02 12:07:37","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO History unchanged, skipping {"listing_id":"606805300","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"606805300","duration_ms":7}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"607679615","duration_ms":6}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"607679615","PhotosChangeTimestamp":"2025-12-15 09:35:48","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO History unchanged, skipping {"listing_id":"607679615","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"607679615","duration_ms":8}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"20260330144031426778000000","duration_ms":5}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260330144031426778000000","PhotosChangeTimestamp":"2026-04-10 12:45:23","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260330144031426778000000","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"20260330144031426778000000","duration_ms":7}
[2026-04-11T09:40:02+00:00] INFO Listing upserted {"id":"610590054","duration_ms":6}
[2026-04-11T09:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"610590054","PhotosChangeTimestamp":"2026-03-02 15:32:17","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO History unchanged, skipping {"listing_id":"610590054","duration_ms":1}
[2026-04-11T09:40:02+00:00] INFO Listing processed {"listing_id":"610590054","duration_ms":8}
[2026-04-11T09:40:02+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-11T09:40:03+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-11 09:37:36.000","adjusted":true}
[2026-04-11T09:40:03+00:00] INFO Property sync complete {"last_modification":"2026-04-11T09:37:36+00:00"}
[2026-04-11T09:40:03+00:00] INFO Property sync finished {"status":"ok","duration_ms":1777}
