[2026-04-19T10:20:02+00:00] INFO Starting closed-listing sync {"start":"2026-04-18T00:00:00+00:00","end":"2026-04-28T00:00:00+00:00","page_size":500,"expand":["Media","OpenHouse","Unit","Room"],"statuses":["Closed"],"property_types":["Residential"]}
[2026-04-19T10:20:02+00:00] INFO Spark close-date filter constructed {"filter":"CloseDate ge 2026-04-18 and CloseDate le 2026-04-28 and (StandardStatus eq 'Closed') and (PropertyType eq 'Residential')"}
[2026-04-19T10:20:02+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=CloseDate+ge+2026-04-18+and+CloseDate+le+2026-04-28+and+%28StandardStatus+eq+%27Closed%27%29+and+%28PropertyType+eq+%27Residential%27%29&%24orderby=CloseDate+asc%2CListingKey+asc&%24top=500&%24expand=Media%2COpenHouse%2CUnit%2CRoom"}
[2026-04-19T10:20:04+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=CloseDate+ge+2026-04-18+and+CloseDate+le+2026-04-28+and+%28StandardStatus+eq+%27Closed%27%29+and+%28PropertyType+eq+%27Residential%27%29&%24orderby=CloseDate+asc%2CListingKey+asc&%24top=500&%24expand=Media%2COpenHouse%2CUnit%2CRoom","count":7,"duration_ms":1729}
[2026-04-19T10:20:04+00:00] INFO Processing closed page {"count":7,"has_next":false}
[2026-04-19T10:20:04+00:00] INFO Listing upserted {"id":"20260418180633077775000000","duration_ms":53}
[2026-04-19T10:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260418180633077775000000","PhotosChangeTimestamp":"2026-04-18 18:23:36","duration_ms":1}
[2026-04-19T10:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260418180633077775000000","duration_ms":1}
[2026-04-19T10:20:04+00:00] INFO Listing processed {"listing_id":"20260418180633077775000000","duration_ms":55}
[2026-04-19T10:20:04+00:00] INFO Listing upserted {"id":"20260418182535913747000000","duration_ms":3}
[2026-04-19T10:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260418182535913747000000","PhotosChangeTimestamp":"2026-04-18 18:33:11","duration_ms":0}
[2026-04-19T10:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260418182535913747000000","duration_ms":1}
[2026-04-19T10:20:04+00:00] INFO Listing processed {"listing_id":"20260418182535913747000000","duration_ms":5}
[2026-04-19T10:20:04+00:00] INFO Listing upserted {"id":"20260418183643858862000000","duration_ms":3}
[2026-04-19T10:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260418183643858862000000","PhotosChangeTimestamp":"2026-04-18 18:46:39","duration_ms":0}
[2026-04-19T10:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260418183643858862000000","duration_ms":1}
[2026-04-19T10:20:04+00:00] INFO Listing processed {"listing_id":"20260418183643858862000000","duration_ms":4}
[2026-04-19T10:20:04+00:00] INFO Listing upserted {"id":"20260418184751299635000000","duration_ms":3}
[2026-04-19T10:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260418184751299635000000","PhotosChangeTimestamp":"2026-04-18 18:53:32","duration_ms":0}
[2026-04-19T10:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260418184751299635000000","duration_ms":0}
[2026-04-19T10:20:04+00:00] INFO Listing processed {"listing_id":"20260418184751299635000000","duration_ms":4}
[2026-04-19T10:20:04+00:00] INFO Listing upserted {"id":"20260418185802919188000000","duration_ms":2}
[2026-04-19T10:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260418185802919188000000","PhotosChangeTimestamp":"2026-04-18 19:06:49","duration_ms":0}
[2026-04-19T10:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260418185802919188000000","duration_ms":0}
[2026-04-19T10:20:04+00:00] INFO Listing processed {"listing_id":"20260418185802919188000000","duration_ms":3}
[2026-04-19T10:20:04+00:00] INFO Listing upserted {"id":"20260418190828934946000000","duration_ms":2}
[2026-04-19T10:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260418190828934946000000","PhotosChangeTimestamp":"2026-04-18 19:21:42","duration_ms":0}
[2026-04-19T10:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260418190828934946000000","duration_ms":0}
[2026-04-19T10:20:04+00:00] INFO Listing processed {"listing_id":"20260418190828934946000000","duration_ms":3}
[2026-04-19T10:20:04+00:00] INFO Listing upserted {"id":"20260418194558092821000000","duration_ms":2}
[2026-04-19T10:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260418194558092821000000","PhotosChangeTimestamp":"2026-04-18 19:57:48","duration_ms":0}
[2026-04-19T10:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260418194558092821000000","duration_ms":0}
[2026-04-19T10:20:04+00:00] INFO Listing processed {"listing_id":"20260418194558092821000000","duration_ms":3}
[2026-04-19T10:20:04+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-19T10:20:04+00:00] INFO Offset updated {"script":"Sold Listing","raw":"2026-04-18","adjusted":false}
[2026-04-19T10:20:04+00:00] INFO Closed-listing sync complete {"last_close_date":"2026-04-18"}
