[2026-04-16T02:20:02+00:00] INFO Starting property sync {"start":"2026-04-16T01:59:40+00:00","end":"2026-04-16T04:59:40+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-16T02:20:02+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-16T01:59:40Z and ModificationTimestamp lt 2026-04-16T04:59:40Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-16T02:20:02+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-16T01%3A59%3A40Z+and+ModificationTimestamp+lt+2026-04-16T04%3A59%3A40Z+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-16T02:20:03+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-16T01%3A59%3A40Z+and+ModificationTimestamp+lt+2026-04-16T04%3A59%3A40Z+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":20,"duration_ms":1060}
[2026-04-16T02:20:03+00:00] INFO Processing page {"count":20,"has_next":false}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260416012827542091000000","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260416012827542091000000","PhotosChangeTimestamp":"2026-04-16 01:51:10","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260416012827542091000000","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260416012827542091000000","duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20240424205919391337000000","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20240424205919391337000000","PhotosChangeTimestamp":"2024-07-12 23:50:56","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20240424205919391337000000","duration_ms":0}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20240424205919391337000000","duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260414125451431285000000","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260414125451431285000000","count":43,"duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260414125451431285000000","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260414125451431285000000","duration_ms":9}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20251204173810232724000000","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20251204173810232724000000","count":60,"duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20251204173810232724000000","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20251204173810232724000000","duration_ms":7}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260401154036017586000000","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260401154036017586000000","PhotosChangeTimestamp":"2026-04-02 05:12:10","duration_ms":0}
[2026-04-16T02:20:03+00:00] INFO History recorded {"listing_id":"20260401154036017586000000","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-16T02:06:15Z","duration_ms":2}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260401154036017586000000","duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"610450320","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"610450320","PhotosChangeTimestamp":"2026-03-25 11:59:16","duration_ms":2}
[2026-04-16T02:20:03+00:00] INFO History recorded {"listing_id":"610450320","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-16T02:07:40Z","duration_ms":2}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"610450320","duration_ms":8}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20251018011853499271000000","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20251018011853499271000000","PhotosChangeTimestamp":"2026-02-05 02:21:00","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20251018011853499271000000","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20251018011853499271000000","duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260415031135920275000000","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260415031135920275000000","count":50,"duration_ms":8}
[2026-04-16T02:20:03+00:00] INFO History recorded {"listing_id":"20260415031135920275000000","event":"Status Coming Soon","price_change":"","price_change_ts":null,"last_update":"2026-04-16T02:12:08Z","duration_ms":2}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260415031135920275000000","duration_ms":14}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260212162742787414000000","duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260212162742787414000000","PhotosChangeTimestamp":"2026-02-12 16:48:41","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO History recorded {"listing_id":"20260212162742787414000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-16 02:12:54","last_update":"2026-04-16T02:12:54Z","duration_ms":12}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260212162742787414000000","duration_ms":19}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260416014059154724000000","duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260416014059154724000000","count":40,"duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO History recorded {"listing_id":"20260416014059154724000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-16T02:13:22Z","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260416014059154724000000","duration_ms":13}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260321023701921567000000","duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260321023701921567000000","PhotosChangeTimestamp":"2026-04-09 13:02:02","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO History recorded {"listing_id":"20260321023701921567000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-16 02:13:23","last_update":"2026-04-16T02:13:23Z","duration_ms":6}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260321023701921567000000","duration_ms":10}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260409144207950190000000","duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260409144207950190000000","count":48,"duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260409144207950190000000","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260409144207950190000000","duration_ms":9}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260416012924772203000000","duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260416012924772203000000","count":46,"duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO History recorded {"listing_id":"20260416012924772203000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-16T02:15:07Z","duration_ms":2}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260416012924772203000000","duration_ms":10}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260415115801592292000000","duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260415115801592292000000","PhotosChangeTimestamp":"2026-04-16 01:47:45","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260415115801592292000000","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260415115801592292000000","duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260406145743886219000000","duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260406145743886219000000","count":36,"duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260406145743886219000000","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260406145743886219000000","duration_ms":10}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260415235605148553000000","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260415235605148553000000","count":68,"duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO History recorded {"listing_id":"20260415235605148553000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-16T02:15:37Z","duration_ms":3}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260415235605148553000000","duration_ms":10}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260414131956556125000000","duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260414131956556125000000","count":37,"duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260414131956556125000000","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260414131956556125000000","duration_ms":10}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260414114111553334000000","duration_ms":5}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260414114111553334000000","count":24,"duration_ms":2}
[2026-04-16T02:20:03+00:00] INFO History recorded {"listing_id":"20260414114111553334000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-16T02:18:32Z","duration_ms":2}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260414114111553334000000","duration_ms":10}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260416012121842110000000","duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260416012121842110000000","count":43,"duration_ms":2}
[2026-04-16T02:20:03+00:00] INFO History recorded {"listing_id":"20260416012121842110000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-16T02:18:32Z","duration_ms":2}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260416012121842110000000","duration_ms":9}
[2026-04-16T02:20:03+00:00] INFO Listing upserted {"id":"20260410222124605101000000","duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO Photos saved {"listing_id":"20260410222124605101000000","count":29,"duration_ms":4}
[2026-04-16T02:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260410222124605101000000","duration_ms":1}
[2026-04-16T02:20:03+00:00] INFO Listing processed {"listing_id":"20260410222124605101000000","duration_ms":9}
[2026-04-16T02:20:03+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-16T02:20:04+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-16 02:19:39.000","adjusted":true}
[2026-04-16T02:20:04+00:00] INFO Property sync complete {"last_modification":"2026-04-16T02:19:39+00:00"}
[2026-04-16T02:20:04+00:00] INFO Property sync finished {"status":"ok","duration_ms":1791}
