[2026-04-19T03:20:02+00:00] INFO Starting property sync {"start":"2026-04-19T02:59:55+00:00","end":"2026-04-19T05:59:55+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-19T03:20:02+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-19T02:59:55Z and ModificationTimestamp lt 2026-04-19T05:59:55Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-19T03:20:02+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-19T02%3A59%3A55Z+and+ModificationTimestamp+lt+2026-04-19T05%3A59%3A55Z+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-19T03: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-19T02%3A59%3A55Z+and+ModificationTimestamp+lt+2026-04-19T05%3A59%3A55Z+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":9,"duration_ms":1280}
[2026-04-19T03:20:03+00:00] INFO Processing page {"count":9,"has_next":false}
[2026-04-19T03:20:03+00:00] INFO Listing upserted {"id":"20260417211148753520000000","duration_ms":23}
[2026-04-19T03:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260417211148753520000000","PhotosChangeTimestamp":"2026-04-19 02:49:28","duration_ms":1}
[2026-04-19T03:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260417211148753520000000","duration_ms":1}
[2026-04-19T03:20:03+00:00] INFO Listing processed {"listing_id":"20260417211148753520000000","duration_ms":25}
[2026-04-19T03:20:03+00:00] INFO Listing upserted {"id":"602585065","duration_ms":9}
[2026-04-19T03:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"602585065","PhotosChangeTimestamp":"2025-08-31 13:34:13","duration_ms":1}
[2026-04-19T03:20:03+00:00] INFO History unchanged, skipping {"listing_id":"602585065","duration_ms":1}
[2026-04-19T03:20:03+00:00] INFO Listing processed {"listing_id":"602585065","duration_ms":11}
[2026-04-19T03:20:03+00:00] INFO Listing upserted {"id":"20260326112550415816000000","duration_ms":23}
[2026-04-19T03:20:03+00:00] INFO Photos saved {"listing_id":"20260326112550415816000000","count":41,"duration_ms":26}
[2026-04-19T03:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260326112550415816000000","duration_ms":1}
[2026-04-19T03:20:03+00:00] INFO Listing processed {"listing_id":"20260326112550415816000000","duration_ms":50}
[2026-04-19T03:20:03+00:00] INFO Listing upserted {"id":"20260418205318209035000000","duration_ms":12}
[2026-04-19T03:20:03+00:00] INFO Photos saved {"listing_id":"20260418205318209035000000","count":73,"duration_ms":22}
[2026-04-19T03:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260418205318209035000000","duration_ms":1}
[2026-04-19T03:20:03+00:00] INFO Listing processed {"listing_id":"20260418205318209035000000","duration_ms":36}
[2026-04-19T03:20:03+00:00] INFO Listing upserted {"id":"20260413185654489170000000","duration_ms":14}
[2026-04-19T03:20:03+00:00] INFO Photos saved {"listing_id":"20260413185654489170000000","count":28,"duration_ms":22}
[2026-04-19T03:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260413185654489170000000","duration_ms":0}
[2026-04-19T03:20:03+00:00] INFO Listing processed {"listing_id":"20260413185654489170000000","duration_ms":37}
[2026-04-19T03:20:03+00:00] INFO Listing upserted {"id":"20260419021149379144000000","duration_ms":24}
[2026-04-19T03:20:03+00:00] INFO Photos saved {"listing_id":"20260419021149379144000000","count":40,"duration_ms":27}
[2026-04-19T03:20:03+00:00] INFO History recorded {"listing_id":"20260419021149379144000000","event":"Status Coming Soon","price_change":"","price_change_ts":null,"last_update":"2026-04-19T03:11:28Z","duration_ms":20}
[2026-04-19T03:20:03+00:00] INFO Listing processed {"listing_id":"20260419021149379144000000","duration_ms":71}
[2026-04-19T03:20:03+00:00] INFO Listing upserted {"id":"20260403222534799985000000","duration_ms":9}
[2026-04-19T03:20:03+00:00] INFO Photos saved {"listing_id":"20260403222534799985000000","count":33,"duration_ms":12}
[2026-04-19T03:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260403222534799985000000","duration_ms":1}
[2026-04-19T03:20:03+00:00] INFO Listing processed {"listing_id":"20260403222534799985000000","duration_ms":22}
[2026-04-19T03:20:03+00:00] INFO Listing upserted {"id":"609344161","duration_ms":16}
[2026-04-19T03:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"609344161","PhotosChangeTimestamp":"2026-01-27 20:16:36","duration_ms":1}
[2026-04-19T03:20:03+00:00] INFO History recorded {"listing_id":"609344161","event":"Status Active Under Contract","price_change":"","price_change_ts":"2026-04-06 14:51:07","last_update":"2026-04-19T03:18:00Z","duration_ms":16}
[2026-04-19T03:20:03+00:00] INFO Listing processed {"listing_id":"609344161","duration_ms":33}
[2026-04-19T03:20:03+00:00] INFO Listing upserted {"id":"20260314032642810130000000","duration_ms":18}
[2026-04-19T03:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260314032642810130000000","PhotosChangeTimestamp":"2026-03-25 15:27:05","duration_ms":1}
[2026-04-19T03:20:03+00:00] INFO History recorded {"listing_id":"20260314032642810130000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-19 03:19:34","last_update":"2026-04-19T03:19:34Z","duration_ms":24}
[2026-04-19T03:20:03+00:00] INFO Listing processed {"listing_id":"20260314032642810130000000","duration_ms":44}
[2026-04-19T03:20:03+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-19T03:20:04+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-19 03:19:34.000","adjusted":true}
[2026-04-19T03:20:04+00:00] INFO Property sync complete {"last_modification":"2026-04-19T03:19:34+00:00"}
[2026-04-19T03:20:04+00:00] INFO Property sync finished {"status":"ok","duration_ms":2378}
