| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 120
 121
 122
 123
 124
 125
 126
 127
 128
 
 | <?php
/**
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License along
 * with this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 * http://www.gnu.org/copyleft/gpl.html
 *
 * @file
 */
namespace Wikimedia\Rdbms;
use BadMethodCallException;
use InvalidArgumentException;
/**
 * LoadBalancer manager for sites with one "main" cluster using only injected database connections
 *
 * This class assumes that there are no "external" clusters.
 *
 * LoadBalancerDisabled will be used if a null connection handle is injected.
 *
 * @see ILBFactory
 * @ingroup Database
 */
class LBFactorySingle extends LBFactory {
	/** @var LoadBalancerSingle|LoadBalancerDisabled */
	private $mainLB;
	/**
	 * @note Use of {@link newFromConnection} is preferable
	 *
	 * @param array $conf An associative array containing one of the following:
	 *  - connection: The IDatabase connection handle to use; null to disable access
	 */
	public function __construct( array $conf ) {
		parent::__construct( $conf );
		if ( !array_key_exists( 'connection', $conf ) ) {
			throw new InvalidArgumentException( "Missing 'connection' argument." );
		}
		$conn = $conf['connection'];
		if ( $conn ) {
			$mainLB = new LoadBalancerSingle( array_merge(
				$this->baseLoadBalancerParams(),
				[ 'connection' => $conn ]
			) );
		} else {
			$mainLB = new LoadBalancerDisabled( $this->baseLoadBalancerParams() );
		}
		$this->initLoadBalancer( $mainLB );
		$this->mainLB = $mainLB;
	}
	/**
	 * @param IDatabase $db Live connection handle
	 * @param array $params Parameter map to LBFactorySingle::__construct()
	 * @return LBFactorySingle
	 * @since 1.28
	 */
	public static function newFromConnection( IDatabase $db, array $params = [] ) {
		return new static( array_merge(
			[ 'localDomain' => $db->getDomainID() ],
			$params,
			[ 'connection' => $db ]
		) );
	}
	/**
	 * @param array $params Parameter map to LBFactorySingle::__construct()
	 * @return LBFactorySingle
	 * @since 1.40
	 */
	public static function newDisabled( array $params = [] ) {
		return new static( array_merge(
			$params,
			[ 'connection' => null ]
		) );
	}
	public function newMainLB( $domain = false ): ILoadBalancerForOwner {
		// @phan-suppress-previous-line PhanPluginNeverReturnMethod
		throw new BadMethodCallException( "Method is not supported." );
	}
	public function getMainLB( $domain = false ): ILoadBalancer {
		return $this->mainLB;
	}
	public function newExternalLB( $cluster ): ILoadBalancerForOwner {
		// @phan-suppress-previous-line PhanPluginNeverReturnMethod
		throw new BadMethodCallException( "Method is not supported." );
	}
	public function getExternalLB( $cluster ): ILoadBalancer {
		// @phan-suppress-previous-line PhanPluginNeverReturnMethod
		throw new BadMethodCallException( "Method is not supported." );
	}
	public function getAllMainLBs(): array {
		return [ self::CLUSTER_MAIN_DEFAULT => $this->mainLB ];
	}
	public function getAllExternalLBs(): array {
		return [];
	}
	protected function getLBsForOwner() {
		if ( $this->mainLB !== null ) {
			yield $this->mainLB;
		}
	}
	public function __destruct() {
		// do nothing since the connection was injected
	}
}
 |