[2026-04-08T07:20:02+00:00] INFO Starting property sync {"start":"2026-04-08T06:35:41+00:00","end":"2026-04-08T09:35:41+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-08T07:20:02+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-08T06:35:41Z and ModificationTimestamp lt 2026-04-08T09:35:41Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-08T07:20:02+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-08T06%3A35%3A41Z+and+ModificationTimestamp+lt+2026-04-08T09%3A35%3A41Z+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-08T07: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-08T06%3A35%3A41Z+and+ModificationTimestamp+lt+2026-04-08T09%3A35%3A41Z+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":1576}
[2026-04-08T07:20:04+00:00] INFO Processing page {"count":23,"has_next":false}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260329173957934504000000","duration_ms":1958}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260329173957934504000000","count":92,"duration_ms":6}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260329173957934504000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:04Z","duration_ms":3}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260329173957934504000000","duration_ms":1967}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260401180211816309000000","duration_ms":8}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260401180211816309000000","count":32,"duration_ms":6}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260401180211816309000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:04Z","duration_ms":7}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260401180211816309000000","duration_ms":22}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260402181947964952000000","duration_ms":9}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260402181947964952000000","count":45,"duration_ms":51}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260402181947964952000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:04Z","duration_ms":3}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260402181947964952000000","duration_ms":63}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260318093852736918000000","duration_ms":14}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260318093852736918000000","count":3,"duration_ms":13}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260318093852736918000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:05Z","duration_ms":2}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260318093852736918000000","duration_ms":30}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260331120741914746000000","duration_ms":3}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260331120741914746000000","count":71,"duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260331120741914746000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:05Z","duration_ms":5}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260331120741914746000000","duration_ms":12}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260402181212483611000000","duration_ms":7}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260402181212483611000000","count":77,"duration_ms":14}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260402181212483611000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:05Z","duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260402181212483611000000","duration_ms":25}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260404152917891657000000","duration_ms":3}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260404152917891657000000","count":11,"duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260404152917891657000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:05Z","duration_ms":2}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260404152917891657000000","duration_ms":10}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260406171842070233000000","duration_ms":17}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260406171842070233000000","count":3,"duration_ms":19}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260406171842070233000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:05Z","duration_ms":3}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260406171842070233000000","duration_ms":40}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260406180206454438000000","duration_ms":3}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260406180206454438000000","count":22,"duration_ms":7}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260406180206454438000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:05Z","duration_ms":5}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260406180206454438000000","duration_ms":16}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260406183532471657000000","duration_ms":19}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260406183532471657000000","count":12,"duration_ms":23}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260406183532471657000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:05Z","duration_ms":3}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260406183532471657000000","duration_ms":47}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260406201229244877000000","duration_ms":30}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260406201229244877000000","count":5,"duration_ms":5}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260406201229244877000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:05Z","duration_ms":2}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260406201229244877000000","duration_ms":38}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260321161532051712000000","duration_ms":5}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260321161532051712000000","count":39,"duration_ms":16}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260321161532051712000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260321161532051712000000","duration_ms":25}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260325201426837431000000","duration_ms":12}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260325201426837431000000","count":79,"duration_ms":18}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260325201426837431000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":17}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260325201426837431000000","duration_ms":48}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260326235957153606000000","duration_ms":8}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260326235957153606000000","count":61,"duration_ms":8}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260326235957153606000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":5}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260326235957153606000000","duration_ms":22}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260329201631641595000000","duration_ms":9}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260329201631641595000000","count":1,"duration_ms":25}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260329201631641595000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":3}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260329201631641595000000","duration_ms":37}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260330112958282874000000","duration_ms":6}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260330112958282874000000","count":82,"duration_ms":5}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260330112958282874000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":3}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260330112958282874000000","duration_ms":15}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260401203734115370000000","duration_ms":5}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260401203734115370000000","count":87,"duration_ms":13}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260401203734115370000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":13}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260401203734115370000000","duration_ms":32}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260402161716657818000000","duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260402161716657818000000","count":24,"duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260402161716657818000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":2}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260402161716657818000000","duration_ms":11}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260403003832127073000000","duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260403003832127073000000","count":52,"duration_ms":5}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260403003832127073000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":2}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260403003832127073000000","duration_ms":11}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260406152557551978000000","duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260406152557551978000000","count":78,"duration_ms":5}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260406152557551978000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":15}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260406152557551978000000","duration_ms":24}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260406210228629660000000","duration_ms":16}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260406210228629660000000","count":1,"duration_ms":5}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260406210228629660000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260406210228629660000000","duration_ms":24}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260407010845319885000000","duration_ms":22}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260407010845319885000000","count":59,"duration_ms":9}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260407010845319885000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:06Z","duration_ms":3}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260407010845319885000000","duration_ms":34}
[2026-04-08T07:20:06+00:00] INFO Listing upserted {"id":"20260403135256590109000000","duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO Photos saved {"listing_id":"20260403135256590109000000","count":27,"duration_ms":6}
[2026-04-08T07:20:06+00:00] INFO History recorded {"listing_id":"20260403135256590109000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-08T07:16:07Z","duration_ms":4}
[2026-04-08T07:20:06+00:00] INFO Listing processed {"listing_id":"20260403135256590109000000","duration_ms":14}
[2026-04-08T07:20:06+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-08T07:20:07+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-08 07:16:07.000","adjusted":true}
[2026-04-08T07:20:07+00:00] INFO Property sync complete {"last_modification":"2026-04-08T07:16:07+00:00"}
[2026-04-08T07:20:07+00:00] INFO Property sync finished {"status":"ok","duration_ms":5482}
