[2026-04-15T04:00:02+00:00] INFO Starting property sync {"start":"2026-04-15T03:39:38+00:00","end":"2026-04-15T06:39:38+00:00","offset_fetch_duration_ms":1,"page_size":100,"expand":["Media","OpenHouse","Unit","Room"],"statuses":["Active","Coming Soon","Active Under Contract"],"property_types":["Residential"]}
[2026-04-15T04:00:02+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-15T03:39:38Z and ModificationTimestamp lt 2026-04-15T06:39:38Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-15T04:00:02+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-15T03%3A39%3A38Z+and+ModificationTimestamp+lt+2026-04-15T06%3A39%3A38Z+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-15T04: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-15T03%3A39%3A38Z+and+ModificationTimestamp+lt+2026-04-15T06%3A39%3A38Z+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":11,"duration_ms":1184}
[2026-04-15T04:00:03+00:00] INFO Processing page {"count":11,"has_next":false}
[2026-04-15T04:00:03+00:00] INFO Listing upserted {"id":"20260218030904805775000000","duration_ms":96}
[2026-04-15T04:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260218030904805775000000","PhotosChangeTimestamp":"2026-04-10 23:26:46","duration_ms":7}
[2026-04-15T04:00:03+00:00] INFO History recorded {"listing_id":"20260218030904805775000000","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-15T03:44:20Z","duration_ms":65}
[2026-04-15T04:00:03+00:00] INFO Listing processed {"listing_id":"20260218030904805775000000","duration_ms":168}
[2026-04-15T04:00:03+00:00] INFO Listing upserted {"id":"20260406133434201299000000","duration_ms":16}
[2026-04-15T04:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260406133434201299000000","PhotosChangeTimestamp":"2026-04-08 22:59:06","duration_ms":3}
[2026-04-15T04:00:03+00:00] INFO History recorded {"listing_id":"20260406133434201299000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-15 03:48:50","last_update":"2026-04-15T03:48:50Z","duration_ms":207}
[2026-04-15T04:00:03+00:00] INFO Listing processed {"listing_id":"20260406133434201299000000","duration_ms":227}
[2026-04-15T04:00:03+00:00] INFO Listing upserted {"id":"20260415021645384214000000","duration_ms":39}
[2026-04-15T04:00:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260415021645384214000000","PhotosChangeTimestamp":"2026-04-15 03:09:26","duration_ms":0}
[2026-04-15T04:00:03+00:00] INFO History unchanged, skipping {"listing_id":"20260415021645384214000000","duration_ms":1}
[2026-04-15T04:00:03+00:00] INFO Listing processed {"listing_id":"20260415021645384214000000","duration_ms":41}
[2026-04-15T04:00:03+00:00] INFO Listing upserted {"id":"20260412231137990553000000","duration_ms":15}
[2026-04-15T04:00:03+00:00] INFO Photos saved {"listing_id":"20260412231137990553000000","count":74,"duration_ms":20}
[2026-04-15T04:00:03+00:00] INFO History recorded {"listing_id":"20260412231137990553000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-15T03:52:16Z","duration_ms":31}
[2026-04-15T04:00:03+00:00] INFO Listing processed {"listing_id":"20260412231137990553000000","duration_ms":66}
[2026-04-15T04:00:03+00:00] INFO Listing upserted {"id":"20260204111310056181000000","duration_ms":74}
[2026-04-15T04:00:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260204111310056181000000","PhotosChangeTimestamp":"2026-03-06 22:41:25","duration_ms":27}
[2026-04-15T04:00:04+00:00] INFO History unchanged, skipping {"listing_id":"20260204111310056181000000","duration_ms":1}
[2026-04-15T04:00:04+00:00] INFO Listing processed {"listing_id":"20260204111310056181000000","duration_ms":104}
[2026-04-15T04:00:04+00:00] INFO Listing upserted {"id":"20260414221532760253000000","duration_ms":71}
[2026-04-15T04:00:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260414221532760253000000","PhotosChangeTimestamp":"2026-04-15 02:54:42","duration_ms":1}
[2026-04-15T04:00:04+00:00] INFO History unchanged, skipping {"listing_id":"20260414221532760253000000","duration_ms":1}
[2026-04-15T04:00:04+00:00] INFO Listing processed {"listing_id":"20260414221532760253000000","duration_ms":73}
[2026-04-15T04:00:04+00:00] INFO Listing upserted {"id":"20260312203215421108000000","duration_ms":12}
[2026-04-15T04:00:04+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260312203215421108000000","PhotosChangeTimestamp":"2026-03-12 23:19:17","duration_ms":1}
[2026-04-15T04:00:04+00:00] INFO History unchanged, skipping {"listing_id":"20260312203215421108000000","duration_ms":1}
[2026-04-15T04:00:04+00:00] INFO Listing processed {"listing_id":"20260312203215421108000000","duration_ms":15}
[2026-04-15T04:00:04+00:00] INFO Listing upserted {"id":"20260402182712892590000000","duration_ms":78}
[2026-04-15T04:00:04+00:00] INFO Photos saved {"listing_id":"20260402182712892590000000","count":25,"duration_ms":340}
[2026-04-15T04:00:04+00:00] INFO History unchanged, skipping {"listing_id":"20260402182712892590000000","duration_ms":1}
[2026-04-15T04:00:04+00:00] INFO Listing processed {"listing_id":"20260402182712892590000000","duration_ms":420}
[2026-04-15T04:00:04+00:00] INFO Listing upserted {"id":"20260414181741315414000000","duration_ms":16}
[2026-04-15T04:00:04+00:00] INFO Photos saved {"listing_id":"20260414181741315414000000","count":15,"duration_ms":47}
[2026-04-15T04:00:04+00:00] INFO History unchanged, skipping {"listing_id":"20260414181741315414000000","duration_ms":1}
[2026-04-15T04:00:04+00:00] INFO Listing processed {"listing_id":"20260414181741315414000000","duration_ms":65}
[2026-04-15T04:00:04+00:00] INFO Listing upserted {"id":"20251013145730947371000000","duration_ms":14}
[2026-04-15T04:00:04+00:00] INFO Photos saved {"listing_id":"20251013145730947371000000","count":43,"duration_ms":108}
[2026-04-15T04:00:04+00:00] INFO History unchanged, skipping {"listing_id":"20251013145730947371000000","duration_ms":34}
[2026-04-15T04:00:04+00:00] INFO Listing processed {"listing_id":"20251013145730947371000000","duration_ms":156}
[2026-04-15T04:00:04+00:00] INFO Listing upserted {"id":"20260411193401460939000000","duration_ms":66}
[2026-04-15T04:00:04+00:00] INFO Photos saved {"listing_id":"20260411193401460939000000","count":26,"duration_ms":65}
[2026-04-15T04:00:04+00:00] INFO History unchanged, skipping {"listing_id":"20260411193401460939000000","duration_ms":6}
[2026-04-15T04:00:04+00:00] INFO Listing processed {"listing_id":"20260411193401460939000000","duration_ms":137}
[2026-04-15T04:00:04+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-15T04:00:05+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-15 04:00:01.000","adjusted":true}
[2026-04-15T04:00:05+00:00] INFO Property sync complete {"last_modification":"2026-04-15T04:00:01+00:00"}
[2026-04-15T04:00:05+00:00] INFO Property sync finished {"status":"ok","duration_ms":3651}
