X7ROOT File Manager
Current Path:
/home/u126090504/domains/tncm.org.in/public_html/wp-includes
home
/
u126090504
/
domains
/
tncm.org.in
/
public_html
/
wp-includes
/
📁
..
📁
ID3
📁
IXR
📁
PHPMailer
📁
Requests
📁
SimplePie
📁
Text
📁
abilities-api
📄
abilities-api.php
(23.8 KB)
📄
abilities.php
(7.82 KB)
📄
admin-bar.php
(38.39 KB)
📁
ai-client
📄
ai-client.php
(2.49 KB)
📁
assets
📄
atomlib.php
(11.9 KB)
📄
author-template.php
(19.38 KB)
📁
block-bindings
📄
block-bindings.php
(7.35 KB)
📄
block-editor.php
(28.05 KB)
📄
block-i18n.json
(316 B)
📁
block-patterns
📄
block-patterns.php
(15.24 KB)
📁
block-supports
📄
block-template-utils.php
(61.33 KB)
📄
block-template.php
(17.83 KB)
📁
blocks
📄
blocks.php
(116.64 KB)
📄
bookmark-template.php
(12.47 KB)
📄
bookmark.php
(15.07 KB)
📁
build
📄
cache-compat.php
(10.76 KB)
📄
cache.php
(13.17 KB)
📄
canonical.php
(33.83 KB)
📄
capabilities.php
(42.61 KB)
📄
category-template.php
(55.65 KB)
📄
category.php
(12.53 KB)
📁
certificates
📄
class-IXR.php
(2.55 KB)
📄
class-avif-info.php
(29.3 KB)
📄
class-feed.php
(539 B)
📄
class-http.php
(367 B)
📄
class-json.php
(42.65 KB)
📄
class-oembed.php
(401 B)
📄
class-phpass.php
(6.61 KB)
📄
class-phpmailer.php
(664 B)
📄
class-pop3.php
(20.63 KB)
📄
class-requests.php
(2.18 KB)
📄
class-simplepie.php
(453 B)
📄
class-smtp.php
(457 B)
📄
class-snoopy.php
(36.83 KB)
📄
class-walker-category-dropdown.php
(2.41 KB)
📄
class-walker-category.php
(8.28 KB)
📄
class-walker-comment.php
(13.89 KB)
📄
class-walker-nav-menu.php
(11.76 KB)
📄
class-walker-page-dropdown.php
(2.65 KB)
📄
class-walker-page.php
(7.43 KB)
📄
class-wp-admin-bar.php
(17.58 KB)
📄
class-wp-ajax-response.php
(5.14 KB)
📄
class-wp-application-passwords.php
(16.7 KB)
📄
class-wp-block-bindings-registry.php
(8.07 KB)
📄
class-wp-block-bindings-source.php
(2.92 KB)
📄
class-wp-block-editor-context.php
(1.32 KB)
📄
class-wp-block-list.php
(4.6 KB)
📄
class-wp-block-metadata-registry.php
(11.57 KB)
📄
class-wp-block-parser-block.php
(2.5 KB)
📄
class-wp-block-parser-frame.php
(1.95 KB)
📄
class-wp-block-parser.php
(11.25 KB)
📄
class-wp-block-pattern-categories-registry.php
(4.28 KB)
📄
class-wp-block-patterns-registry.php
(10.07 KB)
📄
class-wp-block-processor.php
(68.32 KB)
📄
class-wp-block-styles-registry.php
(6.27 KB)
📄
class-wp-block-supports.php
(6.4 KB)
📄
class-wp-block-template.php
(1.99 KB)
📄
class-wp-block-templates-registry.php
(6.91 KB)
📄
class-wp-block-type-registry.php
(4.91 KB)
📄
class-wp-block-type.php
(16.83 KB)
📄
class-wp-block.php
(24.14 KB)
📄
class-wp-classic-to-block-menu-converter.php
(3.93 KB)
📄
class-wp-comment-query.php
(47.49 KB)
📄
class-wp-comment.php
(9.15 KB)
📄
class-wp-connector-registry.php
(14.07 KB)
📄
class-wp-customize-control.php
(25.51 KB)
📄
class-wp-customize-manager.php
(198.13 KB)
📄
class-wp-customize-nav-menus.php
(56.61 KB)
📄
class-wp-customize-panel.php
(10.46 KB)
📄
class-wp-customize-section.php
(10.95 KB)
📄
class-wp-customize-setting.php
(29.26 KB)
📄
class-wp-customize-widgets.php
(70.89 KB)
📄
class-wp-date-query.php
(35.13 KB)
📄
class-wp-dependencies.php
(16.69 KB)
📄
class-wp-dependency.php
(2.59 KB)
📄
class-wp-duotone.php
(39.95 KB)
📄
class-wp-editor.php
(70.54 KB)
📄
class-wp-embed.php
(15.54 KB)
📄
class-wp-error.php
(7.33 KB)
📄
class-wp-exception.php
(253 B)
📄
class-wp-fatal-error-handler.php
(7.96 KB)
📄
class-wp-feed-cache-transient.php
(3.23 KB)
📄
class-wp-feed-cache.php
(969 B)
📄
class-wp-hook.php
(16.25 KB)
📄
class-wp-http-cookie.php
(7.1 KB)
📄
class-wp-http-curl.php
(12.95 KB)
📄
class-wp-http-encoding.php
(6.53 KB)
📄
class-wp-http-ixr-client.php
(3.43 KB)
📄
class-wp-http-proxy.php
(5.84 KB)
📄
class-wp-http-requests-hooks.php
(1.97 KB)
📄
class-wp-http-requests-response.php
(4.14 KB)
📄
class-wp-http-response.php
(2.91 KB)
📄
class-wp-http-streams.php
(16.37 KB)
📄
class-wp-http.php
(40.67 KB)
📄
class-wp-icons-registry.php
(7.67 KB)
📄
class-wp-image-editor-gd.php
(20.22 KB)
📄
class-wp-image-editor-imagick.php
(36.11 KB)
📄
class-wp-image-editor.php
(17.01 KB)
📄
class-wp-list-util.php
(7.27 KB)
📄
class-wp-locale-switcher.php
(6.62 KB)
📄
class-wp-locale.php
(16.45 KB)
📄
class-wp-matchesmapregex.php
(1.79 KB)
📄
class-wp-meta-query.php
(29.79 KB)
📄
class-wp-metadata-lazyloader.php
(6.67 KB)
📄
class-wp-navigation-fallback.php
(8.98 KB)
📄
class-wp-network-query.php
(19.25 KB)
📄
class-wp-network.php
(12.01 KB)
📄
class-wp-object-cache.php
(17.11 KB)
📄
class-wp-oembed-controller.php
(6.74 KB)
📄
class-wp-oembed.php
(30.86 KB)
📄
class-wp-paused-extensions-storage.php
(4.95 KB)
📄
class-wp-phpmailer.php
(4.25 KB)
📄
class-wp-plugin-dependencies.php
(24.59 KB)
📄
class-wp-post-type.php
(29.95 KB)
📄
class-wp-post.php
(6.33 KB)
📄
class-wp-query.php
(159.5 KB)
📄
class-wp-recovery-mode-cookie-service.php
(6.72 KB)
📄
class-wp-recovery-mode-email-service.php
(10.9 KB)
📄
class-wp-recovery-mode-key-service.php
(4.8 KB)
📄
class-wp-recovery-mode-link-service.php
(3.44 KB)
📄
class-wp-recovery-mode.php
(11.18 KB)
📄
class-wp-rewrite.php
(62.2 KB)
📄
class-wp-role.php
(2.46 KB)
📄
class-wp-roles.php
(9.1 KB)
📄
class-wp-script-modules.php
(39.65 KB)
📄
class-wp-scripts.php
(35.93 KB)
📄
class-wp-session-tokens.php
(7.15 KB)
📄
class-wp-simplepie-file.php
(3.47 KB)
📄
class-wp-simplepie-sanitize-kses.php
(1.87 KB)
📄
class-wp-site-query.php
(30.74 KB)
📄
class-wp-site.php
(7.28 KB)
📄
class-wp-speculation-rules.php
(7.38 KB)
📄
class-wp-styles.php
(13.04 KB)
📄
class-wp-tax-query.php
(19.12 KB)
📄
class-wp-taxonomy.php
(18.12 KB)
📄
class-wp-term-query.php
(39.8 KB)
📄
class-wp-term.php
(5.14 KB)
📄
class-wp-text-diff-renderer-inline.php
(979 B)
📄
class-wp-text-diff-renderer-table.php
(18.49 KB)
📄
class-wp-textdomain-registry.php
(10.24 KB)
📄
class-wp-theme-json-data.php
(1.77 KB)
📄
class-wp-theme-json-resolver.php
(34.86 KB)
📄
class-wp-theme-json-schema.php
(7.19 KB)
📄
class-wp-theme-json.php
(169.57 KB)
📄
class-wp-theme.php
(64.22 KB)
📄
class-wp-token-map.php
(27.95 KB)
📄
class-wp-url-pattern-prefixer.php
(4.69 KB)
📄
class-wp-user-meta-session-tokens.php
(2.88 KB)
📄
class-wp-user-query.php
(43.07 KB)
📄
class-wp-user-request.php
(2.25 KB)
📄
class-wp-user.php
(22.48 KB)
📄
class-wp-walker.php
(13.01 KB)
📄
class-wp-widget-factory.php
(3.27 KB)
📄
class-wp-widget.php
(17.99 KB)
📄
class-wp-xmlrpc-server.php
(209.98 KB)
📄
class-wp.php
(25.75 KB)
📄
class-wpdb.php
(115.86 KB)
📄
class.wp-dependencies.php
(373 B)
📄
class.wp-scripts.php
(343 B)
📄
class.wp-styles.php
(338 B)
📁
collaboration
📄
collaboration.php
(2.11 KB)
📄
comment-template.php
(100.79 KB)
📄
comment.php
(130.94 KB)
📄
compat-utf8.php
(19.1 KB)
📄
compat.php
(15.69 KB)
📄
connectors.php
(23.52 KB)
📄
cron.php
(43.94 KB)
📁
css
📁
customize
📄
date.php
(400 B)
📄
default-constants.php
(11.1 KB)
📄
default-filters.php
(36.54 KB)
📄
default-widgets.php
(2.24 KB)
📄
deprecated.php
(189.43 KB)
📄
embed-template.php
(338 B)
📄
embed.php
(37.99 KB)
📄
error-protection.php
(4 KB)
📄
feed-atom-comments.php
(5.38 KB)
📄
feed-atom.php
(3.05 KB)
📄
feed-rdf.php
(2.61 KB)
📄
feed-rss.php
(1.16 KB)
📄
feed-rss2-comments.php
(4.04 KB)
📄
feed-rss2.php
(3.71 KB)
📄
feed.php
(24.6 KB)
📁
fonts
📄
fonts.php
(9.56 KB)
📄
formatting.php
(346.38 KB)
📄
functions.php
(283.52 KB)
📄
functions.wp-scripts.php
(20.01 KB)
📄
functions.wp-styles.php
(8.45 KB)
📄
general-template.php
(170.83 KB)
📄
global-styles-and-settings.php
(20.29 KB)
📁
html-api
📄
http.php
(26.62 KB)
📄
https-detection.php
(5.72 KB)
📄
https-migration.php
(4.63 KB)
📁
images
📁
interactivity-api
📁
js
📄
kses.php
(80.64 KB)
📁
l10n
📄
l10n.php
(69.74 KB)
📄
link-template.php
(156.39 KB)
📄
load.php
(55.15 KB)
📄
locale.php
(162 B)
📄
media-template.php
(61.79 KB)
📄
media.php
(218.55 KB)
📄
meta.php
(65.17 KB)
📄
ms-blogs.php
(25.71 KB)
📄
ms-default-constants.php
(4.81 KB)
📄
ms-default-filters.php
(6.48 KB)
📄
ms-deprecated.php
(21.24 KB)
📄
ms-files.php
(2.79 KB)
📄
ms-functions.php
(89.69 KB)
📄
ms-load.php
(19.57 KB)
📄
ms-network.php
(3.69 KB)
📄
ms-settings.php
(4.11 KB)
📄
ms-site.php
(40.75 KB)
📄
nav-menu-template.php
(25.38 KB)
📄
nav-menu.php
(43.23 KB)
📄
option.php
(102.62 KB)
📁
php-ai-client
📁
php-compat
📄
pluggable-deprecated.php
(6.18 KB)
📄
pluggable.php
(124.57 KB)
📄
plugin.php
(35.65 KB)
📁
pomo
📄
post-formats.php
(6.9 KB)
📄
post-template.php
(67.01 KB)
📄
post-thumbnail-template.php
(10.62 KB)
📄
post.php
(289.58 KB)
📄
query.php
(36.23 KB)
📄
registration-functions.php
(200 B)
📄
registration.php
(200 B)
📁
rest-api
📄
rest-api.php
(98.52 KB)
📄
revision.php
(29.99 KB)
📄
rewrite.php
(19 KB)
📄
robots-template.php
(5.06 KB)
📄
rss-functions.php
(255 B)
📄
rss.php
(22.66 KB)
📄
script-loader.php
(159.3 KB)
📄
script-modules.php
(11.66 KB)
📄
session.php
(258 B)
📄
shortcodes.php
(23.47 KB)
📁
sitemaps
📄
sitemaps.php
(3.16 KB)
📁
sodium_compat
📄
speculative-loading.php
(8.4 KB)
📄
spl-autoload-compat.php
(441 B)
📁
style-engine
📄
style-engine.php
(7.39 KB)
📄
taxonomy.php
(172.99 KB)
📄
template-canvas.php
(544 B)
📄
template-loader.php
(4.17 KB)
📄
template.php
(35.96 KB)
📁
theme-compat
📄
theme-i18n.json
(1.85 KB)
📄
theme-previews.php
(2.82 KB)
📄
theme-templates.php
(3.96 KB)
📄
theme.json
(8.83 KB)
📄
theme.php
(131.48 KB)
📄
update.php
(37.38 KB)
📄
user.php
(174.63 KB)
📄
utf8.php
(7.09 KB)
📄
vars.php
(6.45 KB)
📄
version.php
(1.08 KB)
📄
view-transitions.php
(602 B)
📁
widgets
📄
widgets.php
(69.17 KB)
📄
wp-db.php
(445 B)
📄
wp-diff.php
(799 B)
Editing: class-wp-connector-registry.php
<?php /** * Connectors API: WP_Connector_Registry class. * * @package WordPress * @subpackage Connectors * @since 7.0.0 */ /** * Manages the registration and lookup of connectors. * * This is an internal class. Use the public API functions to interact with connectors: * * - `wp_is_connector_registered()` — check if a connector exists. * - `wp_get_connector()` — retrieve a single connector's data. * - `wp_get_connectors()` — retrieve all registered connectors. * * Plugins receive the registry instance via the `wp_connectors_init` action * to register or override connectors directly. * * @since 7.0.0 * @access private * * @see wp_is_connector_registered() * @see wp_get_connector() * @see wp_get_connectors() * @see _wp_connectors_init() * * @phpstan-type Connector array{ * name: non-empty-string, * description: string, * logo_url?: non-empty-string, * type: non-empty-string, * authentication: array{ * method: 'api_key'|'none', * credentials_url?: non-empty-string, * setting_name?: non-empty-string, * constant_name?: non-empty-string, * env_var_name?: non-empty-string * }, * plugin: array{ * file?: non-empty-string, * is_active: callable(): bool * } * } */ final class WP_Connector_Registry { /** * The singleton instance of the registry. * * @since 7.0.0 */ private static ?WP_Connector_Registry $instance = null; /** * Holds the registered connectors. * * Each connector is stored as an associative array with keys: * name, description, type, authentication, and optionally plugin. * * @since 7.0.0 * @var array<string, array> * @phpstan-var array<string, Connector> */ private array $registered_connectors = array(); /** * Registers a new connector. * * Validates the provided arguments and stores the connector in the registry. * For connectors with `api_key` authentication, a `setting_name` can be provided * explicitly. If omitted, one is automatically generated using the pattern * `connectors_{$type}_{$id}_api_key`, with hyphens in the type and ID normalized * to underscores (e.g., connector type `spam_filtering` with ID `my_plugin` produces * `connectors_spam_filtering_my_plugin_api_key`). This setting name is used for the * Settings API registration and REST API exposure. * * Registering a connector with an ID that is already registered will trigger a * `_doing_it_wrong()` notice and return `null`. To override an existing connector, * call `unregister()` first. * * @since 7.0.0 * * @see WP_Connector_Registry::unregister() * * @param string $id The unique connector identifier. Must match the pattern * `/^[a-z0-9_-]+$/` (lowercase alphanumeric, hyphens, and underscores only). * @param array $args { * An associative array of arguments for the connector. * * @type string $name Required. The connector's display name. * @type string $description Optional. The connector's description. Default empty string. * @type string $logo_url Optional. URL to the connector's logo image. * @type string $type Required. The connector type, e.g. 'ai_provider'. * @type array $authentication { * Required. Authentication configuration. * * @type string $method Required. The authentication method: 'api_key' or 'none'. * @type string $credentials_url Optional. URL where users can obtain API credentials. * @type string $setting_name Optional. The setting name for the API key. * When omitted, auto-generated as * `connectors_{$type}_{$id}_api_key`. * Must be a non-empty string when provided. * @type string $constant_name Optional. PHP constant name for the API key * (e.g. 'ANTHROPIC_API_KEY'). Only checked when provided. * @type string $env_var_name Optional. Environment variable name for the API key * (e.g. 'ANTHROPIC_API_KEY'). Only checked when provided. * } * @type array $plugin { * Optional. Plugin data for install/activate UI. * * @type string $file Optional. The plugin's main file path relative to the * plugins directory (e.g. 'my-plugin/my-plugin.php' or * 'hello.php'). * @type callable $is_active Optional callback to determine whether the plugin * is active. Receives no arguments and must return bool. * Defaults to `__return_true`. * } * } * @return array|null The registered connector data on success, null on failure. * * @phpstan-param array{ * name: non-empty-string, * description?: string, * logo_url?: non-empty-string, * type: non-empty-string, * authentication: array{ * method: 'api_key'|'none', * credentials_url?: non-empty-string, * setting_name?: non-empty-string, * constant_name?: non-empty-string, * env_var_name?: non-empty-string * }, * plugin?: array{ * file?: non-empty-string, * is_active?: callable(): bool * } * } $args * @phpstan-return Connector|null */ public function register( string $id, array $args ): ?array { if ( ! preg_match( '/^[a-z0-9_-]+$/', $id ) ) { _doing_it_wrong( __METHOD__, __( 'Connector ID must contain only lowercase alphanumeric characters, hyphens, and underscores.' ), '7.0.0' ); return null; } if ( $this->is_registered( $id ) ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" is already registered.' ), esc_html( $id ) ), '7.0.0' ); return null; } // Validate required fields. if ( empty( $args['name'] ) || ! is_string( $args['name'] ) ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" requires a non-empty "name" string.' ), esc_html( $id ) ), '7.0.0' ); return null; } if ( empty( $args['type'] ) || ! is_string( $args['type'] ) ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" requires a non-empty "type" string.' ), esc_html( $id ) ), '7.0.0' ); return null; } if ( ! isset( $args['authentication'] ) || ! is_array( $args['authentication'] ) ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" requires an "authentication" array.' ), esc_html( $id ) ), '7.0.0' ); return null; } if ( empty( $args['authentication']['method'] ) || ! in_array( $args['authentication']['method'], array( 'api_key', 'none' ), true ) ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" authentication method must be "api_key" or "none".' ), esc_html( $id ) ), '7.0.0' ); return null; } if ( 'ai_provider' === $args['type'] && ! wp_supports_ai() ) { // No need for a `doing_it_wrong` as AI support is disabled intentionally. return null; } $connector = array( 'name' => $args['name'], 'description' => isset( $args['description'] ) && is_string( $args['description'] ) ? $args['description'] : '', 'type' => $args['type'], 'authentication' => array( 'method' => $args['authentication']['method'], ), ); if ( ! empty( $args['logo_url'] ) && is_string( $args['logo_url'] ) ) { $connector['logo_url'] = $args['logo_url']; } if ( 'api_key' === $args['authentication']['method'] ) { if ( ! empty( $args['authentication']['credentials_url'] ) && is_string( $args['authentication']['credentials_url'] ) ) { $connector['authentication']['credentials_url'] = $args['authentication']['credentials_url']; } if ( isset( $args['authentication']['setting_name'] ) ) { if ( ! is_string( $args['authentication']['setting_name'] ) || '' === $args['authentication']['setting_name'] ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" authentication setting_name must be a non-empty string.' ), esc_html( $id ) ), '7.0.0' ); return null; } $connector['authentication']['setting_name'] = $args['authentication']['setting_name']; } else { $connector['authentication']['setting_name'] = str_replace( '-', '_', "connectors_{$connector['type']}_{$id}_api_key" ); } if ( isset( $args['authentication']['constant_name'] ) ) { if ( ! is_string( $args['authentication']['constant_name'] ) || '' === $args['authentication']['constant_name'] ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" authentication constant_name must be a non-empty string.' ), esc_html( $id ) ), '7.0.0' ); return null; } $connector['authentication']['constant_name'] = $args['authentication']['constant_name']; } if ( isset( $args['authentication']['env_var_name'] ) ) { if ( ! is_string( $args['authentication']['env_var_name'] ) || '' === $args['authentication']['env_var_name'] ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" authentication env_var_name must be a non-empty string.' ), esc_html( $id ) ), '7.0.0' ); return null; } $connector['authentication']['env_var_name'] = $args['authentication']['env_var_name']; } } $connector['plugin'] = array(); if ( ! empty( $args['plugin'] ) && is_array( $args['plugin'] ) ) { if ( ! empty( $args['plugin']['file'] ) ) { $connector['plugin']['file'] = $args['plugin']['file']; } if ( isset( $args['plugin']['is_active'] ) ) { if ( ! is_callable( $args['plugin']['is_active'] ) ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" plugin is_active must be callable.' ), esc_html( $id ) ), '7.0.0' ); return null; } $connector['plugin']['is_active'] = $args['plugin']['is_active']; } } if ( ! isset( $connector['plugin']['is_active'] ) ) { $connector['plugin']['is_active'] = '__return_true'; } $this->registered_connectors[ $id ] = $connector; return $connector; } /** * Unregisters a connector. * * Returns the connector data on success, which can be modified and passed * back to `register()` to override a connector's metadata. * * Triggers a `_doing_it_wrong()` notice if the connector is not registered. * Use `is_registered()` to check first when the connector may not exist. * * @since 7.0.0 * * @see WP_Connector_Registry::register() * @see WP_Connector_Registry::is_registered() * * @param string $id The connector identifier. * @return array|null The unregistered connector data on success, null on failure. * * @phpstan-return Connector|null */ public function unregister( string $id ): ?array { if ( ! $this->is_registered( $id ) ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" not found.' ), esc_html( $id ) ), '7.0.0' ); return null; } $unregistered = $this->registered_connectors[ $id ]; unset( $this->registered_connectors[ $id ] ); return $unregistered; } /** * Retrieves the list of all registered connectors. * * Do not use this method directly. Instead, use the `wp_get_connectors()` function. * * @since 7.0.0 * * @see wp_get_connectors() * * @return array Connector settings keyed by connector ID. * * @phpstan-return array<string, Connector> */ public function get_all_registered(): array { return $this->registered_connectors; } /** * Checks if a connector is registered. * * Do not use this method directly. Instead, use the `wp_is_connector_registered()` function. * * @since 7.0.0 * * @see wp_is_connector_registered() * * @param string $id The connector identifier. * @return bool True if the connector is registered, false otherwise. */ public function is_registered( string $id ): bool { return isset( $this->registered_connectors[ $id ] ); } /** * Retrieves a registered connector. * * Do not use this method directly. Instead, use the `wp_get_connector()` function. * * Triggers a `_doing_it_wrong()` notice if the connector is not registered. * Use `is_registered()` to check first when the connector may not exist. * * @since 7.0.0 * * @see wp_get_connector() * * @param string $id The connector identifier. * @return array|null The registered connector data, or null if it is not registered. * @phpstan-return Connector|null */ public function get_registered( string $id ): ?array { if ( ! $this->is_registered( $id ) ) { _doing_it_wrong( __METHOD__, /* translators: %s: Connector ID. */ sprintf( __( 'Connector "%s" not found.' ), esc_html( $id ) ), '7.0.0' ); return null; } return $this->registered_connectors[ $id ]; } /** * Retrieves the main instance of the registry class. * * @since 7.0.0 * * @return WP_Connector_Registry|null The main registry instance, or null if not yet initialized. */ public static function get_instance(): ?self { return self::$instance; } /** * Sets the main instance of the registry class. * * Called by `_wp_connectors_init()` during the `init` action. Must not be * called outside of that context. * * @since 7.0.0 * @access private * * @see _wp_connectors_init() * * @param WP_Connector_Registry $registry The registry instance. */ public static function set_instance( WP_Connector_Registry $registry ): void { if ( ! doing_action( 'init' ) ) { _doing_it_wrong( __METHOD__, __( 'The connector registry instance must be set during the <code>init</code> action.' ), '7.0.0' ); return; } self::$instance = $registry; } }
Upload File
Create Folder