[2026-04-12T17:20:01+00:00] INFO Starting property sync {"start":"2026-04-12T16:59:33+00:00","end":"2026-04-12T19:59:33+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-12T17:20:01+00:00] INFO Spark filter constructed {"filter":"ModificationTimestamp gt 2026-04-12T16:59:33Z and ModificationTimestamp lt 2026-04-12T19:59:33Z and (StandardStatus eq 'Active' or StandardStatus eq 'Coming Soon' or StandardStatus eq 'Active Under Contract') and (PropertyType eq 'Residential')"}
[2026-04-12T17:20:01+00:00] INFO Spark initial request {"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-12T16%3A59%3A33Z+and+ModificationTimestamp+lt+2026-04-12T19%3A59%3A33Z+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-12T17:20:03+00:00] INFO Spark API response {"status":200,"url":"https://replication.sparkapi.com/Version/3/Reso/OData/Property?%24filter=ModificationTimestamp+gt+2026-04-12T16%3A59%3A33Z+and+ModificationTimestamp+lt+2026-04-12T19%3A59%3A33Z+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":36,"duration_ms":1276}
[2026-04-12T17:20:03+00:00] INFO Processing page {"count":36,"has_next":false}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260209124655355786000000","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260209124655355786000000","PhotosChangeTimestamp":"2026-02-11 16:27:06","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History recorded {"listing_id":"20260209124655355786000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 17:00:39","last_update":"2026-04-12T17:00:39Z","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260209124655355786000000","duration_ms":16}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20251116201219715087000000","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20251116201219715087000000","PhotosChangeTimestamp":"2025-12-11 00:07:49","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20251116201219715087000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20251116201219715087000000","duration_ms":9}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260204202940883077000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos saved {"listing_id":"20260204202940883077000000","count":43,"duration_ms":11}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260204202940883077000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260204202940883077000000","duration_ms":17}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260323155355058909000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260323155355058909000000","PhotosChangeTimestamp":"2026-04-07 16:42:55","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260323155355058909000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260323155355058909000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260319165311810793000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260319165311810793000000","PhotosChangeTimestamp":"2026-04-07 00:38:07","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260319165311810793000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260319165311810793000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260412154909983355000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260412154909983355000000","PhotosChangeTimestamp":"2026-04-12 16:30:02","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260412154909983355000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260412154909983355000000","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260330203447062270000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260330203447062270000000","PhotosChangeTimestamp":"2026-04-12 16:49:19","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260330203447062270000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260330203447062270000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260407023909006228000000","duration_ms":15}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260407023909006228000000","PhotosChangeTimestamp":"2026-04-12 16:19:35","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260407023909006228000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260407023909006228000000","duration_ms":17}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260409111945367013000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260409111945367013000000","PhotosChangeTimestamp":"2026-04-12 16:29:47","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260409111945367013000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260409111945367013000000","duration_ms":9}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260411160955919268000000","duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260411160955919268000000","PhotosChangeTimestamp":"2026-04-12 16:54:43","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260411160955919268000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260411160955919268000000","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260412143659521786000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260412143659521786000000","PhotosChangeTimestamp":"2026-04-12 16:47:10","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260412143659521786000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260412143659521786000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"607741695","duration_ms":10}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"607741695","PhotosChangeTimestamp":"2025-12-16 18:39:11","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"607741695","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"607741695","duration_ms":12}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"609488130","duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"609488130","PhotosChangeTimestamp":"2026-02-03 16:21:52","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History recorded {"listing_id":"609488130","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 17:06:05","last_update":"2026-04-12T17:06:05Z","duration_ms":14}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"609488130","duration_ms":20}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260409200430224609000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260409200430224609000000","PhotosChangeTimestamp":"2026-04-09 20:19:29","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History recorded {"listing_id":"20260409200430224609000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 17:06:49","last_update":"2026-04-12T17:06:49Z","duration_ms":15}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260409200430224609000000","duration_ms":22}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20251217223850778850000000","duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20251217223850778850000000","PhotosChangeTimestamp":"2026-04-12 16:29:32","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20251217223850778850000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20251217223850778850000000","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260411122233297362000000","duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260411122233297362000000","PhotosChangeTimestamp":"2026-04-12 16:58:22","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260411122233297362000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260411122233297362000000","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"610519753","duration_ms":22}
[2026-04-12T17:20:03+00:00] INFO Photos saved {"listing_id":"610519753","count":44,"duration_ms":8}
[2026-04-12T17:20:03+00:00] INFO History recorded {"listing_id":"610519753","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 17:09:42","last_update":"2026-04-12T17:09:42Z","duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"610519753","duration_ms":35}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260124183441143352000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260124183441143352000000","PhotosChangeTimestamp":"2026-04-11 16:09:49","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260124183441143352000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260124183441143352000000","duration_ms":8}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260211214314495309000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260211214314495309000000","PhotosChangeTimestamp":"2026-02-13 20:48:45","duration_ms":2}
[2026-04-12T17:20:03+00:00] INFO History recorded {"listing_id":"20260211214314495309000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 17:10:39","last_update":"2026-04-12T17:10:39Z","duration_ms":19}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260211214314495309000000","duration_ms":28}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260409010537615943000000","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Photos saved {"listing_id":"20260409010537615943000000","count":45,"duration_ms":10}
[2026-04-12T17:20:03+00:00] INFO History recorded {"listing_id":"20260409010537615943000000","event":"Price Decreased","price_change":"Price Decreased","price_change_ts":"2026-04-12 17:12:12","last_update":"2026-04-12T17:12:12Z","duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260409010537615943000000","duration_ms":23}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260410211939118878000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260410211939118878000000","PhotosChangeTimestamp":"2026-04-10 21:48:27","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260410211939118878000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260410211939118878000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260212210915387815000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260212210915387815000000","PhotosChangeTimestamp":"2026-02-14 14:09:56","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260212210915387815000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260212210915387815000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260410135207996797000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos saved {"listing_id":"20260410135207996797000000","count":31,"duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260410135207996797000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260410135207996797000000","duration_ms":10}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260410135451903676000000","duration_ms":79}
[2026-04-12T17:20:03+00:00] INFO Photos saved {"listing_id":"20260410135451903676000000","count":76,"duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO History recorded {"listing_id":"20260410135451903676000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T17:15:19Z","duration_ms":3}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260410135451903676000000","duration_ms":87}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"609807382","duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO Photos saved {"listing_id":"609807382","count":18,"duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"609807382","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"609807382","duration_ms":11}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260411163741439289000000","duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO Photos saved {"listing_id":"20260411163741439289000000","count":57,"duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO History recorded {"listing_id":"20260411163741439289000000","event":"Status Active","price_change":"","price_change_ts":null,"last_update":"2026-04-12T17:16:17Z","duration_ms":3}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260411163741439289000000","duration_ms":12}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260322184333665913000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260322184333665913000000","PhotosChangeTimestamp":"2026-03-26 00:45:28","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260322184333665913000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260322184333665913000000","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260408002951012586000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260408002951012586000000","PhotosChangeTimestamp":"2026-04-08 22:11:54","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260408002951012586000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260408002951012586000000","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260412152812798265000000","duration_ms":11}
[2026-04-12T17:20:03+00:00] INFO Photos saved {"listing_id":"20260412152812798265000000","count":25,"duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260412152812798265000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260412152812798265000000","duration_ms":16}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20251108123454696684000000","duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20251108123454696684000000","PhotosChangeTimestamp":"2025-11-08 17:30:31","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20251108123454696684000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20251108123454696684000000","duration_ms":7}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260406015731926780000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260406015731926780000000","PhotosChangeTimestamp":"2026-04-08 15:15:44","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History recorded {"listing_id":"20260406015731926780000000","event":"Status Active Under Contract","price_change":"","price_change_ts":null,"last_update":"2026-04-12T17:18:53Z","duration_ms":3}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260406015731926780000000","duration_ms":8}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260411205501409120000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260411205501409120000000","PhotosChangeTimestamp":"2026-04-11 21:56:40","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260411205501409120000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260411205501409120000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260408184926485309000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos saved {"listing_id":"20260408184926485309000000","count":19,"duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260408184926485309000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260408184926485309000000","duration_ms":9}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260331200123947999000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260331200123947999000000","PhotosChangeTimestamp":"2026-04-04 16:56:54","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260331200123947999000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260331200123947999000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260327193429737463000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos unchanged, skipping save {"listing_id":"20260327193429737463000000","PhotosChangeTimestamp":"2026-03-29 16:57:29","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260327193429737463000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260327193429737463000000","duration_ms":6}
[2026-04-12T17:20:03+00:00] INFO Listing upserted {"id":"20260115224424924805000000","duration_ms":4}
[2026-04-12T17:20:03+00:00] INFO Photos saved {"listing_id":"20260115224424924805000000","count":13,"duration_ms":5}
[2026-04-12T17:20:03+00:00] INFO History unchanged, skipping {"listing_id":"20260115224424924805000000","duration_ms":1}
[2026-04-12T17:20:03+00:00] INFO Listing processed {"listing_id":"20260115224424924805000000","duration_ms":10}
[2026-04-12T17:20:03+00:00] INFO Spark nextLink {"nextLink":null}
[2026-04-12T17:20:04+00:00] INFO Offset updated {"script":"Listing","raw":"2026-04-12 17:19:55.000","adjusted":true}
[2026-04-12T17:20:04+00:00] INFO Property sync complete {"last_modification":"2026-04-12T17:19:55+00:00"}
[2026-04-12T17:20:04+00:00] INFO Property sync finished {"status":"ok","duration_ms":2372}
