b6df4dbb92
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>
78 lines
2.0 KiB
PHP
Executable File
78 lines
2.0 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* Helper functions to work with Providers API.
|
|
*
|
|
* @since 1.8.0
|
|
*/
|
|
|
|
/**
|
|
* Get an array of all the active provider addons.
|
|
*
|
|
* @since 1.4.7
|
|
*
|
|
* @return array
|
|
*/
|
|
function wpforms_get_providers_available() {
|
|
|
|
return (array) apply_filters( 'wpforms_providers_available', [] );
|
|
}
|
|
|
|
/**
|
|
* Get options for all providers.
|
|
*
|
|
* @since 1.4.7
|
|
*
|
|
* @param string $provider Define a single provider to get options for this one only.
|
|
*
|
|
* @return array
|
|
*/
|
|
function wpforms_get_providers_options( $provider = '' ) {
|
|
|
|
$options = get_option( 'wpforms_providers', [] );
|
|
$provider = sanitize_key( $provider );
|
|
$data = $options;
|
|
|
|
if ( ! empty( $provider ) ) {
|
|
$data = $options[ $provider ] ?? [];
|
|
}
|
|
|
|
return (array) apply_filters( 'wpforms_get_providers_options', $data, $provider );
|
|
}
|
|
|
|
/**
|
|
* Update options for all providers.
|
|
*
|
|
* @since 1.4.7
|
|
*
|
|
* @param string $provider Provider slug.
|
|
* @param array|false $options If false is passed - provider will be removed. Otherwise saved.
|
|
* @param string $key Optional key to identify which connection to update. If empty - generate a new one.
|
|
*/
|
|
function wpforms_update_providers_options( $provider, $options, $key = '' ) {
|
|
|
|
$providers = wpforms_get_providers_options();
|
|
$id = ! empty( $key ) ? $key : uniqid();
|
|
$provider = sanitize_key( $provider );
|
|
|
|
if ( $options ) {
|
|
$providers[ $provider ][ $id ] = (array) $options;
|
|
} else {
|
|
unset( $providers[ $provider ] );
|
|
}
|
|
|
|
/**
|
|
* A collection of service providers used for dependency injection or service registration
|
|
* within the application.
|
|
*
|
|
* @since 1.9.6
|
|
*
|
|
* @param array $providers List of all registered providers.
|
|
* @param string $provider Provider slug.
|
|
* @param array $options Provider options data. If false - provider will be removed.
|
|
* @param string $id Provider connection ID.
|
|
*/
|
|
$providers = (array) apply_filters( 'wpforms_update_providers_options', $providers, $provider, $options, $id );
|
|
|
|
update_option( 'wpforms_providers', $providers );
|
|
}
|