[2026-04-17T11:20:02+00:00] INFO Starting property sync {"start":"2026-04-17T10:59:50+00:00","end":"2026-04-17T13:59:50+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-17T11:20:02+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-17T10:59:50Z and ModificationTimestamp lt 2026-04-17T13:59:50Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-17T11:20:02+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-17T10%3A59%3A50Z+and+ModificationTimestamp+lt+2026-04-17T13%3A59%3A50Z+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-17T11:20:04+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-17T10%3A59%3A50Z+and+ModificationTimestamp+lt+2026-04-17T13%3A59%3A50Z+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":15,"duration_ms":1873}
[2026-04-17T11:20:04+00:00] INFO Processing page {"count":15,"has_next":false}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260416003401312787000000","duration_ms":14}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260416003401312787000000","PhotosChangeTimestamp":"2026-04-17 10:27:09","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260416003401312787000000","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260416003401312787000000","duration_ms":16}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260416133604439685000000","duration_ms":7}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260416133604439685000000","PhotosChangeTimestamp":"2026-04-17 10:35:11","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260416133604439685000000","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260416133604439685000000","duration_ms":9}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260406154906102831000000","duration_ms":6}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260406154906102831000000","PhotosChangeTimestamp":"2026-04-14 01:53:50","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260406154906102831000000","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260406154906102831000000","duration_ms":8}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"603873646","duration_ms":5}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"603873646","PhotosChangeTimestamp":"2025-09-15 11:38:36","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History unchanged, skipping {"listing_id":"603873646","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"603873646","duration_ms":7}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260217110947343289000000","duration_ms":4}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260217110947343289000000","PhotosChangeTimestamp":"2026-03-24 13:06:46","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260217110947343289000000","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260217110947343289000000","duration_ms":6}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260407113745649012000000","duration_ms":5}
[2026-04-17T11:20:04+00:00] INFO Photos saved {"listing_id":"20260407113745649012000000","count":54,"duration_ms":5}
[2026-04-17T11:20:04+00:00] INFO History recorded {"listing_id":"20260407113745649012000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-17T11:10:55Z","duration_ms":4}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260407113745649012000000","duration_ms":14}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20251008091104977979000000","duration_ms":5}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20251008091104977979000000","PhotosChangeTimestamp":"2026-03-15 15:27:37","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20251008091104977979000000","duration_ms":2}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20251008091104977979000000","duration_ms":9}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260407175638937922000000","duration_ms":6}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260407175638937922000000","PhotosChangeTimestamp":"2026-04-12 13:45:07","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History recorded {"listing_id":"20260407175638937922000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-17 11:12:22","last_update":"2026-04-17T11:12:22Z","duration_ms":16}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260407175638937922000000","duration_ms":24}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260413142859701209000000","duration_ms":5}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260413142859701209000000","PhotosChangeTimestamp":"2026-04-13 14:51:20","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260413142859701209000000","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260413142859701209000000","duration_ms":6}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260415214407622595000000","duration_ms":4}
[2026-04-17T11:20:04+00:00] INFO Photos saved {"listing_id":"20260415214407622595000000","count":44,"duration_ms":3}
[2026-04-17T11:20:04+00:00] INFO History recorded {"listing_id":"20260415214407622595000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-17T11:12:55Z","duration_ms":2}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260415214407622595000000","duration_ms":10}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260404161531893520000000","duration_ms":6}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260404161531893520000000","PhotosChangeTimestamp":"2026-04-04 18:16:11","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History recorded {"listing_id":"20260404161531893520000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-17 11:15:07","last_update":"2026-04-17T11:15:07Z","duration_ms":7}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260404161531893520000000","duration_ms":14}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260323180052806452000000","duration_ms":4}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260323180052806452000000","PhotosChangeTimestamp":"2026-04-13 15:57:12","duration_ms":2}
[2026-04-17T11:20:04+00:00] INFO History recorded {"listing_id":"20260323180052806452000000","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-17T11:17:06Z","duration_ms":2}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260323180052806452000000","duration_ms":9}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260414150335573711000000","duration_ms":4}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260414150335573711000000","PhotosChangeTimestamp":"2026-04-16 21:02:44","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260414150335573711000000","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260414150335573711000000","duration_ms":6}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"20260416164547676266000000","duration_ms":12}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260416164547676266000000","PhotosChangeTimestamp":"2026-04-16 18:12:53","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History unchanged, skipping {"listing_id":"20260416164547676266000000","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"20260416164547676266000000","duration_ms":14}
[2026-04-17T11:20:04+00:00] INFO Listing upserted {"id":"604298097","duration_ms":16}
[2026-04-17T11:20:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"604298097","PhotosChangeTimestamp":"2026-04-07 19:49:39","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO History unchanged, skipping {"listing_id":"604298097","duration_ms":1}
[2026-04-17T11:20:04+00:00] INFO Listing processed {"listing_id":"604298097","duration_ms":18}
[2026-04-17T11:20:04+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-17T11:20:05+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-17 11:19:05.000","adjusted":true}
[2026-04-17T11:20:05+00:00] INFO Property sync complete {"last_modification":"2026-04-17T11:19:05+00:00"}
[2026-04-17T11:20:05+00:00] INFO Property sync finished {"status":"ok","duration_ms":3099}
