[2026-04-12T12:40:01+00:00] INFO Starting property sync {"start":"2026-04-12T12:17:27+00:00","end":"2026-04-12T15:17:27+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-12T12:40:01+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-12T12:17:27Z and ModificationTimestamp lt 2026-04-12T15:17:27Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-12T12:40:01+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-12T12%3A17%3A27Z+and+ModificationTimestamp+lt+2026-04-12T15%3A17%3A27Z+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-12T12: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-12T12%3A17%3A27Z+and+ModificationTimestamp+lt+2026-04-12T15%3A17%3A27Z+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":981}
[2026-04-12T12:40:02+00:00] INFO Processing page {"count":12,"has_next":false}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20260322011224825413000000","duration_ms":14}
[2026-04-12T12:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260322011224825413000000","PhotosChangeTimestamp":"2026-03-27 13:54:20","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260322011224825413000000","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20260322011224825413000000","duration_ms":17}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20260406132911556950000000","duration_ms":14}
[2026-04-12T12:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260406132911556950000000","PhotosChangeTimestamp":"2026-04-12 12:09:58","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260406132911556950000000","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20260406132911556950000000","duration_ms":16}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20260301003036178697000000","duration_ms":4}
[2026-04-12T12:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260301003036178697000000","PhotosChangeTimestamp":"2026-03-01 01:24:21","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260301003036178697000000","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20260301003036178697000000","duration_ms":6}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20251121154055538030000000","duration_ms":5}
[2026-04-12T12:40:02+00:00] INFO Photos saved {"listing_id":"20251121154055538030000000","count":88,"duration_ms":6}
[2026-04-12T12:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20251121154055538030000000","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20251121154055538030000000","duration_ms":13}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"605791337","duration_ms":4}
[2026-04-12T12:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"605791337","PhotosChangeTimestamp":"2026-04-02 19:22:48","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO History unchanged, skipping {"listing_id":"605791337","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"605791337","duration_ms":7}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20260322132255929316000000","duration_ms":6}
[2026-04-12T12:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260322132255929316000000","PhotosChangeTimestamp":"2026-03-27 11:31:42","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO History recorded {"listing_id":"20260322132255929316000000","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-12T12:32:50Z","duration_ms":3}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20260322132255929316000000","duration_ms":10}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20260319144048932239000000","duration_ms":5}
[2026-04-12T12:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260319144048932239000000","PhotosChangeTimestamp":"2026-04-12 12:16:22","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260319144048932239000000","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20260319144048932239000000","duration_ms":8}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20260129153331007267000000","duration_ms":5}
[2026-04-12T12:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260129153331007267000000","PhotosChangeTimestamp":"2026-01-30 18:06:12","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260129153331007267000000","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20260129153331007267000000","duration_ms":7}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20251110193923065490000000","duration_ms":7}
[2026-04-12T12:40:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20251110193923065490000000","PhotosChangeTimestamp":"2025-11-11 21:12:16","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO History recorded {"listing_id":"20251110193923065490000000","event":"Status Active Under Contract","price_change":"","price_change_ts":"2026-04-02 13:20:54","last_update":"2026-04-12T12:37:48Z","duration_ms":3}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20251110193923065490000000","duration_ms":11}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20260401182235486908000000","duration_ms":5}
[2026-04-12T12:40:02+00:00] INFO Photos saved {"listing_id":"20260401182235486908000000","count":36,"duration_ms":6}
[2026-04-12T12:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260401182235486908000000","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20260401182235486908000000","duration_ms":12}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20260331012331377367000000","duration_ms":4}
[2026-04-12T12:40:02+00:00] INFO Photos saved {"listing_id":"20260331012331377367000000","count":26,"duration_ms":5}
[2026-04-12T12:40:02+00:00] INFO History unchanged, skipping {"listing_id":"20260331012331377367000000","duration_ms":1}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20260331012331377367000000","duration_ms":10}
[2026-04-12T12:40:02+00:00] INFO Listing upserted {"id":"20260411164726140756000000","duration_ms":32}
[2026-04-12T12:40:02+00:00] INFO Photos saved {"listing_id":"20260411164726140756000000","count":33,"duration_ms":5}
[2026-04-12T12:40:02+00:00] INFO History recorded {"listing_id":"20260411164726140756000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T12:39:48Z","duration_ms":6}
[2026-04-12T12:40:02+00:00] INFO Listing processed {"listing_id":"20260411164726140756000000","duration_ms":44}
[2026-04-12T12:40:02+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-12T12:40:03+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-12 12:39:48.000","adjusted":true}
[2026-04-12T12:40:03+00:00] INFO Property sync complete {"last_modification":"2026-04-12T12:39:48+00:00"}
[2026-04-12T12:40:03+00:00] INFO Property sync finished {"status":"ok","duration_ms":1747}
