%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /opt/bitnami/php/lib/php/AWSSDKforPHP/utilities/
Upload File :
Create Path :
Current File : /opt/bitnami/php/lib/php/AWSSDKforPHP/utilities/complextype.class.php

<?php
/*
 * Copyright 2010-2013 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 *
 *  http://aws.amazon.com/apache2.0
 *
 * or in the "license" file accompanying this file. This file is distributed
 * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing
 * permissions and limitations under the License.
 */


/*%******************************************************************************************%*/
// CLASS

/**
 * Contains utility methods used for converting array, JSON, and YAML data types into query string keys.
 *
 * @version 2010.11.11
 * @license See the included NOTICE.md file for more information.
 * @copyright See the included NOTICE.md file for more information.
 * @link http://aws.amazon.com/php/ PHP Developer Center
 */
class CFComplexType
{
	/**
	 * Takes a JSON object, as a string, to convert to query string keys.
	 *
	 * @param string $json (Required) A JSON object. The JSON string should use canonical rules (e.g., double quotes, quoted keys) as is required by PHP's <php:json_encode()> function.
	 * @param string $member (Optional) The name of the "member" property that AWS uses for lists in certain services. Defaults to an empty string.
	 * @param string $default_key (Optional) The default key to use when the value for `$data` is a string. Defaults to an empty string.
	 * @return array The option group parameters to merge into another method's `$opt` parameter.
	 */
	public static function json($json, $member = '', $default_key = '')
	{
		return self::option_group(json_decode($json, true), $member, $default_key);
	}

	/**
	 * Takes a YAML object, as a string, to convert to query string keys.
	 *
	 * @param string $yaml (Required) A YAML object.
	 * @param string $member (Optional) The name of the "member" property that AWS uses for lists in certain services. Defaults to an empty string.
	 * @param string $default_key (Optional) The default key to use when the value for `$data` is a string. Defaults to an empty string.
	 * @return array The option group parameters to merge into another method's `$opt` parameter.
	 */
	public static function yaml($yaml, $member = '', $default_key = '')
	{
		return self::option_group(sfYaml::load($yaml), $member, $default_key);
	}

	/**
	 * Takes an associative array to convert to query string keys.
	 *
	 * @param array $map (Required) An associative array.
	 * @param string $member (Optional) The name of the "member" property that AWS uses for lists in certain services. Defaults to an empty string.
	 * @param string $default_key (Optional) The default key to use when the value for `$data` is a string. Defaults to an empty string.
	 * @return array The option group parameters to merge into another method's `$opt` parameter.
	 */
	public static function map($map, $member = '', $default_key = '')
	{
		return self::option_group($map, $member, $default_key);
	}

	/**
	 * A protected method that is used by <json()>, <yaml()> and <map()>.
	 *
	 * @param string|array $data (Required) The data to iterate over.
	 * @param string $member (Optional) The name of the "member" property that AWS uses for lists in certain services. Defaults to an empty string.
	 * @param string $key (Optional) The default key to use when the value for `$data` is a string. Defaults to an empty string.
	 * @param array $out (Optional) INTERNAL ONLY. The array that contains the calculated values up to this point.
	 * @return array The option group parameters to merge into another method's `$opt` parameter.
	 */
	public static function option_group($data, $member = '', $key = '', &$out = array())
	{
		$reset = $key;

		if (is_array($data))
		{
			foreach ($data as $k => $v)
			{
				// Avoid 0-based indexes.
				if (is_int($k))
				{
					$k = $k + 1;

					if ($member !== '')
					{
						$key .= '.' . $member;
					}
				}

				$key .= ($key === '' ? $k : '.' . $k);

				if (is_array($v))
				{
					self::option_group($v, $member, $key, $out);
				}
				elseif ($v instanceof CFStepConfig)
				{
					self::option_group($v->get_config(), $member, $key, $out);
				}
				else
				{
					$out[$key] = $v;
				}

				$key = $reset;
			}
		}
		else
		{
			$out[$key] = $data;
		}

		return $out;
	}
}

Zerion Mini Shell 1.0