[2026-04-13T10:40:02+00:00] INFO Starting property sync {"start":"2026-04-13T08:00:14+00:00","end":"2026-04-13T11:00:14+00:00","offset_fetch_duration_ms":0,"page_size":100,"expand":["Media","OpenHouse","Unit","Room"],"statuses":["Active","Coming Soon","Active Under Contract"],"property_types":["Residential"]}
[2026-04-13T10:40:02+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-13T08:00:14Z and ModificationTimestamp lt 2026-04-13T11:00:14Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-13T10:40:02+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-13T08%3A00%3A14Z+and+ModificationTimestamp+lt+2026-04-13T11%3A00%3A14Z+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-13T10:40:03+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-13T08%3A00%3A14Z+and+ModificationTimestamp+lt+2026-04-13T11%3A00%3A14Z+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":14,"duration_ms":1061}
[2026-04-13T10:40:03+00:00] INFO Processing page {"count":14,"has_next":false}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260325151038322945000000","duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO Photos saved {"listing_id":"20260325151038322945000000","count":77,"duration_ms":2}
[2026-04-13T10:40:03+00:00] INFO History recorded {"listing_id":"20260325151038322945000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-13T10:26:17Z","duration_ms":2}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260325151038322945000000","duration_ms":9}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"593271789","duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"593271789","PhotosChangeTimestamp":"2025-10-14 15:15:09","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO History unchanged, skipping {"listing_id":"593271789","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"593271789","duration_ms":4}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260409191301956997000000","duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260409191301956997000000","PhotosChangeTimestamp":"2026-04-11 15:32:22","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO History recorded {"listing_id":"20260409191301956997000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-13T10:31:53Z","duration_ms":2}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260409191301956997000000","duration_ms":5}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260410203948389393000000","duration_ms":2}
[2026-04-13T10:40:03+00:00] INFO Photos saved {"listing_id":"20260410203948389393000000","count":27,"duration_ms":4}
[2026-04-13T10:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260410203948389393000000","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260410203948389393000000","duration_ms":7}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260413095356995824000000","duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO Photos saved {"listing_id":"20260413095356995824000000","count":7,"duration_ms":2}
[2026-04-13T10:40:03+00:00] INFO History recorded {"listing_id":"20260413095356995824000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-13T10:31:53Z","duration_ms":2}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260413095356995824000000","duration_ms":7}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20251110150402688116000000","duration_ms":2}
[2026-04-13T10:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20251110150402688116000000","PhotosChangeTimestamp":"2025-11-18 01:35:42","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20251110150402688116000000","duration_ms":1}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20251110150402688116000000","duration_ms":4}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20251212004859485766000000","duration_ms":2}
[2026-04-13T10:40:03+00:00] INFO Photos saved {"listing_id":"20251212004859485766000000","count":4,"duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20251212004859485766000000","duration_ms":1}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20251212004859485766000000","duration_ms":7}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260324140114103750000000","duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260324140114103750000000","PhotosChangeTimestamp":"2026-03-26 21:13:39","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO History recorded {"listing_id":"20260324140114103750000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-13 10:31:54","last_update":"2026-04-13T10:31:54Z","duration_ms":4}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260324140114103750000000","duration_ms":7}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260329152649313177000000","duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260329152649313177000000","PhotosChangeTimestamp":"2026-03-29 15:53:50","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO History recorded {"listing_id":"20260329152649313177000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-13 10:31:54","last_update":"2026-04-13T10:31:54Z","duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260329152649313177000000","duration_ms":6}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260107235955022898000000","duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260107235955022898000000","PhotosChangeTimestamp":"2026-01-08 00:19:48","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO History recorded {"listing_id":"20260107235955022898000000","event":"Status Active","price_change":"","price_change_ts":"2026-02-14 15:06:04","last_update":"2026-04-13T10:31:55Z","duration_ms":2}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260107235955022898000000","duration_ms":5}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260403225334149764000000","duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260403225334149764000000","PhotosChangeTimestamp":"2026-04-03 23:36:28","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO History recorded {"listing_id":"20260403225334149764000000","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-13T10:31:55Z","duration_ms":2}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260403225334149764000000","duration_ms":5}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260410124746724476000000","duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO Photos saved {"listing_id":"20260410124746724476000000","count":63,"duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260410124746724476000000","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260410124746724476000000","duration_ms":7}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260312233231783712000000","duration_ms":4}
[2026-04-13T10:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260312233231783712000000","PhotosChangeTimestamp":"2026-03-16 20:10:55","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260312233231783712000000","duration_ms":0}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260312233231783712000000","duration_ms":5}
[2026-04-13T10:40:03+00:00] INFO Listing upserted {"id":"20260405105255738881000000","duration_ms":7}
[2026-04-13T10:40:03+00:00] INFO Photos saved {"listing_id":"20260405105255738881000000","count":7,"duration_ms":3}
[2026-04-13T10:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260405105255738881000000","duration_ms":1}
[2026-04-13T10:40:03+00:00] INFO Listing processed {"listing_id":"20260405105255738881000000","duration_ms":11}
[2026-04-13T10:40:03+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-13T10:40:04+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-13 10:39:39.000","adjusted":true}
[2026-04-13T10:40:04+00:00] INFO Property sync complete {"last_modification":"2026-04-13T10:39:39+00:00"}
[2026-04-13T10:40:04+00:00] INFO Property sync finished {"status":"ok","duration_ms":1627}
