Snapshot: MLS sync fixes, image refresh, plugin/theme updates

MLS plugin fixes from this session:
- Fix silent insert failures: location column NOT NULL was rejecting wpdb->insert calls,
  causing ~18k new properties since Dec 2025 to be lost. Inserts now build raw SQL
  with ST_PointFromText so the spatial column is populated atomically.
- Auto-refresh expired media URLs in MLS_Media_Handler::fetch_and_cache(), guarded by
  a property-level GET_LOCK so concurrent fetches share one API refresh.
- Normalize WP_Error to null in mls_get_property_image() so callers can rely on the
  documented string|null contract.
- Support comma-separated property_type filters in MLS_Query and MLS_Cluster so the
  homepage "View All Commercial" link (?property_type=Commercial+Sale,Land,Farm)
  actually filters correctly.
- Incremental sync now looks back 10 minutes past the latest modification timestamp
  as a safety margin against missed records.
- Smart sync exits silently (info-level, not warning) when a full sync is in progress.

Operational:
- New cron: weekly full sync Sundays at 3 AM (/usr/local/bin/mls-full-sync).
- New cron: hourly 2GB cap on mls-thumbnails/ and cache/transformed-images/
  (/usr/local/bin/mls-image-cache-cap).
- Logrotate config for wp-content/debug.log (2-day retention, daily rotation,
  delaycompress).

Repo policy:
- CLAUDE.md updated with explicit "commit everything except build artifacts" policy.
- .gitignore: untrack runtime image caches and debug.log rotations.

Other modifications in this snapshot are pre-existing in-flight theme/plugin/db_content_updates work.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
root
2026-04-29 15:32:23 +00:00
parent 57b752f54e
commit b6df4dbb92
5385 changed files with 838580 additions and 2416 deletions
@@ -0,0 +1,7 @@
<svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">
<g id="Avatar">
<rect x="0.5" y="0.5" width="31" height="31" rx="15.5" fill="white"/>
<rect x="0.5" y="0.5" width="31" height="31" rx="15.5" stroke="#FFE6A6"/>
<path id="exclamation-circle" d="M18.1399 20.2856V22.7856C18.1399 23.1763 17.8162 23.4999 17.4256 23.4999H14.5684C14.1778 23.4999 13.8542 23.1763 13.8542 22.7856V20.2856C13.8542 19.895 14.1778 19.5714 14.5684 19.5714H17.4256C17.8162 19.5714 18.1399 19.895 18.1399 20.2856ZM18.4747 8.49993L18.1622 17.0714C18.151 17.462 17.8162 17.7856 17.4256 17.7856H14.5684C14.1778 17.7856 13.843 17.462 13.8318 17.0714L13.5193 8.49993C13.5082 8.1093 13.8207 7.78564 14.2113 7.78564H17.7827C18.1734 7.78564 18.4859 8.1093 18.4747 8.49993Z" fill="#E6A700"/>
</g>
</svg>

After

Width:  |  Height:  |  Size: 810 B