[2026-04-19T12:20:01+00:00] INFO Starting property sync {"start":"2026-04-19T11:59:44+00:00","end":"2026-04-19T14:59:44+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-19T12:20:01+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-19T11:59:44Z and ModificationTimestamp lt 2026-04-19T14:59:44Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-19T12:20:01+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-19T11%3A59%3A44Z+and+ModificationTimestamp+lt+2026-04-19T14%3A59%3A44Z+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-19T12: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-19T11%3A59%3A44Z+and+ModificationTimestamp+lt+2026-04-19T14%3A59%3A44Z+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":984}
[2026-04-19T12:20:02+00:00] INFO Processing page {"count":15,"has_next":false}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260323175832157047000000","duration_ms":18}
[2026-04-19T12:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260323175832157047000000","PhotosChangeTimestamp":"2026-03-30 15:44:39","duration_ms":7}
[2026-04-19T12:20:02+00:00] INFO History recorded {"listing_id":"20260323175832157047000000","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-19T12:03:04Z","duration_ms":12}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260323175832157047000000","duration_ms":38}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260323154619647290000000","duration_ms":15}
[2026-04-19T12:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260323154619647290000000","PhotosChangeTimestamp":"2026-03-25 13:59:28","duration_ms":2}
[2026-04-19T12:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260323154619647290000000","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260323154619647290000000","duration_ms":19}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"610721640","duration_ms":5}
[2026-04-19T12:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"610721640","PhotosChangeTimestamp":"2026-03-16 18:56:40","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO History unchanged, skipping {"listing_id":"610721640","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"610721640","duration_ms":7}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260316212814800418000000","duration_ms":4}
[2026-04-19T12:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260316212814800418000000","PhotosChangeTimestamp":"2026-04-08 21:24:39","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260316212814800418000000","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260316212814800418000000","duration_ms":6}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260211162743422931000000","duration_ms":7}
[2026-04-19T12:20:02+00:00] INFO Photos saved {"listing_id":"20260211162743422931000000","count":32,"duration_ms":7}
[2026-04-19T12:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260211162743422931000000","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260211162743422931000000","duration_ms":15}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260416165138210420000000","duration_ms":8}
[2026-04-19T12:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260416165138210420000000","PhotosChangeTimestamp":"2026-04-19 11:58:20","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260416165138210420000000","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260416165138210420000000","duration_ms":10}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260407140131338261000000","duration_ms":8}
[2026-04-19T12:20:02+00:00] INFO Photos saved {"listing_id":"20260407140131338261000000","count":24,"duration_ms":6}
[2026-04-19T12:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260407140131338261000000","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260407140131338261000000","duration_ms":16}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"610668430","duration_ms":4}
[2026-04-19T12:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"610668430","PhotosChangeTimestamp":"2026-02-26 13:03:44","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO History recorded {"listing_id":"610668430","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-19 12:08:56","last_update":"2026-04-19T12:08:56Z","duration_ms":5}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"610668430","duration_ms":10}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260404182821230019000000","duration_ms":4}
[2026-04-19T12:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260404182821230019000000","PhotosChangeTimestamp":"2026-04-19 07:15:09","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260404182821230019000000","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260404182821230019000000","duration_ms":6}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"606789712","duration_ms":4}
[2026-04-19T12:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"606789712","PhotosChangeTimestamp":"2026-03-21 13:18:07","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO History recorded {"listing_id":"606789712","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-19 12:12:20","last_update":"2026-04-19T12:12:20Z","duration_ms":36}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"606789712","duration_ms":41}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260417140251115222000000","duration_ms":5}
[2026-04-19T12:20:02+00:00] INFO Photos saved {"listing_id":"20260417140251115222000000","count":48,"duration_ms":6}
[2026-04-19T12:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260417140251115222000000","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260417140251115222000000","duration_ms":13}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260418214459240153000000","duration_ms":5}
[2026-04-19T12:20:02+00:00] INFO Photos saved {"listing_id":"20260418214459240153000000","count":13,"duration_ms":4}
[2026-04-19T12:20:02+00:00] INFO History recorded {"listing_id":"20260418214459240153000000","event":"Status Coming Soon","price_change":"","price_change_ts":null,"last_update":"2026-04-19T12:16:05Z","duration_ms":5}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260418214459240153000000","duration_ms":14}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260417144230962261000000","duration_ms":5}
[2026-04-19T12:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260417144230962261000000","PhotosChangeTimestamp":"2026-04-18 16:42:27","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260417144230962261000000","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260417144230962261000000","duration_ms":7}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260326144422953597000000","duration_ms":4}
[2026-04-19T12:20:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260326144422953597000000","PhotosChangeTimestamp":"2026-04-06 14:00:11","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO History unchanged, skipping {"listing_id":"20260326144422953597000000","duration_ms":1}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260326144422953597000000","duration_ms":6}
[2026-04-19T12:20:02+00:00] INFO Listing upserted {"id":"20260417144536010353000000","duration_ms":7}
[2026-04-19T12:20:02+00:00] INFO Photos saved {"listing_id":"20260417144536010353000000","count":49,"duration_ms":8}
[2026-04-19T12:20:02+00:00] INFO History recorded {"listing_id":"20260417144536010353000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-19T12:19:31Z","duration_ms":4}
[2026-04-19T12:20:02+00:00] INFO Listing processed {"listing_id":"20260417144536010353000000","duration_ms":19}
[2026-04-19T12:20:02+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-19T12:20:03+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-19 12:19:31.000","adjusted":true}
[2026-04-19T12:20:03+00:00] INFO Property sync complete {"last_modification":"2026-04-19T12:19:31+00:00"}
[2026-04-19T12:20:03+00:00] INFO Property sync finished {"status":"ok","duration_ms":1941}
