[2026-04-12T19:20:01+00:00] INFO Starting property sync {"start":"2026-04-12T18:59:33+00:00","end":"2026-04-12T21:59:33+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-12T19:20:01+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-12T18:59:33Z and ModificationTimestamp lt 2026-04-12T21:59:33Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-12T19:20:01+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-12T18%3A59%3A33Z+and+ModificationTimestamp+lt+2026-04-12T21%3A59%3A33Z+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-12T19:20:02+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-12T18%3A59%3A33Z+and+ModificationTimestamp+lt+2026-04-12T21%3A59%3A33Z+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":23,"duration_ms":1020}
[2026-04-12T19:20:02+00:00] INFO Processing page {"count":23,"has_next":false}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260119154839772711000000","duration_ms":11}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260119154839772711000000","PhotosChangeTimestamp":"2026-02-02 08:15:30","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History recorded {"listing_id":"20260119154839772711000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 19:00:05","last_update":"2026-04-12T19:00:05Z","duration_ms":13}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260119154839772711000000","duration_ms":25}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260408143444302075000000","duration_ms":4}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260408143444302075000000","PhotosChangeTimestamp":"2026-04-11 00:55:22","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260408143444302075000000","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260408143444302075000000","duration_ms":6}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260408123609407554000000","duration_ms":5}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260408123609407554000000","PhotosChangeTimestamp":"2026-04-10 20:12:20","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260408123609407554000000","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260408123609407554000000","duration_ms":7}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"610819798","duration_ms":5}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"610819798","PhotosChangeTimestamp":"2026-02-28 10:29:25","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"610819798","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"610819798","duration_ms":7}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260407144844150922000000","duration_ms":26}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260407144844150922000000","PhotosChangeTimestamp":"2026-04-10 11:55:51","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260407144844150922000000","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260407144844150922000000","duration_ms":28}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"609341456","duration_ms":8}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"609341456","PhotosChangeTimestamp":"2026-03-04 03:02:53","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"609341456","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"609341456","duration_ms":10}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260303224612428332000000","duration_ms":18}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260303224612428332000000","PhotosChangeTimestamp":"2026-03-04 13:26:46","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History recorded {"listing_id":"20260303224612428332000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 19:08:54","last_update":"2026-04-12T19:08:54Z","duration_ms":5}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260303224612428332000000","duration_ms":25}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260402140010072859000000","duration_ms":4}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260402140010072859000000","PhotosChangeTimestamp":"2026-04-12 18:44:40","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260402140010072859000000","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260402140010072859000000","duration_ms":6}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260401170420443485000000","duration_ms":15}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260401170420443485000000","PhotosChangeTimestamp":"2026-04-08 12:01:12","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260401170420443485000000","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260401170420443485000000","duration_ms":17}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20250807160314346920000000","duration_ms":21}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20250807160314346920000000","PhotosChangeTimestamp":"2026-03-15 20:44:26","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20250807160314346920000000","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20250807160314346920000000","duration_ms":23}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260327121529503175000000","duration_ms":4}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260327121529503175000000","PhotosChangeTimestamp":"2026-04-01 19:13:29","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260327121529503175000000","duration_ms":4}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260327121529503175000000","duration_ms":9}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260410193841609366000000","duration_ms":4}
[2026-04-12T19:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260410193841609366000000","PhotosChangeTimestamp":"2026-04-12 18:58:44","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260410193841609366000000","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260410193841609366000000","duration_ms":6}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260213215121879574000000","duration_ms":4}
[2026-04-12T19:20:02+00:00] INFO Photos saved {"listing_id":"20260213215121879574000000","count":67,"duration_ms":5}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260213215121879574000000","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260213215121879574000000","duration_ms":11}
[2026-04-12T19:20:02+00:00] INFO Listing upserted {"id":"20260111230231782012000000","duration_ms":5}
[2026-04-12T19:20:02+00:00] INFO Photos saved {"listing_id":"20260111230231782012000000","count":42,"duration_ms":6}
[2026-04-12T19:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260111230231782012000000","duration_ms":1}
[2026-04-12T19:20:02+00:00] INFO Listing processed {"listing_id":"20260111230231782012000000","duration_ms":12}
[2026-04-12T19:20:03+00:00] INFO Listing upserted {"id":"20260316224645974851000000","duration_ms":5}
[2026-04-12T19:20:03+00:00] INFO Photos saved {"listing_id":"20260316224645974851000000","count":2,"duration_ms":3}
[2026-04-12T19:20:03+00:00] INFO History recorded {"listing_id":"20260316224645974851000000","event":"Status Coming Soon","price_change":"","price_change_ts":null,"last_update":"2026-04-12T19:13:17Z","duration_ms":3}
[2026-04-12T19:20:03+00:00] INFO Listing processed {"listing_id":"20260316224645974851000000","duration_ms":11}
[2026-04-12T19:20:03+00:00] INFO Listing upserted {"id":"20260221170823778271000000","duration_ms":5}
[2026-04-12T19:20:03+00:00] INFO Photos saved {"listing_id":"20260221170823778271000000","count":67,"duration_ms":7}
[2026-04-12T19:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260221170823778271000000","duration_ms":1}
[2026-04-12T19:20:03+00:00] INFO Listing processed {"listing_id":"20260221170823778271000000","duration_ms":13}
[2026-04-12T19:20:03+00:00] INFO Listing upserted {"id":"20260330171656069702000000","duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260330171656069702000000","PhotosChangeTimestamp":"2026-04-09 00:13:13","duration_ms":1}
[2026-04-12T19:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260330171656069702000000","duration_ms":1}
[2026-04-12T19:20:03+00:00] INFO Listing processed {"listing_id":"20260330171656069702000000","duration_ms":6}
[2026-04-12T19:20:03+00:00] INFO Listing upserted {"id":"20260412180702960582000000","duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO Photos saved {"listing_id":"20260412180702960582000000","count":18,"duration_ms":3}
[2026-04-12T19:20:03+00:00] INFO History recorded {"listing_id":"20260412180702960582000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T19:15:07Z","duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO Listing processed {"listing_id":"20260412180702960582000000","duration_ms":12}
[2026-04-12T19:20:03+00:00] INFO Listing upserted {"id":"20260409030229539147000000","duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO Photos saved {"listing_id":"20260409030229539147000000","count":23,"duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260409030229539147000000","duration_ms":1}
[2026-04-12T19:20:03+00:00] INFO Listing processed {"listing_id":"20260409030229539147000000","duration_ms":10}
[2026-04-12T19:20:03+00:00] INFO Listing upserted {"id":"20260217152544759266000000","duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO Photos saved {"listing_id":"20260217152544759266000000","count":71,"duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260217152544759266000000","duration_ms":1}
[2026-04-12T19:20:03+00:00] INFO Listing processed {"listing_id":"20260217152544759266000000","duration_ms":9}
[2026-04-12T19:20:03+00:00] INFO Listing upserted {"id":"20260402093306929551000000","duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260402093306929551000000","PhotosChangeTimestamp":"2026-04-03 14:47:59","duration_ms":1}
[2026-04-12T19:20:03+00:00] INFO History recorded {"listing_id":"20260402093306929551000000","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-12T19:17:48Z","duration_ms":3}
[2026-04-12T19:20:03+00:00] INFO Listing processed {"listing_id":"20260402093306929551000000","duration_ms":8}
[2026-04-12T19:20:03+00:00] INFO Listing upserted {"id":"20260312185906930834000000","duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260312185906930834000000","PhotosChangeTimestamp":"2026-03-13 17:20:50","duration_ms":1}
[2026-04-12T19:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260312185906930834000000","duration_ms":1}
[2026-04-12T19:20:03+00:00] INFO Listing processed {"listing_id":"20260312185906930834000000","duration_ms":7}
[2026-04-12T19:20:03+00:00] INFO Listing upserted {"id":"20260408184926485309000000","duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO Photos saved {"listing_id":"20260408184926485309000000","count":27,"duration_ms":4}
[2026-04-12T19:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260408184926485309000000","duration_ms":1}
[2026-04-12T19:20:03+00:00] INFO Listing processed {"listing_id":"20260408184926485309000000","duration_ms":9}
[2026-04-12T19:20:03+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-12T19:20:04+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-12 19:18:36.000","adjusted":true}
[2026-04-12T19:20:04+00:00] INFO Property sync complete {"last_modification":"2026-04-12T19:18:36+00:00"}
[2026-04-12T19:20:04+00:00] INFO Property sync finished {"status":"ok","duration_ms":2322}
