[2026-04-18T03:00:01+00:00] INFO Starting property sync {"start":"2026-04-18T02:39:18+00:00","end":"2026-04-18T05:39:18+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-18T03:00:01+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-18T02:39:18Z and ModificationTimestamp lt 2026-04-18T05:39:18Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-18T03:00:01+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-18T02%3A39%3A18Z+and+ModificationTimestamp+lt+2026-04-18T05%3A39%3A18Z+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-18T03:00:02+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-18T02%3A39%3A18Z+and+ModificationTimestamp+lt+2026-04-18T05%3A39%3A18Z+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":12,"duration_ms":1222}
[2026-04-18T03:00:02+00:00] INFO Processing page {"count":12,"has_next":false}
[2026-04-18T03:00:02+00:00] INFO Listing upserted {"id":"20260224235610884222000000","duration_ms":28}
[2026-04-18T03:00:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260224235610884222000000","PhotosChangeTimestamp":"2026-03-01 16:17:57","duration_ms":1}
[2026-04-18T03:00:02+00:00] INFO History unchanged, skipping {"listing_id":"20260224235610884222000000","duration_ms":1}
[2026-04-18T03:00:02+00:00] INFO Listing processed {"listing_id":"20260224235610884222000000","duration_ms":30}
[2026-04-18T03:00:02+00:00] INFO Listing upserted {"id":"20260417231648389277000000","duration_ms":12}
[2026-04-18T03:00:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260417231648389277000000","PhotosChangeTimestamp":"2026-04-18 01:00:08","duration_ms":1}
[2026-04-18T03:00:02+00:00] INFO History unchanged, skipping {"listing_id":"20260417231648389277000000","duration_ms":1}
[2026-04-18T03:00:02+00:00] INFO Listing processed {"listing_id":"20260417231648389277000000","duration_ms":14}
[2026-04-18T03:00:02+00:00] INFO Listing upserted {"id":"20260411140748197020000000","duration_ms":30}
[2026-04-18T03:00:02+00:00] INFO Photos saved {"listing_id":"20260411140748197020000000","count":46,"duration_ms":23}
[2026-04-18T03:00:02+00:00] INFO History unchanged, skipping {"listing_id":"20260411140748197020000000","duration_ms":1}
[2026-04-18T03:00:02+00:00] INFO Listing processed {"listing_id":"20260411140748197020000000","duration_ms":54}
[2026-04-18T03:00:02+00:00] INFO Listing upserted {"id":"20250825053548302727000000","duration_ms":54}
[2026-04-18T03:00:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20250825053548302727000000","PhotosChangeTimestamp":"2026-02-17 13:06:26","duration_ms":1}
[2026-04-18T03:00:02+00:00] INFO History unchanged, skipping {"listing_id":"20250825053548302727000000","duration_ms":1}
[2026-04-18T03:00:02+00:00] INFO Listing processed {"listing_id":"20250825053548302727000000","duration_ms":56}
[2026-04-18T03:00:03+00:00] INFO Listing upserted {"id":"20260417042854027312000000","duration_ms":179}
[2026-04-18T03:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260417042854027312000000","PhotosChangeTimestamp":"2026-04-17 18:28:18","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20260417042854027312000000","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO Listing processed {"listing_id":"20260417042854027312000000","duration_ms":181}
[2026-04-18T03:00:03+00:00] INFO Listing upserted {"id":"20250621181143326410000000","duration_ms":255}
[2026-04-18T03:00:03+00:00] INFO Photos saved {"listing_id":"20250621181143326410000000","count":69,"duration_ms":68}
[2026-04-18T03:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20250621181143326410000000","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO Listing processed {"listing_id":"20250621181143326410000000","duration_ms":345}
[2026-04-18T03:00:03+00:00] INFO Listing upserted {"id":"20260418000800276087000000","duration_ms":15}
[2026-04-18T03:00:03+00:00] INFO Photos saved {"listing_id":"20260418000800276087000000","count":36,"duration_ms":21}
[2026-04-18T03:00:03+00:00] INFO History recorded {"listing_id":"20260418000800276087000000","event":"Status Coming Soon","price_change":"","price_change_ts":null,"last_update":"2026-04-18T02:53:34Z","duration_ms":90}
[2026-04-18T03:00:03+00:00] INFO Listing processed {"listing_id":"20260418000800276087000000","duration_ms":126}
[2026-04-18T03:00:03+00:00] INFO Listing upserted {"id":"20250723125407621926000000","duration_ms":8}
[2026-04-18T03:00:03+00:00] INFO Photos saved {"listing_id":"20250723125407621926000000","count":42,"duration_ms":27}
[2026-04-18T03:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20250723125407621926000000","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO Listing processed {"listing_id":"20250723125407621926000000","duration_ms":36}
[2026-04-18T03:00:03+00:00] INFO Listing upserted {"id":"20251110211834482057000000","duration_ms":15}
[2026-04-18T03:00:03+00:00] INFO Photos saved {"listing_id":"20251110211834482057000000","count":53,"duration_ms":44}
[2026-04-18T03:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20251110211834482057000000","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO Listing processed {"listing_id":"20251110211834482057000000","duration_ms":61}
[2026-04-18T03:00:03+00:00] INFO Listing upserted {"id":"20260412203047563941000000","duration_ms":14}
[2026-04-18T03:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260412203047563941000000","PhotosChangeTimestamp":"2026-04-18 02:30:22","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20260412203047563941000000","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO Listing processed {"listing_id":"20260412203047563941000000","duration_ms":16}
[2026-04-18T03:00:03+00:00] INFO Listing upserted {"id":"20260415212038345562000000","duration_ms":20}
[2026-04-18T03:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260415212038345562000000","PhotosChangeTimestamp":"2026-04-18 02:37:37","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20260415212038345562000000","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO Listing processed {"listing_id":"20260415212038345562000000","duration_ms":22}
[2026-04-18T03:00:03+00:00] INFO Listing upserted {"id":"20260417184905632856000000","duration_ms":9}
[2026-04-18T03:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260417184905632856000000","PhotosChangeTimestamp":"2026-04-18 02:35:52","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20260417184905632856000000","duration_ms":1}
[2026-04-18T03:00:03+00:00] INFO Listing processed {"listing_id":"20260417184905632856000000","duration_ms":12}
[2026-04-18T03:00:03+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-18T03:00:04+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-18 02:59:14.000","adjusted":true}
[2026-04-18T03:00:04+00:00] INFO Property sync complete {"last_modification":"2026-04-18T02:59:14+00:00"}
[2026-04-18T03:00:04+00:00] INFO Property sync finished {"status":"ok","duration_ms":3100}
