[2026-04-12T20:40:01+00:00] INFO Starting property sync {"start":"2026-04-12T20:19:54+00:00","end":"2026-04-12T23:19:54+00:00","offset_fetch_duration_ms":2,"page_size":100,"expand":["Media","OpenHouse","Unit","Room"],"statuses":["Active","Coming Soon","Active Under Contract"],"property_types":["Residential"]}
[2026-04-12T20:40:01+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-12T20:19:54Z and ModificationTimestamp lt 2026-04-12T23:19:54Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-12T20:40:01+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-12T20%3A19%3A54Z+and+ModificationTimestamp+lt+2026-04-12T23%3A19%3A54Z+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-12T20:40:03+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-12T20%3A19%3A54Z+and+ModificationTimestamp+lt+2026-04-12T23%3A19%3A54Z+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":16,"duration_ms":1084}
[2026-04-12T20:40:03+00:00] INFO Processing page {"count":16,"has_next":false}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"610278515","duration_ms":9}
[2026-04-12T20:40:03+00:00] INFO Photos saved {"listing_id":"610278515","count":30,"duration_ms":4}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"610278515","duration_ms":0}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"610278515","duration_ms":15}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20250809164814728037000000","duration_ms":5}
[2026-04-12T20:40:03+00:00] INFO Photos saved {"listing_id":"20250809164814728037000000","count":56,"duration_ms":27}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20250809164814728037000000","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20250809164814728037000000","duration_ms":34}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260112222430005770000000","duration_ms":4}
[2026-04-12T20:40:03+00:00] INFO Photos saved {"listing_id":"20260112222430005770000000","count":34,"duration_ms":5}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260112222430005770000000","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260112222430005770000000","duration_ms":11}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260325205316175824000000","duration_ms":12}
[2026-04-12T20:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260325205316175824000000","PhotosChangeTimestamp":"2026-03-31 22:58:32","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260325205316175824000000","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260325205316175824000000","duration_ms":14}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260320141534233221000000","duration_ms":13}
[2026-04-12T20:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260320141534233221000000","PhotosChangeTimestamp":"2026-03-20 19:25:12","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO History recorded {"listing_id":"20260320141534233221000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 20:27:14","last_update":"2026-04-12T20:27:14Z","duration_ms":6}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260320141534233221000000","duration_ms":21}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260219201524489579000000","duration_ms":4}
[2026-04-12T20:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260219201524489579000000","PhotosChangeTimestamp":"2026-02-20 16:12:51","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260219201524489579000000","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260219201524489579000000","duration_ms":6}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260408125126409250000000","duration_ms":4}
[2026-04-12T20:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260408125126409250000000","PhotosChangeTimestamp":"2026-04-10 13:41:00","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260408125126409250000000","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260408125126409250000000","duration_ms":5}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260410140556277700000000","duration_ms":4}
[2026-04-12T20:40:03+00:00] INFO Photos saved {"listing_id":"20260410140556277700000000","count":19,"duration_ms":6}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260410140556277700000000","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260410140556277700000000","duration_ms":12}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260312151150980705000000","duration_ms":334}
[2026-04-12T20:40:03+00:00] INFO Photos saved {"listing_id":"20260312151150980705000000","count":23,"duration_ms":16}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260312151150980705000000","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260312151150980705000000","duration_ms":351}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260312192046160685000000","duration_ms":6}
[2026-04-12T20:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260312192046160685000000","PhotosChangeTimestamp":"2026-03-18 15:13:01","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260312192046160685000000","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260312192046160685000000","duration_ms":8}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260409160752765592000000","duration_ms":4}
[2026-04-12T20:40:03+00:00] INFO Photos saved {"listing_id":"20260409160752765592000000","count":53,"duration_ms":4}
[2026-04-12T20:40:03+00:00] INFO History recorded {"listing_id":"20260409160752765592000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T20:36:20Z","duration_ms":2}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260409160752765592000000","duration_ms":11}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260409212446305560000000","duration_ms":3}
[2026-04-12T20:40:03+00:00] INFO Photos saved {"listing_id":"20260409212446305560000000","count":98,"duration_ms":7}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260409212446305560000000","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260409212446305560000000","duration_ms":11}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260326140510961455000000","duration_ms":6}
[2026-04-12T20:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260326140510961455000000","PhotosChangeTimestamp":"2026-04-10 16:25:54","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO History recorded {"listing_id":"20260326140510961455000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 20:37:04","last_update":"2026-04-12T20:37:04Z","duration_ms":8}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260326140510961455000000","duration_ms":15}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260222004359545897000000","duration_ms":18}
[2026-04-12T20:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260222004359545897000000","PhotosChangeTimestamp":"2026-04-09 13:24:32","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260222004359545897000000","duration_ms":0}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260222004359545897000000","duration_ms":20}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"609807382","duration_ms":4}
[2026-04-12T20:40:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"609807382","PhotosChangeTimestamp":"2026-04-12 18:19:56","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"609807382","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"609807382","duration_ms":6}
[2026-04-12T20:40:03+00:00] INFO Listing upserted {"id":"20260401194800114102000000","duration_ms":4}
[2026-04-12T20:40:03+00:00] INFO Photos saved {"listing_id":"20260401194800114102000000","count":79,"duration_ms":7}
[2026-04-12T20:40:03+00:00] INFO History unchanged, skipping {"listing_id":"20260401194800114102000000","duration_ms":1}
[2026-04-12T20:40:03+00:00] INFO Listing processed {"listing_id":"20260401194800114102000000","duration_ms":12}
[2026-04-12T20:40:03+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-12T20:40:04+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-12 20:39:57.000","adjusted":true}
[2026-04-12T20:40:04+00:00] INFO Property sync complete {"last_modification":"2026-04-12T20:39:57+00:00"}
[2026-04-12T20:40:04+00:00] INFO Property sync finished {"status":"ok","duration_ms":2350}
