[2026-04-15T11:00:01+00:00] INFO Starting property sync {"start":"2026-04-15T10:39:48+00:00","end":"2026-04-15T13:39:48+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-15T11:00:01+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-15T10:39:48Z and ModificationTimestamp lt 2026-04-15T13:39:48Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-15T11:00:01+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-15T10%3A39%3A48Z+and+ModificationTimestamp+lt+2026-04-15T13%3A39%3A48Z+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-15T11: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-15T10%3A39%3A48Z+and+ModificationTimestamp+lt+2026-04-15T13%3A39%3A48Z+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":9,"duration_ms":1017}
[2026-04-15T11:00:02+00:00] INFO Processing page {"count":9,"has_next":false}
[2026-04-15T11:00:02+00:00] INFO Listing upserted {"id":"610213766","duration_ms":51}
[2026-04-15T11:00:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"610213766","PhotosChangeTimestamp":"2026-02-16 19:01:25","duration_ms":28}
[2026-04-15T11:00:02+00:00] INFO History unchanged, skipping {"listing_id":"610213766","duration_ms":42}
[2026-04-15T11:00:02+00:00] INFO Listing processed {"listing_id":"610213766","duration_ms":122}
[2026-04-15T11:00:02+00:00] INFO Listing upserted {"id":"20260328224238496520000000","duration_ms":17}
[2026-04-15T11:00:02+00:00] INFO Photos saved {"listing_id":"20260328224238496520000000","count":71,"duration_ms":112}
[2026-04-15T11:00:02+00:00] INFO History unchanged, skipping {"listing_id":"20260328224238496520000000","duration_ms":0}
[2026-04-15T11:00:02+00:00] INFO Listing processed {"listing_id":"20260328224238496520000000","duration_ms":130}
[2026-04-15T11:00:02+00:00] INFO Listing upserted {"id":"20251229214159794275000000","duration_ms":51}
[2026-04-15T11:00:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20251229214159794275000000","PhotosChangeTimestamp":"2025-12-29 21:51:22","duration_ms":1}
[2026-04-15T11:00:02+00:00] INFO History unchanged, skipping {"listing_id":"20251229214159794275000000","duration_ms":1}
[2026-04-15T11:00:02+00:00] INFO Listing processed {"listing_id":"20251229214159794275000000","duration_ms":53}
[2026-04-15T11:00:02+00:00] INFO Listing upserted {"id":"20250808022718690979000000","duration_ms":78}
[2026-04-15T11:00:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20250808022718690979000000","PhotosChangeTimestamp":"2026-03-12 19:17:00","duration_ms":15}
[2026-04-15T11:00:02+00:00] INFO History recorded {"listing_id":"20250808022718690979000000","event":"Status Active Under Contract","price_change":"","price_change_ts":"2026-03-12 19:30:37","last_update":"2026-04-15T10:50:13Z","duration_ms":105}
[2026-04-15T11:00:02+00:00] INFO Listing processed {"listing_id":"20250808022718690979000000","duration_ms":199}
[2026-04-15T11:00:02+00:00] INFO Listing upserted {"id":"20260311221955570897000000","duration_ms":65}
[2026-04-15T11:00:02+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260311221955570897000000","PhotosChangeTimestamp":"2026-03-11 23:22:13","duration_ms":74}
[2026-04-15T11:00:02+00:00] INFO History recorded {"listing_id":"20260311221955570897000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-15T10:51:31Z","duration_ms":35}
[2026-04-15T11:00:02+00:00] INFO Listing processed {"listing_id":"20260311221955570897000000","duration_ms":175}
[2026-04-15T11:00:03+00:00] INFO Listing upserted {"id":"20260305152922029380000000","duration_ms":18}
[2026-04-15T11:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260305152922029380000000","PhotosChangeTimestamp":"2026-03-13 23:13:54","duration_ms":1}
[2026-04-15T11:00:03+00:00] INFO History recorded {"listing_id":"20260305152922029380000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-15 10:52:39","last_update":"2026-04-15T10:52:39Z","duration_ms":51}
[2026-04-15T11:00:03+00:00] INFO Listing processed {"listing_id":"20260305152922029380000000","duration_ms":70}
[2026-04-15T11:00:03+00:00] INFO Listing upserted {"id":"20260412142724256123000000","duration_ms":46}
[2026-04-15T11:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260412142724256123000000","PhotosChangeTimestamp":"2026-04-13 22:09:18","duration_ms":1}
[2026-04-15T11:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20260412142724256123000000","duration_ms":1}
[2026-04-15T11:00:03+00:00] INFO Listing processed {"listing_id":"20260412142724256123000000","duration_ms":48}
[2026-04-15T11:00:03+00:00] INFO Listing upserted {"id":"20260328232619101642000000","duration_ms":19}
[2026-04-15T11:00:03+00:00] INFO Photos saved {"listing_id":"20260328232619101642000000","count":102,"duration_ms":19}
[2026-04-15T11:00:03+00:00] INFO History recorded {"listing_id":"20260328232619101642000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-15T10:59:46Z","duration_ms":11}
[2026-04-15T11:00:03+00:00] INFO Listing processed {"listing_id":"20260328232619101642000000","duration_ms":49}
[2026-04-15T11:00:03+00:00] INFO Listing upserted {"id":"20260319132342187229000000","duration_ms":18}
[2026-04-15T11:00:03+00:00] INFO Photos saved {"listing_id":"20260319132342187229000000","count":83,"duration_ms":52}
[2026-04-15T11:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20260319132342187229000000","duration_ms":1}
[2026-04-15T11:00:03+00:00] INFO Listing processed {"listing_id":"20260319132342187229000000","duration_ms":71}
[2026-04-15T11:00:03+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-15T11:00:04+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-15 10:59:48.000","adjusted":true}
[2026-04-15T11:00:04+00:00] INFO Property sync complete {"last_modification":"2026-04-15T10:59:48+00:00"}
[2026-04-15T11:00:04+00:00] INFO Property sync finished {"status":"ok","duration_ms":2985}
