[2026-04-14T09:00:02+00:00] INFO Starting property sync {"start":"2026-04-14T08:37:37+00:00","end":"2026-04-14T11:37:37+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-14T09:00:02+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-14T08:37:37Z and ModificationTimestamp lt 2026-04-14T11:37:37Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-14T09:00:02+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-14T08%3A37%3A37Z+and+ModificationTimestamp+lt+2026-04-14T11%3A37%3A37Z+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-14T09:00:03+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-14T08%3A37%3A37Z+and+ModificationTimestamp+lt+2026-04-14T11%3A37%3A37Z+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":3,"duration_ms":830}
[2026-04-14T09:00:03+00:00] INFO Processing page {"count":3,"has_next":false}
[2026-04-14T09:00:03+00:00] INFO Listing upserted {"id":"20251102025835473330000000","duration_ms":58}
[2026-04-14T09:00:03+00:00] INFO Photos saved {"listing_id":"20251102025835473330000000","count":8,"duration_ms":188}
[2026-04-14T09:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20251102025835473330000000","duration_ms":1}
[2026-04-14T09:00:03+00:00] INFO Listing processed {"listing_id":"20251102025835473330000000","duration_ms":248}
[2026-04-14T09:00:03+00:00] INFO Listing upserted {"id":"20260408210023157696000000","duration_ms":11}
[2026-04-14T09:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260408210023157696000000","PhotosChangeTimestamp":"2026-04-08 23:04:54","duration_ms":1}
[2026-04-14T09:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20260408210023157696000000","duration_ms":1}
[2026-04-14T09:00:03+00:00] INFO Listing processed {"listing_id":"20260408210023157696000000","duration_ms":13}
[2026-04-14T09:00:03+00:00] INFO Listing upserted {"id":"20260414080729162945000000","duration_ms":52}
[2026-04-14T09:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260414080729162945000000","PhotosChangeTimestamp":"2026-04-14 08:35:44","duration_ms":1}
[2026-04-14T09:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20260414080729162945000000","duration_ms":1}
[2026-04-14T09:00:03+00:00] INFO Listing processed {"listing_id":"20260414080729162945000000","duration_ms":54}
[2026-04-14T09:00:03+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-14T09:00:04+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-14 08:57:05.000","adjusted":true}
[2026-04-14T09:00:04+00:00] INFO Property sync complete {"last_modification":"2026-04-14T08:57:05+00:00"}
[2026-04-14T09:00:04+00:00] INFO Property sync finished {"status":"ok","duration_ms":1859}
