[2026-04-05T01:20:02+00:00] INFO Starting property sync {"start":"2026-04-05T01:00:03+00:00","end":"2026-04-05T04:00:03+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-05T01:20:02+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-05T01:00:03Z and ModificationTimestamp lt 2026-04-05T04:00:03Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-05T01:20:02+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-05T01%3A00%3A03Z+and+ModificationTimestamp+lt+2026-04-05T04%3A00%3A03Z+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-05T01:20:03+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-05T01%3A00%3A03Z+and+ModificationTimestamp+lt+2026-04-05T04%3A00%3A03Z+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":10,"duration_ms":821}
[2026-04-05T01:20:03+00:00] INFO Processing page {"count":10,"has_next":false}
[2026-04-05T01:20:03+00:00] INFO Listing upserted {"id":"20260404151713243912000000","duration_ms":4}
[2026-04-05T01:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260404151713243912000000","PhotosChangeTimestamp":"2026-04-04 17:22:30","duration_ms":1}
[2026-04-05T01:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260404151713243912000000","duration_ms":1}
[2026-04-05T01:20:03+00:00] INFO Listing processed {"listing_id":"20260404151713243912000000","duration_ms":7}
[2026-04-05T01:20:03+00:00] INFO Listing upserted {"id":"20260302181453820242000000","duration_ms":4}
[2026-04-05T01:20:03+00:00] INFO Photos saved {"listing_id":"20260302181453820242000000","count":36,"duration_ms":5}
[2026-04-05T01:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260302181453820242000000","duration_ms":1}
[2026-04-05T01:20:03+00:00] INFO Listing processed {"listing_id":"20260302181453820242000000","duration_ms":10}
[2026-04-05T01:20:03+00:00] INFO Listing upserted {"id":"20260404192431491422000000","duration_ms":5}
[2026-04-05T01:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260404192431491422000000","PhotosChangeTimestamp":"2026-04-05 00:52:38","duration_ms":1}
[2026-04-05T01:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260404192431491422000000","duration_ms":1}
[2026-04-05T01:20:03+00:00] INFO Listing processed {"listing_id":"20260404192431491422000000","duration_ms":6}
[2026-04-05T01:20:03+00:00] INFO Listing upserted {"id":"20260105020322776153000000","duration_ms":3}
[2026-04-05T01:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260105020322776153000000","PhotosChangeTimestamp":"2026-01-05 14:43:01","duration_ms":1}
[2026-04-05T01:20:03+00:00] INFO History recorded {"listing_id":"20260105020322776153000000","event":"Price Increased","price_change":"Price Increased","price_change_ts":"2026-04-05 01:04:25","last_update":"2026-04-05T01:04:25Z","duration_ms":4}
[2026-04-05T01:20:03+00:00] INFO Listing processed {"listing_id":"20260105020322776153000000","duration_ms":8}
[2026-04-05T01:20:03+00:00] INFO Listing upserted {"id":"20250321125814313050000000","duration_ms":3}
[2026-04-05T01:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20250321125814313050000000","PhotosChangeTimestamp":"2025-07-24 11:51:43","duration_ms":1}
[2026-04-05T01:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20250321125814313050000000","duration_ms":1}
[2026-04-05T01:20:03+00:00] INFO Listing processed {"listing_id":"20250321125814313050000000","duration_ms":4}
[2026-04-05T01:20:03+00:00] INFO Listing upserted {"id":"20260404202507619435000000","duration_ms":3}
[2026-04-05T01:20:03+00:00] INFO Photos saved {"listing_id":"20260404202507619435000000","count":40,"duration_ms":3}
[2026-04-05T01:20:03+00:00] INFO History recorded {"listing_id":"20260404202507619435000000","event":"Status Coming Soon","price_change":"","price_change_ts":null,"last_update":"2026-04-05T01:11:50Z","duration_ms":2}
[2026-04-05T01:20:03+00:00] INFO Listing processed {"listing_id":"20260404202507619435000000","duration_ms":9}
[2026-04-05T01:20:03+00:00] INFO Listing upserted {"id":"610754899","duration_ms":3}
[2026-04-05T01:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"610754899","PhotosChangeTimestamp":"2026-02-26 12:38:15","duration_ms":0}
[2026-04-05T01:20:03+00:00] INFO History unchanged, skipping {"listing_id":"610754899","duration_ms":0}
[2026-04-05T01:20:03+00:00] INFO Listing processed {"listing_id":"610754899","duration_ms":5}
[2026-04-05T01:20:03+00:00] INFO Listing upserted {"id":"20260326141237647763000000","duration_ms":3}
[2026-04-05T01:20:03+00:00] INFO Photos saved {"listing_id":"20260326141237647763000000","count":19,"duration_ms":3}
[2026-04-05T01:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260326141237647763000000","duration_ms":1}
[2026-04-05T01:20:03+00:00] INFO Listing processed {"listing_id":"20260326141237647763000000","duration_ms":7}
[2026-04-05T01:20:03+00:00] INFO Listing upserted {"id":"20260404213600257363000000","duration_ms":3}
[2026-04-05T01:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260404213600257363000000","PhotosChangeTimestamp":"2026-04-05 00:58:17","duration_ms":0}
[2026-04-05T01:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260404213600257363000000","duration_ms":0}
[2026-04-05T01:20:03+00:00] INFO Listing processed {"listing_id":"20260404213600257363000000","duration_ms":4}
[2026-04-05T01:20:03+00:00] INFO Listing upserted {"id":"20260331000530197379000000","duration_ms":3}
[2026-04-05T01:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260331000530197379000000","PhotosChangeTimestamp":"2026-04-02 07:16:04","duration_ms":0}
[2026-04-05T01:20:03+00:00] INFO History recorded {"listing_id":"20260331000530197379000000","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-05T01:19:55Z","duration_ms":2}
[2026-04-05T01:20:03+00:00] INFO Listing processed {"listing_id":"20260331000530197379000000","duration_ms":6}
[2026-04-05T01:20:03+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-05T01:20:03+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-05 01:19:55.000","adjusted":true}
[2026-04-05T01:20:03+00:00] INFO Property sync complete {"last_modification":"2026-04-05T01:19:55+00:00"}
[2026-04-05T01:20:03+00:00] INFO Property sync finished {"status":"ok","duration_ms":1318}
