[2026-04-14T23:40:02+00:00] INFO Starting property sync {"start":"2026-04-14T23:19:59+00:00","end":"2026-04-15T02:19:59+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-14T23:40:02+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-14T23:19:59Z and ModificationTimestamp lt 2026-04-15T02:19:59Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-14T23:40:02+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-14T23%3A19%3A59Z+and+ModificationTimestamp+lt+2026-04-15T02%3A19%3A59Z+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-14T23:40:04+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-14T23%3A19%3A59Z+and+ModificationTimestamp+lt+2026-04-15T02%3A19%3A59Z+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":28,"duration_ms":2507}
[2026-04-14T23:40:04+00:00] INFO Processing page {"count":28,"has_next":false}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"20260403030319666453000000","duration_ms":4}
[2026-04-14T23:40:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260403030319666453000000","PhotosChangeTimestamp":"2026-04-14 22:33:50","duration_ms":1}
[2026-04-14T23:40:04+00:00] INFO History unchanged, skipping {"listing_id":"20260403030319666453000000","duration_ms":1}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"20260403030319666453000000","duration_ms":6}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"602343199","duration_ms":4}
[2026-04-14T23:40:04+00:00] INFO Photos saved {"listing_id":"602343199","count":17,"duration_ms":6}
[2026-04-14T23:40:04+00:00] INFO History unchanged, skipping {"listing_id":"602343199","duration_ms":28}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"602343199","duration_ms":39}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"20260217175646457424000000","duration_ms":4}
[2026-04-14T23:40:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260217175646457424000000","PhotosChangeTimestamp":"2026-04-09 19:24:04","duration_ms":1}
[2026-04-14T23:40:04+00:00] INFO History unchanged, skipping {"listing_id":"20260217175646457424000000","duration_ms":9}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"20260217175646457424000000","duration_ms":15}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"20260403183630115508000000","duration_ms":4}
[2026-04-14T23:40:04+00:00] INFO Photos saved {"listing_id":"20260403183630115508000000","count":21,"duration_ms":6}
[2026-04-14T23:40:04+00:00] INFO History unchanged, skipping {"listing_id":"20260403183630115508000000","duration_ms":2}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"20260403183630115508000000","duration_ms":13}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"20260313203420453579000000","duration_ms":4}
[2026-04-14T23:40:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260313203420453579000000","PhotosChangeTimestamp":"2026-04-02 07:15:57","duration_ms":1}
[2026-04-14T23:40:04+00:00] INFO History unchanged, skipping {"listing_id":"20260313203420453579000000","duration_ms":3}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"20260313203420453579000000","duration_ms":8}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"20260407101035021565000000","duration_ms":4}
[2026-04-14T23:40:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260407101035021565000000","PhotosChangeTimestamp":"2026-04-07 14:32:50","duration_ms":1}
[2026-04-14T23:40:04+00:00] INFO History unchanged, skipping {"listing_id":"20260407101035021565000000","duration_ms":2}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"20260407101035021565000000","duration_ms":8}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"609174438","duration_ms":4}
[2026-04-14T23:40:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"609174438","PhotosChangeTimestamp":"2026-02-10 11:44:57","duration_ms":2}
[2026-04-14T23:40:04+00:00] INFO History unchanged, skipping {"listing_id":"609174438","duration_ms":2}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"609174438","duration_ms":8}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"20260414171135675090000000","duration_ms":11}
[2026-04-14T23:40:04+00:00] INFO Photos saved {"listing_id":"20260414171135675090000000","count":45,"duration_ms":6}
[2026-04-14T23:40:04+00:00] INFO History unchanged, skipping {"listing_id":"20260414171135675090000000","duration_ms":0}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"20260414171135675090000000","duration_ms":18}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"20260325165832028874000000","duration_ms":4}
[2026-04-14T23:40:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260325165832028874000000","PhotosChangeTimestamp":"2026-04-14 18:08:54","duration_ms":1}
[2026-04-14T23:40:04+00:00] INFO History unchanged, skipping {"listing_id":"20260325165832028874000000","duration_ms":1}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"20260325165832028874000000","duration_ms":6}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"20250120152702646751000000","duration_ms":4}
[2026-04-14T23:40:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20250120152702646751000000","PhotosChangeTimestamp":"2025-06-27 14:15:13","duration_ms":2}
[2026-04-14T23:40:04+00:00] INFO History recorded {"listing_id":"20250120152702646751000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-14 23:26:21","last_update":"2026-04-14T23:26:21Z","duration_ms":6}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"20250120152702646751000000","duration_ms":12}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"20260313202504206447000000","duration_ms":8}
[2026-04-14T23:40:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260313202504206447000000","PhotosChangeTimestamp":"2026-03-19 20:44:23","duration_ms":2}
[2026-04-14T23:40:04+00:00] INFO History recorded {"listing_id":"20260313202504206447000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-14 23:26:32","last_update":"2026-04-14T23:26:32Z","duration_ms":21}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"20260313202504206447000000","duration_ms":32}
[2026-04-14T23:40:04+00:00] INFO Listing upserted {"id":"608293090","duration_ms":27}
[2026-04-14T23:40:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"608293090","PhotosChangeTimestamp":"2026-01-05 12:12:31","duration_ms":4}
[2026-04-14T23:40:04+00:00] INFO History unchanged, skipping {"listing_id":"608293090","duration_ms":3}
[2026-04-14T23:40:04+00:00] INFO Listing processed {"listing_id":"608293090","duration_ms":35}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260414202844848763000000","duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260414202844848763000000","count":27,"duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO History unchanged, skipping {"listing_id":"20260414202844848763000000","duration_ms":1}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260414202844848763000000","duration_ms":9}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260303145548581058000000","duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260303145548581058000000","PhotosChangeTimestamp":"2026-03-06 01:16:17","duration_ms":1}
[2026-04-14T23:40:05+00:00] INFO History recorded {"listing_id":"20260303145548581058000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-14 23:31:41","last_update":"2026-04-14T23:31:41Z","duration_ms":8}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260303145548581058000000","duration_ms":14}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260319215232596581000000","duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260319215232596581000000","PhotosChangeTimestamp":"2026-03-20 13:29:44","duration_ms":1}
[2026-04-14T23:40:05+00:00] INFO History recorded {"listing_id":"20260319215232596581000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-14 23:33:18","last_update":"2026-04-14T23:33:18Z","duration_ms":6}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260319215232596581000000","duration_ms":12}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260414164240091955000000","duration_ms":6}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260414164240091955000000","count":15,"duration_ms":3}
[2026-04-14T23:40:05+00:00] INFO History recorded {"listing_id":"20260414164240091955000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-14T23:34:35Z","duration_ms":2}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260414164240091955000000","duration_ms":12}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20250925151428092542000000","duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO Photos unchanged, skipping save {"listing_id":"20250925151428092542000000","PhotosChangeTimestamp":"2025-09-30 17:05:05","duration_ms":1}
[2026-04-14T23:40:05+00:00] INFO History recorded {"listing_id":"20250925151428092542000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-14 23:35:03","last_update":"2026-04-14T23:35:03Z","duration_ms":5}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20250925151428092542000000","duration_ms":11}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260326162138279960000000","duration_ms":3}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260326162138279960000000","count":41,"duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO History unchanged, skipping {"listing_id":"20260326162138279960000000","duration_ms":2}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260326162138279960000000","duration_ms":9}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260414221452870374000000","duration_ms":3}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260414221452870374000000","count":14,"duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO History unchanged, skipping {"listing_id":"20260414221452870374000000","duration_ms":1}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260414221452870374000000","duration_ms":8}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260414232812708864000000","duration_ms":5}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260414232812708864000000","count":32,"duration_ms":2}
[2026-04-14T23:40:05+00:00] INFO History recorded {"listing_id":"20260414232812708864000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-14T23:36:22Z","duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260414232812708864000000","duration_ms":11}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260414195202708699000000","duration_ms":7}
[2026-04-14T23:40:05+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260414195202708699000000","PhotosChangeTimestamp":"2026-04-14 23:10:55","duration_ms":1}
[2026-04-14T23:40:05+00:00] INFO History unchanged, skipping {"listing_id":"20260414195202708699000000","duration_ms":0}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260414195202708699000000","duration_ms":8}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260414214404827501000000","duration_ms":3}
[2026-04-14T23:40:05+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260414214404827501000000","PhotosChangeTimestamp":"2026-04-14 23:18:00","duration_ms":1}
[2026-04-14T23:40:05+00:00] INFO History unchanged, skipping {"listing_id":"20260414214404827501000000","duration_ms":0}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260414214404827501000000","duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260406201229244877000000","duration_ms":3}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260406201229244877000000","count":34,"duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO History unchanged, skipping {"listing_id":"20260406201229244877000000","duration_ms":1}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260406201229244877000000","duration_ms":9}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260127132913985009000000","duration_ms":3}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260127132913985009000000","count":65,"duration_ms":5}
[2026-04-14T23:40:05+00:00] INFO History unchanged, skipping {"listing_id":"20260127132913985009000000","duration_ms":1}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260127132913985009000000","duration_ms":9}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260414231534554084000000","duration_ms":4}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260414231534554084000000","count":64,"duration_ms":3}
[2026-04-14T23:40:05+00:00] INFO History recorded {"listing_id":"20260414231534554084000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-14T23:38:50Z","duration_ms":8}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260414231534554084000000","duration_ms":16}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260414221532760253000000","duration_ms":9}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260414221532760253000000","count":1,"duration_ms":2}
[2026-04-14T23:40:05+00:00] INFO History recorded {"listing_id":"20260414221532760253000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-14T23:39:17Z","duration_ms":2}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260414221532760253000000","duration_ms":14}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260414214709318736000000","duration_ms":8}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260414214709318736000000","count":39,"duration_ms":3}
[2026-04-14T23:40:05+00:00] INFO History recorded {"listing_id":"20260414214709318736000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-14T23:39:26Z","duration_ms":2}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260414214709318736000000","duration_ms":14}
[2026-04-14T23:40:05+00:00] INFO Listing upserted {"id":"20260410203448473347000000","duration_ms":8}
[2026-04-14T23:40:05+00:00] INFO Photos saved {"listing_id":"20260410203448473347000000","count":57,"duration_ms":5}
[2026-04-14T23:40:05+00:00] INFO History unchanged, skipping {"listing_id":"20260410203448473347000000","duration_ms":1}
[2026-04-14T23:40:05+00:00] INFO Listing processed {"listing_id":"20260410203448473347000000","duration_ms":15}
[2026-04-14T23:40:05+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-14T23:40:05+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-14 23:39:36.000","adjusted":true}
[2026-04-14T23:40:05+00:00] INFO Property sync complete {"last_modification":"2026-04-14T23:39:36+00:00"}
[2026-04-14T23:40:05+00:00] INFO Property sync finished {"status":"ok","duration_ms":3605}
