[2026-04-13T00:00:03+00:00] INFO Starting property sync {"start":"2026-04-12T23:38:11+00:00","end":"2026-04-13T02:38:11+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-13T00:00:03+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-12T23:38:11Z and ModificationTimestamp lt 2026-04-13T02:38:11Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-13T00:00:03+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-12T23%3A38%3A11Z+and+ModificationTimestamp+lt+2026-04-13T02%3A38%3A11Z+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-13T00:00:04+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-12T23%3A38%3A11Z+and+ModificationTimestamp+lt+2026-04-13T02%3A38%3A11Z+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":16,"duration_ms":1342}
[2026-04-13T00:00:04+00:00] INFO Processing page {"count":16,"has_next":false}
[2026-04-13T00:00:04+00:00] INFO Listing upserted {"id":"20260412214430891491000000","duration_ms":45}
[2026-04-13T00:00:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260412214430891491000000","PhotosChangeTimestamp":"2026-04-12 23:27:14","duration_ms":1}
[2026-04-13T00:00:04+00:00] INFO History unchanged, skipping {"listing_id":"20260412214430891491000000","duration_ms":1}
[2026-04-13T00:00:04+00:00] INFO Listing processed {"listing_id":"20260412214430891491000000","duration_ms":48}
[2026-04-13T00:00:04+00:00] INFO Listing upserted {"id":"609947059","duration_ms":15}
[2026-04-13T00:00:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"609947059","PhotosChangeTimestamp":"2026-02-09 16:21:44","duration_ms":1}
[2026-04-13T00:00:04+00:00] INFO History recorded {"listing_id":"609947059","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 23:45:03","last_update":"2026-04-12T23:45:03Z","duration_ms":31}
[2026-04-13T00:00:04+00:00] INFO Listing processed {"listing_id":"609947059","duration_ms":48}
[2026-04-13T00:00:04+00:00] INFO Listing upserted {"id":"20260411002633121868000000","duration_ms":20}
[2026-04-13T00:00:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260411002633121868000000","PhotosChangeTimestamp":"2026-04-11 11:13:18","duration_ms":1}
[2026-04-13T00:00:04+00:00] INFO History recorded {"listing_id":"20260411002633121868000000","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-12T23:45:43Z","duration_ms":15}
[2026-04-13T00:00:04+00:00] INFO Listing processed {"listing_id":"20260411002633121868000000","duration_ms":36}
[2026-04-13T00:00:04+00:00] INFO Listing upserted {"id":"20260410140556277700000000","duration_ms":26}
[2026-04-13T00:00:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260410140556277700000000","PhotosChangeTimestamp":"2026-04-12 20:23:25","duration_ms":1}
[2026-04-13T00:00:04+00:00] INFO History unchanged, skipping {"listing_id":"20260410140556277700000000","duration_ms":1}
[2026-04-13T00:00:04+00:00] INFO Listing processed {"listing_id":"20260410140556277700000000","duration_ms":28}
[2026-04-13T00:00:04+00:00] INFO Listing upserted {"id":"20260412225913766897000000","duration_ms":19}
[2026-04-13T00:00:04+00:00] INFO Photos saved {"listing_id":"20260412225913766897000000","count":1,"duration_ms":19}
[2026-04-13T00:00:04+00:00] INFO History recorded {"listing_id":"20260412225913766897000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T23:50:13Z","duration_ms":46}
[2026-04-13T00:00:04+00:00] INFO Listing processed {"listing_id":"20260412225913766897000000","duration_ms":85}
[2026-04-13T00:00:04+00:00] INFO Listing upserted {"id":"20260408165035846016000000","duration_ms":13}
[2026-04-13T00:00:04+00:00] INFO Photos saved {"listing_id":"20260408165035846016000000","count":30,"duration_ms":22}
[2026-04-13T00:00:04+00:00] INFO History recorded {"listing_id":"20260408165035846016000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T23:50:14Z","duration_ms":16}
[2026-04-13T00:00:04+00:00] INFO Listing processed {"listing_id":"20260408165035846016000000","duration_ms":51}
[2026-04-13T00:00:04+00:00] INFO Listing upserted {"id":"20260412224611295212000000","duration_ms":18}
[2026-04-13T00:00:04+00:00] INFO Photos saved {"listing_id":"20260412224611295212000000","count":1,"duration_ms":21}
[2026-04-13T00:00:04+00:00] INFO History recorded {"listing_id":"20260412224611295212000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T23:50:21Z","duration_ms":121}
[2026-04-13T00:00:04+00:00] INFO Listing processed {"listing_id":"20260412224611295212000000","duration_ms":161}
[2026-04-13T00:00:04+00:00] INFO Listing upserted {"id":"20260312181328829039000000","duration_ms":19}
[2026-04-13T00:00:05+00:00] INFO Photos saved {"listing_id":"20260312181328829039000000","count":26,"duration_ms":41}
[2026-04-13T00:00:05+00:00] INFO History recorded {"listing_id":"20260312181328829039000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 23:51:42","last_update":"2026-04-12T23:51:42Z","duration_ms":51}
[2026-04-13T00:00:05+00:00] INFO Listing processed {"listing_id":"20260312181328829039000000","duration_ms":111}
[2026-04-13T00:00:05+00:00] INFO Listing upserted {"id":"20260411203642493916000000","duration_ms":19}
[2026-04-13T00:00:05+00:00] INFO Photos saved {"listing_id":"20260411203642493916000000","count":25,"duration_ms":20}
[2026-04-13T00:00:05+00:00] INFO History recorded {"listing_id":"20260411203642493916000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T23:53:15Z","duration_ms":9}
[2026-04-13T00:00:05+00:00] INFO Listing processed {"listing_id":"20260411203642493916000000","duration_ms":49}
[2026-04-13T00:00:05+00:00] INFO Listing upserted {"id":"20260412212924908704000000","duration_ms":12}
[2026-04-13T00:00:05+00:00] INFO Photos saved {"listing_id":"20260412212924908704000000","count":82,"duration_ms":40}
[2026-04-13T00:00:05+00:00] INFO History unchanged, skipping {"listing_id":"20260412212924908704000000","duration_ms":1}
[2026-04-13T00:00:05+00:00] INFO Listing processed {"listing_id":"20260412212924908704000000","duration_ms":53}
[2026-04-13T00:00:05+00:00] INFO Listing upserted {"id":"20260318174511550817000000","duration_ms":16}
[2026-04-13T00:00:05+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260318174511550817000000","PhotosChangeTimestamp":"2026-03-25 13:52:11","duration_ms":1}
[2026-04-13T00:00:05+00:00] INFO History recorded {"listing_id":"20260318174511550817000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T23:53:56Z","duration_ms":20}
[2026-04-13T00:00:05+00:00] INFO Listing processed {"listing_id":"20260318174511550817000000","duration_ms":38}
[2026-04-13T00:00:05+00:00] INFO Listing upserted {"id":"20260410125228719276000000","duration_ms":16}
[2026-04-13T00:00:05+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260410125228719276000000","PhotosChangeTimestamp":"2026-04-12 23:25:46","duration_ms":1}
[2026-04-13T00:00:05+00:00] INFO History unchanged, skipping {"listing_id":"20260410125228719276000000","duration_ms":1}
[2026-04-13T00:00:05+00:00] INFO Listing processed {"listing_id":"20260410125228719276000000","duration_ms":19}
[2026-04-13T00:00:05+00:00] INFO Listing upserted {"id":"610385253","duration_ms":8}
[2026-04-13T00:00:05+00:00] INFO Photos unchanged, skipping save {"listing_id":"610385253","PhotosChangeTimestamp":"2026-03-05 15:19:37","duration_ms":1}
[2026-04-13T00:00:05+00:00] INFO History recorded {"listing_id":"610385253","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-12T23:53:57Z","duration_ms":12}
[2026-04-13T00:00:05+00:00] INFO Listing processed {"listing_id":"610385253","duration_ms":22}
[2026-04-13T00:00:05+00:00] INFO Listing upserted {"id":"611023318","duration_ms":7}
[2026-04-13T00:00:05+00:00] INFO Photos saved {"listing_id":"611023318","count":33,"duration_ms":21}
[2026-04-13T00:00:05+00:00] INFO History unchanged, skipping {"listing_id":"611023318","duration_ms":1}
[2026-04-13T00:00:05+00:00] INFO Listing processed {"listing_id":"611023318","duration_ms":30}
[2026-04-13T00:00:05+00:00] INFO Listing upserted {"id":"20260412230935844530000000","duration_ms":9}
[2026-04-13T00:00:05+00:00] INFO Photos saved {"listing_id":"20260412230935844530000000","count":15,"duration_ms":7}
[2026-04-13T00:00:05+00:00] INFO History recorded {"listing_id":"20260412230935844530000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T23:56:53Z","duration_ms":5}
[2026-04-13T00:00:05+00:00] INFO Listing processed {"listing_id":"20260412230935844530000000","duration_ms":21}
[2026-04-13T00:00:05+00:00] INFO Listing upserted {"id":"20260409190414768120000000","duration_ms":270}
[2026-04-13T00:00:05+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260409190414768120000000","PhotosChangeTimestamp":"2026-04-09 20:32:32","duration_ms":1}
[2026-04-13T00:00:05+00:00] INFO History unchanged, skipping {"listing_id":"20260409190414768120000000","duration_ms":1}
[2026-04-13T00:00:05+00:00] INFO Listing processed {"listing_id":"20260409190414768120000000","duration_ms":273}
[2026-04-13T00:00:05+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-13T00:00:08+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-12 23:57:20.000","adjusted":true}
[2026-04-13T00:00:08+00:00] INFO Property sync complete {"last_modification":"2026-04-12T23:57:20+00:00"}
[2026-04-13T00:00:08+00:00] INFO Property sync finished {"status":"ok","duration_ms":5335}
