diff --git a/.editorconfig b/.editorconfig
deleted file mode 100644
index e27be283..00000000
--- a/.editorconfig
+++ /dev/null
@@ -1,15 +0,0 @@
-# This file is for unifying the coding style for different editors and IDEs
-# editorconfig.org
-
-root = true
-
-[*]
-charset = utf-8
-end_of_line = lf
-insert_final_newline = true
-trim_trailing_whitespace = true
-indent_style = space
-indent_size = 4
-
-[*.md]
-trim_trailing_whitespace = false
diff --git a/.gitattributes b/.gitattributes
index 4c4dbe73..3e7d094a 100644
--- a/.gitattributes
+++ b/.gitattributes
@@ -1,10 +1,16 @@
-# Path-based git attributes
-# https://www.kernel.org/pub/software/scm/git/docs/gitattributes.html
+*.php diff=php
-# Ignore all test and documentation with "export-ignore".
-/.gitattributes export-ignore
-/.gitignore export-ignore
-/.travis.yml export-ignore
-/phpunit.xml.dist export-ignore
-/scrutinizer.yml export-ignore
-/tests export-ignore
+/.github export-ignore
+/bin export-ignore
+/scripts export-ignore
+/tests export-ignore
+
+/.gitattributes export-ignore
+/.gitignore export-ignore
+/.php-cs-fixer.dist.php export-ignore
+/.phpactor.json export-ignore
+/.release-please-manifest.json export-ignore
+/.stats.yml export-ignore
+/phpstan.dist.neon export-ignore
+/phpunit.xml.dist export-ignore
+/release-please-config.json export-ignore
diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml
new file mode 100644
index 00000000..5d4cad3b
--- /dev/null
+++ b/.github/workflows/ci.yml
@@ -0,0 +1,36 @@
+name: CI
+on:
+ push:
+ branches:
+ - '**'
+ - '!integrated/**'
+ - '!stl-preview-head/**'
+ - '!stl-preview-base/**'
+ - '!generated'
+ - '!codegen/**'
+ - 'codegen/stl/**'
+ pull_request:
+ branches-ignore:
+ - 'stl-preview-head/**'
+ - 'stl-preview-base/**'
+
+jobs:
+ lint:
+ timeout-minutes: 10
+ name: lint
+ runs-on: ubuntu-latest
+ if: github.event_name == 'push' || github.event.pull_request.head.repo.fork
+
+ steps:
+ - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
+
+ - name: Set up PHP
+ uses: shivammathur/setup-php@accd6127cb78bee3e8082180cb391013d204ef9f # 2.37.0
+ with:
+ php-version: '8.3'
+
+ - name: Run Bootstrap
+ run: ./scripts/bootstrap
+
+ - name: Run lints
+ run: ./scripts/lint
diff --git a/.github/workflows/coverage.yml b/.github/workflows/coverage.yml
deleted file mode 100644
index 8cba38a5..00000000
--- a/.github/workflows/coverage.yml
+++ /dev/null
@@ -1,29 +0,0 @@
-name: PHP Coverage CI
-
-on: [ push, pull_request ]
-
-jobs:
- build:
- runs-on: ubuntu-latest
-
- steps:
- - uses: actions/checkout@v1
- - name: Setup PHP
- uses: shivammathur/setup-php@v2
- with:
- php-version: '8.0'
-
- - name: Validate composer.json and composer.lock
- run: composer validate
-
- - name: Install dependencies
- run: composer install --prefer-dist --no-progress --no-suggest
-
- # Add a test script to composer.json, for instance: "test": "vendor/bin/phpunit"
- # Docs: https://getcomposer.org/doc/articles/scripts.md
-
- - name: Run test suite
- run: ./vendor/bin/phpunit --coverage-clover coverage.xml
-
- - name: Upload to codecov
- run: bash <(curl -s https://codecov.io/bash)
diff --git a/.github/workflows/publish-packagist.yml b/.github/workflows/publish-packagist.yml
new file mode 100644
index 00000000..e8509fa2
--- /dev/null
+++ b/.github/workflows/publish-packagist.yml
@@ -0,0 +1,21 @@
+name: Publish Packagist
+on:
+ workflow_dispatch:
+
+ release:
+ types: [published]
+
+jobs:
+ publish:
+ name: publish
+ runs-on: ubuntu-latest
+
+ steps:
+ - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
+
+ - name: Publish to Packagist
+ run: |-
+ curl --fail-with-body -X POST -H 'Content-Type: application/json' "https://packagist.org/api/update-package?username=${PACKAGIST_USERNAME}&apiToken=${PACKAGIST_SAFE_KEY}" -d '{"repository":"https://github.com/imagekit-developer/imagekit-php"}'
+ env:
+ PACKAGIST_USERNAME: ${{ secrets.IMAGE_KIT_PACKAGIST_USERNAME || secrets.PACKAGIST_USERNAME }}
+ PACKAGIST_SAFE_KEY: ${{ secrets.IMAGE_KIT_PACKAGIST_SAFE_KEY || secrets.PACKAGIST_SAFE_KEY }}
\ No newline at end of file
diff --git a/.github/workflows/release-doctor.yml b/.github/workflows/release-doctor.yml
new file mode 100644
index 00000000..19b84d0c
--- /dev/null
+++ b/.github/workflows/release-doctor.yml
@@ -0,0 +1,23 @@
+name: Release Doctor
+on:
+ pull_request:
+ branches:
+ - master
+ workflow_dispatch:
+
+jobs:
+ release_doctor:
+ name: release doctor
+ runs-on: ubuntu-latest
+ if: github.repository == 'imagekit-developer/imagekit-php' && (github.event_name == 'push' || github.event_name == 'workflow_dispatch' || startsWith(github.head_ref, 'release-please') || github.head_ref == 'next')
+
+ steps:
+ - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
+
+ - name: Check release environment
+ run: |
+ bash ./bin/check-release-environment
+ env:
+ RELEASE_PLEASE_TOKEN: ${{ secrets.RELEASE_PLEASE_TOKEN }}
+ PACKAGIST_USERNAME: ${{ secrets.IMAGE_KIT_PACKAGIST_USERNAME || secrets.PACKAGIST_USERNAME }}
+ PACKAGIST_SAFE_KEY: ${{ secrets.IMAGE_KIT_PACKAGIST_SAFE_KEY || secrets.PACKAGIST_SAFE_KEY }}
diff --git a/.github/workflows/release-please.yml b/.github/workflows/release-please.yml
new file mode 100644
index 00000000..0c2e7a62
--- /dev/null
+++ b/.github/workflows/release-please.yml
@@ -0,0 +1,20 @@
+name: Release Please
+on:
+ push:
+ branches:
+ - master
+
+permissions:
+ contents: write
+ pull-requests: write
+
+jobs:
+ release-please:
+ if: github.repository == 'imagekit-developer/imagekit-php'
+ runs-on: ubuntu-latest
+
+ steps:
+ - uses: googleapis/release-please-action@5c625bfb5d1ff62eadeeb3772007f7f66fdcf071 # v4.4.1
+ id: release
+ with:
+ token: ${{ secrets.RELEASE_PLEASE_TOKEN }}
diff --git a/.github/workflows/stlc-promote.yml b/.github/workflows/stlc-promote.yml
new file mode 100644
index 00000000..3aef535e
--- /dev/null
+++ b/.github/workflows/stlc-promote.yml
@@ -0,0 +1,65 @@
+name: Promote SDKs
+
+on:
+ push:
+ branches: [main]
+
+permissions:
+ contents: read
+
+jobs:
+ promote:
+ runs-on: ubuntu-latest
+ env:
+ PRODUCTION_REPO: imagekit-developer/imagekit-php
+ PRODUCTION_BRANCH: master
+ GH_TOKEN: ${{ secrets.SDK_WRITE_TOKEN }}
+ steps:
+ - name: Check out staging
+ uses: actions/checkout@v4
+ with:
+ fetch-depth: 0
+ persist-credentials: false
+
+ - name: Fetch production main
+ run: |
+ git remote add production \
+ "https://x-access-token:${GH_TOKEN}@github.com/${PRODUCTION_REPO}.git"
+ git fetch production "${PRODUCTION_BRANCH}"
+
+ - name: Check if production is already in sync
+ id: diff
+ run: |
+ STAGING_SHA=$(git rev-parse origin/main)
+ PRODUCTION_SHA=$(git rev-parse production/${PRODUCTION_BRANCH})
+ if [ "$STAGING_SHA" = "$PRODUCTION_SHA" ]; then
+ echo "Production is already at $STAGING_SHA. Nothing to release."
+ echo "synced=true" >> "$GITHUB_OUTPUT"
+ else
+ echo "synced=false" >> "$GITHUB_OUTPUT"
+ fi
+
+ - name: Push staging main to the release branch on production
+ if: steps.diff.outputs.synced == 'false'
+ run: |
+ git push production origin/main:refs/heads/stainless/release --force
+
+ - name: Open or update the release PR on production
+ if: steps.diff.outputs.synced == 'false'
+ run: |
+ EXISTING_PR=$(gh pr list \
+ --repo "${PRODUCTION_REPO}" \
+ --head stainless/release \
+ --state open \
+ --json number \
+ --jq '.[0].number')
+ if [ -z "${EXISTING_PR}" ]; then
+ gh pr create \
+ --repo "${PRODUCTION_REPO}" \
+ --base "${PRODUCTION_BRANCH}" \
+ --head stainless/release \
+ --title "Release SDK updates" \
+ --body "$(git log --oneline production/${PRODUCTION_BRANCH}..origin/main)"
+ else
+ echo "Release PR #${EXISTING_PR} already exists. Force-push has updated it."
+ fi
diff --git a/.github/workflows/sync-release-as.yml b/.github/workflows/sync-release-as.yml
new file mode 100644
index 00000000..99150044
--- /dev/null
+++ b/.github/workflows/sync-release-as.yml
@@ -0,0 +1,63 @@
+name: Sync Release-As from release PR title
+
+on:
+ pull_request:
+ types: [edited]
+
+permissions:
+ contents: write
+
+jobs:
+ sync:
+ if: >-
+ github.event.pull_request.base.ref == 'master' &&
+ startsWith(github.event.pull_request.head.ref, 'release-please--') &&
+ github.event.changes.title != null
+ runs-on: ubuntu-latest
+ steps:
+ - name: Extract versions from old and new title
+ id: parse
+ env:
+ NEW_TITLE: ${{ github.event.pull_request.title }}
+ OLD_TITLE: ${{ github.event.changes.title.from }}
+ run: |
+ # Anchored on pull-request-title-pattern "release: ${version}" from release-please-config.json.
+ extract() {
+ echo "$1" | grep -oE '^release:[[:space:]]+v?[0-9]+\.[0-9]+\.[0-9]+(-[0-9A-Za-z.-]+)?' \
+ | sed -E 's/^release:[[:space:]]+v?//'
+ }
+ NEW_VERSION=$(extract "$NEW_TITLE")
+ OLD_VERSION=$(extract "$OLD_TITLE")
+ echo "old=$OLD_VERSION"
+ echo "new=$NEW_VERSION"
+ if [ -z "$NEW_VERSION" ]; then
+ echo "::notice::No semver in new title; nothing to do."
+ echo "skip=true" >> "$GITHUB_OUTPUT"
+ exit 0
+ fi
+ if [ "$NEW_VERSION" = "$OLD_VERSION" ]; then
+ echo "::notice::Version unchanged ($NEW_VERSION); not pushing."
+ echo "skip=true" >> "$GITHUB_OUTPUT"
+ exit 0
+ fi
+ echo "version=$NEW_VERSION" >> "$GITHUB_OUTPUT"
+
+ - name: Check out master
+ if: steps.parse.outputs.skip != 'true'
+ uses: actions/checkout@v6
+ with:
+ ref: master
+ token: ${{ secrets.RELEASE_PLEASE_TOKEN }}
+ fetch-depth: 1
+
+ - name: Push empty Release-As commit
+ if: steps.parse.outputs.skip != 'true'
+ env:
+ VERSION: ${{ steps.parse.outputs.version }}
+ run: |
+ git config user.name "release-as-bot"
+ git config user.email "release-as-bot@users.noreply.github.com"
+ git commit --allow-empty -m "chore: pin next release
+
+ Release-As: ${VERSION}"
+ git push origin master
diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml
deleted file mode 100644
index eded823b..00000000
--- a/.github/workflows/test.yml
+++ /dev/null
@@ -1,31 +0,0 @@
-name: PHP Test CI
-
-on: [ push, pull_request ]
-
-jobs:
- build:
- runs-on: ${{ matrix.operating-system }}
- strategy:
- matrix:
- operating-system: [ 'ubuntu-latest', 'windows-latest', 'macos-latest' ]
- php-versions: [ '5.6', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0' ]
- phpunit-versions: [ 'latest' ]
- steps:
- - uses: actions/checkout@v1
-
- - name: Setup PHP
- uses: shivammathur/setup-php@v2
- with:
- php-version: '${{ matrix.php-versions }}'
-
- - name: Validate composer.json and composer.lock
- run: composer validate
-
- - name: Install dependencies
- run: composer install --prefer-dist --no-progress --no-suggest
-
- # Add a test script to composer.json, for instance: "test": "vendor/bin/phpunit"
- # Docs: https://getcomposer.org/doc/articles/scripts.md
-
- - name: Run test suite
- run: ./vendor/bin/phpunit
diff --git a/.github/workflows/wiki.yml b/.github/workflows/wiki.yml
deleted file mode 100644
index 85568a30..00000000
--- a/.github/workflows/wiki.yml
+++ /dev/null
@@ -1,24 +0,0 @@
-name: Automatic update project documentation
-
-on:
- push:
- branches:
- - master
- tags:
- - '*'
-
-jobs:
- update_wiki:
- runs-on: ubuntu-latest
- steps:
- - name: Checkouting project code...
- uses: actions/checkout@v2
- - name: Updating wiki...
- uses: impresscms-dev/phpdocs-wiki-update-action@v1.0.0
- with:
- wiki_github_update_token: ${{ secrets.WIKI_GITHUB_UPDATE_TOKEN }}
- wiki_github_update_user: ${{ secrets.WIKI_GITHUB_UPDATE_USER }}
- engine: clean/phpdoc-md
- class_root_namespace: ImageKit
- include: |
- ImageKit\**
diff --git a/.gitignore b/.gitignore
index 5f842560..71d6d159 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,42 +1,13 @@
-# IntelliJ - PhpStorm and PyCharm
-.idea
-*.iml
-*.ipr
-*.iws
-
-# Netbeans
-nbproject
-.nbproject
-.nbproject/*
-nbproject/*
-nbproject/private/
-build/
-nbbuild/
-dist/
-nbdist/
-nbactions.xml
-nb-configuration.xml
-
-# Mac OSX
-.DS_Store
-# Thumbnails
-._*
-# Files that might appear on external disk
-.Spotlight-V100
-.Trashes
-
-# SublimeText project files
-/*.sublime-project
-*.sublime-workspace
-
-build
-docs
-vendor
-composer.phar
+docs/
+.idea/
+.php-cs-fixer.cache
+.php-cs-fixer.php
+.phpunit.cache
phpunit.xml
-.vscode
-.phpunit*
-sample/vendor
-sample/composer.lock
+playground/
+*.swo
+*.swp
+vendor/
-*.phar
+# do not edit! excludes generated files used internally
+.artifacts/
diff --git a/.php-cs-fixer.dist.php b/.php-cs-fixer.dist.php
new file mode 100644
index 00000000..d46a37f9
--- /dev/null
+++ b/.php-cs-fixer.dist.php
@@ -0,0 +1,19 @@
+setParallelConfig(ParallelConfigFactory::detect())
+ ->setFinder(Finder::create()->in([__DIR__.'/src', __DIR__.'/tests']))
+ ->setRules([
+ '@PhpCsFixer' => true,
+ 'phpdoc_align' => false,
+ 'new_with_parentheses' => ['named_class' => false],
+ 'ordered_types' => ['null_adjustment' => 'always_last', 'sort_algorithm' => 'none'],
+ 'phpdoc_types_order' => ['null_adjustment' => 'always_last', 'sort_algorithm' => 'none'],
+ ])
+;
diff --git a/.phpactor.json b/.phpactor.json
new file mode 100644
index 00000000..97fdd060
--- /dev/null
+++ b/.phpactor.json
@@ -0,0 +1,6 @@
+{
+ "indexer.exclude_patterns": ["vendor"],
+ "language_server_completion.trim_leading_dollar": true,
+ "language_server_php_cs_fixer.enabled": false,
+ "language_server_phpstan.enabled": true
+}
diff --git a/.release-please-manifest.json b/.release-please-manifest.json
new file mode 100644
index 00000000..1332969b
--- /dev/null
+++ b/.release-please-manifest.json
@@ -0,0 +1,3 @@
+{
+ ".": "0.0.1"
+}
\ No newline at end of file
diff --git a/.stats.yml b/.stats.yml
new file mode 100644
index 00000000..006b15f4
--- /dev/null
+++ b/.stats.yml
@@ -0,0 +1 @@
+configured_endpoints: 47
diff --git a/DEVELOPMENT.md b/DEVELOPMENT.md
deleted file mode 100644
index 2f857ed7..00000000
--- a/DEVELOPMENT.md
+++ /dev/null
@@ -1,25 +0,0 @@
-## Installing dependencies
-
-Install the project dependencies by running the following command in terminal
-
-```
-composer install
-```
-
-## Running the tests
-
-```
-vendor/bin/phpunit
-```
-
-## Sample Code Instruction
-
-To run sample code go to the sample directory and run
-
-```
-php sample.php
-```
-
-## Support
-
-For any feedback or to report any issues or general implementation support, please reach out to [support@imagekit.io](mailto:support@imagekit.io)
\ No newline at end of file
diff --git a/LICENSE b/LICENSE
index 8b976bea..20278610 100644
--- a/LICENSE
+++ b/LICENSE
@@ -1,20 +1,201 @@
-MIT License
-
-Copyright (c) 2020 Imagekit
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is
-furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in all
-copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ Apache License
+ Version 2.0, January 2004
+ http://www.apache.org/licenses/
+
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+ 1. Definitions.
+
+ "License" shall mean the terms and conditions for use, reproduction,
+ and distribution as defined by Sections 1 through 9 of this document.
+
+ "Licensor" shall mean the copyright owner or entity authorized by
+ the copyright owner that is granting the License.
+
+ "Legal Entity" shall mean the union of the acting entity and all
+ other entities that control, are controlled by, or are under common
+ control with that entity. For the purposes of this definition,
+ "control" means (i) the power, direct or indirect, to cause the
+ direction or management of such entity, whether by contract or
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
+ outstanding shares, or (iii) beneficial ownership of such entity.
+
+ "You" (or "Your") shall mean an individual or Legal Entity
+ exercising permissions granted by this License.
+
+ "Source" form shall mean the preferred form for making modifications,
+ including but not limited to software source code, documentation
+ source, and configuration files.
+
+ "Object" form shall mean any form resulting from mechanical
+ transformation or translation of a Source form, including but
+ not limited to compiled object code, generated documentation,
+ and conversions to other media types.
+
+ "Work" shall mean the work of authorship, whether in Source or
+ Object form, made available under the License, as indicated by a
+ copyright notice that is included in or attached to the work
+ (an example is provided in the Appendix below).
+
+ "Derivative Works" shall mean any work, whether in Source or Object
+ form, that is based on (or derived from) the Work and for which the
+ editorial revisions, annotations, elaborations, or other modifications
+ represent, as a whole, an original work of authorship. For the purposes
+ of this License, Derivative Works shall not include works that remain
+ separable from, or merely link (or bind by name) to the interfaces of,
+ the Work and Derivative Works thereof.
+
+ "Contribution" shall mean any work of authorship, including
+ the original version of the Work and any modifications or additions
+ to that Work or Derivative Works thereof, that is intentionally
+ submitted to Licensor for inclusion in the Work by the copyright owner
+ or by an individual or Legal Entity authorized to submit on behalf of
+ the copyright owner. For the purposes of this definition, "submitted"
+ means any form of electronic, verbal, or written communication sent
+ to the Licensor or its representatives, including but not limited to
+ communication on electronic mailing lists, source code control systems,
+ and issue tracking systems that are managed by, or on behalf of, the
+ Licensor for the purpose of discussing and improving the Work, but
+ excluding communication that is conspicuously marked or otherwise
+ designated in writing by the copyright owner as "Not a Contribution."
+
+ "Contributor" shall mean Licensor and any individual or Legal Entity
+ on behalf of whom a Contribution has been received by Licensor and
+ subsequently incorporated within the Work.
+
+ 2. Grant of Copyright License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ copyright license to reproduce, prepare Derivative Works of,
+ publicly display, publicly perform, sublicense, and distribute the
+ Work and such Derivative Works in Source or Object form.
+
+ 3. Grant of Patent License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ (except as stated in this section) patent license to make, have made,
+ use, offer to sell, sell, import, and otherwise transfer the Work,
+ where such license applies only to those patent claims licensable
+ by such Contributor that are necessarily infringed by their
+ Contribution(s) alone or by combination of their Contribution(s)
+ with the Work to which such Contribution(s) was submitted. If You
+ institute patent litigation against any entity (including a
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
+ or a Contribution incorporated within the Work constitutes direct
+ or contributory patent infringement, then any patent licenses
+ granted to You under this License for that Work shall terminate
+ as of the date such litigation is filed.
+
+ 4. Redistribution. You may reproduce and distribute copies of the
+ Work or Derivative Works thereof in any medium, with or without
+ modifications, and in Source or Object form, provided that You
+ meet the following conditions:
+
+ (a) You must give any other recipients of the Work or
+ Derivative Works a copy of this License; and
+
+ (b) You must cause any modified files to carry prominent notices
+ stating that You changed the files; and
+
+ (c) You must retain, in the Source form of any Derivative Works
+ that You distribute, all copyright, patent, trademark, and
+ attribution notices from the Source form of the Work,
+ excluding those notices that do not pertain to any part of
+ the Derivative Works; and
+
+ (d) If the Work includes a "NOTICE" text file as part of its
+ distribution, then any Derivative Works that You distribute must
+ include a readable copy of the attribution notices contained
+ within such NOTICE file, excluding those notices that do not
+ pertain to any part of the Derivative Works, in at least one
+ of the following places: within a NOTICE text file distributed
+ as part of the Derivative Works; within the Source form or
+ documentation, if provided along with the Derivative Works; or,
+ within a display generated by the Derivative Works, if and
+ wherever such third-party notices normally appear. The contents
+ of the NOTICE file are for informational purposes only and
+ do not modify the License. You may add Your own attribution
+ notices within Derivative Works that You distribute, alongside
+ or as an addendum to the NOTICE text from the Work, provided
+ that such additional attribution notices cannot be construed
+ as modifying the License.
+
+ You may add Your own copyright statement to Your modifications and
+ may provide additional or different license terms and conditions
+ for use, reproduction, or distribution of Your modifications, or
+ for any such Derivative Works as a whole, provided Your use,
+ reproduction, and distribution of the Work otherwise complies with
+ the conditions stated in this License.
+
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
+ any Contribution intentionally submitted for inclusion in the Work
+ by You to the Licensor shall be under the terms and conditions of
+ this License, without any additional terms or conditions.
+ Notwithstanding the above, nothing herein shall supersede or modify
+ the terms of any separate license agreement you may have executed
+ with Licensor regarding such Contributions.
+
+ 6. Trademarks. This License does not grant permission to use the trade
+ names, trademarks, service marks, or product names of the Licensor,
+ except as required for reasonable and customary use in describing the
+ origin of the Work and reproducing the content of the NOTICE file.
+
+ 7. Disclaimer of Warranty. Unless required by applicable law or
+ agreed to in writing, Licensor provides the Work (and each
+ Contributor provides its Contributions) on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied, including, without limitation, any warranties or conditions
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+ PARTICULAR PURPOSE. You are solely responsible for determining the
+ appropriateness of using or redistributing the Work and assume any
+ risks associated with Your exercise of permissions under this License.
+
+ 8. Limitation of Liability. In no event and under no legal theory,
+ whether in tort (including negligence), contract, or otherwise,
+ unless required by applicable law (such as deliberate and grossly
+ negligent acts) or agreed to in writing, shall any Contributor be
+ liable to You for damages, including any direct, indirect, special,
+ incidental, or consequential damages of any character arising as a
+ result of this License or out of the use or inability to use the
+ Work (including but not limited to damages for loss of goodwill,
+ work stoppage, computer failure or malfunction, or any and all
+ other commercial damages or losses), even if such Contributor
+ has been advised of the possibility of such damages.
+
+ 9. Accepting Warranty or Additional Liability. While redistributing
+ the Work or Derivative Works thereof, You may choose to offer,
+ and charge a fee for, acceptance of support, warranty, indemnity,
+ or other liability obligations and/or rights consistent with this
+ License. However, in accepting such obligations, You may act only
+ on Your own behalf and on Your sole responsibility, not on behalf
+ of any other Contributor, and only if You agree to indemnify,
+ defend, and hold each Contributor harmless for any liability
+ incurred by, or claims asserted against, such Contributor by reason
+ of your accepting any such warranty or additional liability.
+
+ END OF TERMS AND CONDITIONS
+
+ APPENDIX: How to apply the Apache License to your work.
+
+ To apply the Apache License to your work, attach the following
+ boilerplate notice, with the fields enclosed by brackets "[]"
+ replaced with your own identifying information. (Don't include
+ the brackets!) The text should be enclosed in the appropriate
+ comment syntax for the file format. We also recommend that a
+ file or class name and description of purpose be included on the
+ same "printed page" as the copyright notice for easier
+ identification within third-party archives.
+
+ Copyright 2026 Image Kit
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License 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.
diff --git a/README.md b/README.md
index 69c9d458..ea9290f5 100644
--- a/README.md
+++ b/README.md
@@ -1,1238 +1,207 @@
-# PHP SDK for ImageKit
+# Image Kit PHP API library
-[](https://packagist.org/packages/imagekit/imagekit) [](https://packagist.org/packages/imagekit/imagekit) [](https://opensource.org/licenses/MIT) [](https://codecov.io/gh/imagekit-developer/imagekit-php) [](https://twitter.com/ImagekitIo)
-[](https://github.com/imagekit-developer/imagekit-php/actions/workflows/test.yml) [](https://github.com/imagekit-developer/imagekit-php/actions/workflows/coverage.yml) [](https://github.com/imagekit-developer/imagekit-php/wiki)
+The Image Kit PHP library provides convenient access to the Image Kit REST API from any PHP 8.1.0+ application.
-PHP SDK for [ImageKit](https://imagekit.io/) implements the new APIs and interface for different file operations.
+## Documentation
-ImageKit is complete media storage, optimization, and transformation solution that comes with an [image and video CDN](https://imagekit.io/). It can be integrated with your existing infrastructure - storage like AWS S3, web servers, your CDN, and custom domain names, allowing you to deliver optimized images in minutes with minimal code changes.
-
-- [Key Features](#key-features)
-- [Requirements](#requirements)
-- [Version Support](#version-support)
-- [Breaking changes](#breaking-changes)
-- [Installation](#installation)
-- [Usage](#usage)
-- [Getting Started](#getting-started)
-- [Quick Examples](#quick-examples)
- * [Create an ImageKit Instance](#create-an-imagekit-instance)
- * [URL Generation](#url-generation)
- * [File Upload](#file-upload)
-- [Demo Application](#demo-application)
-- [URL Generation](#url-generation-1)
-- [Signed URL & Image Transformations](#applying-chained-transformations-common-image-manipulations--signed-url)
-- [Server-side File Upload](#server-side-file-upload)
-- [File Management](#file-management)
-- [Custom Metadata Fields API](#custom-metadata-fields-api)
-- [Utility Function](#utility-functions)
-- [Opening Issues](#opening-issues)
-- [Support](#support)
-- [Resources](#resources)
-- [License](#license)
-
-## Key Features
-- [URL Generation](#url-generation)
-- [Transformations](#1-chained-transformations-as-a-query-parameter)
-- [Secure URLS](#6-signed-url)
-- [File Upload](#server-side-file-upload)
-- [File Management](#file-management)
-
-## Requirements
-* PHP 5.6+
-* [JSON PHP Extension](https://www.php.net/manual/en/book.json.php)
-* [cURL PHP Extension](https://www.php.net/manual/en/book.curl.php)
-
-## Version Support
-| SDK Version | PHP 5.4 | PHP 5.5 | PHP 5.6 | PHP 7.x | PHP 8.x |
-|-------------|---------|---------|---------|---------|---------|
-| 4.x | ❌ | ❌ | ✔️ | ✔️ |✔️ |
-| 3.x | ❌ | ❌ | ✔️ | ✔️ |✔️ |
-| 2.x | ❌ | ❌ | ✔️ | ✔️ |✔️ |
-| 1.x | ❌ | ✔️ | ✔️ | ✔️ |✔️ |
-
-## Breaking changes
-
-### Upgrading from 3.x to 4.x version
-
-1. Overlay syntax update
-
-* In version 4.0.0, we've removed the old overlay syntax parameters for transformations, such as `oi`, `ot`, `obg`, and [more](https://docs.imagekit.io/features/image-transformations/overlay). These parameters are deprecated and will start returning errors when used in URLs. Please migrate to the new layers syntax that supports overlay nesting, provides better positional control, and allows more transformations at the layer level. You can start with [examples](https://docs.imagekit.io/features/image-transformations/overlay-using-layers#examples) to learn quickly.
-* You can migrate to the new layers syntax using the `raw` transformation parameter.
+The REST API documentation can be found on [imagekit.io](https://imagekit.io/docs/api-reference).
## Installation
-You can install the bindings via [Composer](http://getcomposer.org/). Run the following command:
+
-```bash
-composer require imagekit/imagekit
```
-To use the bindings, use Composer's [autoload](https://getcomposer.org/doc/01-basic-usage.md#autoloading):
-```php
-require_once('vendor/autoload.php');
+composer require "imagekit/imagekit 0.0.1"
```
-## Usage
-
-You can use this PHP SDK for three different methods - URL generation, file upload, and file management. The usage of the SDK has been explained below.
-
-* `URL Generation`
-* `File Upload`
-* `File Management`
-
-## Getting Started
-1. **Sign up for ImageKit** – Before you begin, you need to sign up for an [ImageKit account](https://imagekit.io/registration/)
-2. Get your [API Keys](https://docs.imagekit.io/api-reference/api-introduction/api-keys) from [developer options](https://imagekit.io/dashboard/developer) inside the dashboard.
-3. **Minimum requirements** – To use PHP SDK, your system must meet the minimum requirements, including having **PHP >= 5.6**. We highly recommend having it compiled with the cURL extension and cURL 7.16.2+ compiled with a TLS backend (e.g., NSS or OpenSSL).
-4. **Install the SDK** – Using Composer is the recommended way to install the ImageKit SDK for PHP. The SDK is available via [Packagist](http://packagist.org/) under the [`imagekit/imagekit`](https://packagist.org/packages/imagekit/imagekit) package. If Composer is installed globally on your system, you can run the following in the base directory of your project to add the SDK as a dependency:
- ```
- composer require imagekit/imagekit
- ```
- Please see the [Installation](#installation) section for more detailed information about installing.
-5. **Using the SDK** – The best way to become familiar with how to use the SDK is to follow the examples provided in the [quick start guide](https://docs.imagekit.io/getting-started/quickstart-guides/php).
-
-## Quick Examples
+
-#### Create an ImageKit Instance
-```php
-// Require the Composer autoloader.
-require 'vendor/autoload.php';
-use ImageKit\ImageKit;
-
-$imageKit = new ImageKit(
- "your_public_key",
- "your_private_key",
- "your_url_endpoint"
-);
-```
+## Usage
-#### URL Generation
-```php
-// For URL Generation, works for both images and videos
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- ]
-);
-echo $imageURL;
-```
+This library uses named parameters to specify optional arguments.
+Parameters with a default value must be set by name.
-#### File Upload
```php
-// For File Upload
-$uploadFile = $imageKit->uploadFile([
- 'file' => 'file-url', # required, "binary","base64" or "file url"
- 'fileName' => 'new-file' # required
- 'checks' => '"file.size" < "1mb"' // optional `checks` parameters can be used to run server-side checks before files are uploaded to the Media Library.
-]);
-```
-
-#### Response Structure
-Following is the response for [server-side file upload API](https://docs.imagekit.io/api-reference/upload-file-api/server-side-file-upload#response-code-and-structure-json)
-
-```json
-{
- "error": null,
- "result": {
- "fileId": "6286329dfef1b033aee60211",
- "name": "your_file_name_S-PgGysnR.jpg",
- "size": 94466,
- "versionInfo": {
- "id": "6286329dfef1b033aee60211",
- "name": "Version 1"
- },
- "filePath": "/your_file_name_S-PgGysnR.jpg",
- "url": "https://ik.imagekit.io/demo/your_file_name_S-PgGysnR.jpg",
- "fileType": "image",
- "height": 640,
- "width": 960,
- "thumbnailUrl": "https://ik.imagekit.io/demo/tr:n-ik_ml_thumbnail/your_file_name_S-PgGysnR.jpg",
- "tags": [],
- "AITags": null,
- "customMetadata": { },
- "extensionStatus": {}
- },
- "responseMetadata":{
- "headers":{
- "access-control-allow-origin": "*",
- "x-ik-requestid": "e98f2464-2a86-4934-a5ab-9a226df012c9",
- "content-type": "application/json; charset=utf-8",
- "content-length": "434",
- "etag": 'W/"1b2-reNzjRCFNt45rEyD7yFY/dk+Ghg"',
- "date": "Thu, 16 Jun 2022 14:22:01 GMT",
- "x-request-id": "e98f2464-2a86-4934-a5ab-9a226df012c9"
- },
- "raw":{
- "fileId": "6286329dfef1b033aee60211",
- "name": "your_file_name_S-PgGysnR.jpg",
- "size": 94466,
- "versionInfo": {
- "id": "6286329dfef1b033aee60211",
- "name": "Version 1"
- },
- "filePath": "/your_file_name_S-PgGysnR.jpg",
- "url": "https://ik.imagekit.io/demo/your_file_name_S-PgGysnR.jpg",
- "fileType": "image",
- "height": 640,
- "width": 960,
- "thumbnailUrl": "https://ik.imagekit.io/demo/tr:n-ik_ml_thumbnail/your_file_name_S-PgGysnR.jpg",
- "tags": [],
- "AITags": null,
- "customMetadata": { },
- "extensionStatus": {}
- },
- "statusCode":200
- }
-}
-```
-
-## Demo application
-
-* Step-by-step PHP quick start guide - https://docs.imagekit.io/getting-started/quickstart-guides/php
-* You can also run the demo application in this repository's [sample](/sample) folder.
- ```sh
- cd sample
- php sample.php
- ```
-
-## URL generation
+url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400'
- ]
- ]
- ]
+$client = new Client(
+ privateKey: getenv('IMAGEKIT_PRIVATE_KEY') ?: 'My Private Key',
+ password: getenv('OPTIONAL_IMAGEKIT_IGNORES_THIS') ?: 'do_not_set',
);
-```
-
-#### Response
-
-```
-https://ik.imagekit.io/your_imagekit_id/tr:h-300,w-400/default-image.jpg
-```
-
-### Using full image URL
-This method allows you to add transformation parameters to an absolute URL. For example, if you have configured a custom CNAME and have absolute asset URLs in your database or CMS, you will often need this.
-
-#### Example
-```php
-$imageURL = $imageKit->url([
- 'src' => 'https://ik.imagekit.io/your_imagekit_id/endpoint/default-image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400'
- ]
- ]
-]);
-```
-
-#### Response
-```
-https://ik.imagekit.io/your_imagekit_id/endpoint/tr:h-300,w-400/default-image.jpg
-```
-
-The `$imageKit->url()` method accepts the following parameters.
-
-| Option | Description |
-| :-------------------- | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
-| urlEndpoint | Optional. The base URL to be appended before the path of the image. If not specified, the URL Endpoint specified at the time of SDK initialization is used. For example, https://ik.imagekit.io/your_imagekit_id/endpoint/ |
-| path | Conditional. This is the path at which the image exists. For example, `/path/to/image.jpg`. Either the `path` or `src` parameter needs to be specified for URL generation. |
-| src | Conditional. This is the complete URL of an image already mapped to ImageKit. For example, `https://ik.imagekit.io/your_imagekit_id/endpoint/path/to/image.jpg`. Either the `path` or `src` parameter needs to be specified for URL generation. |
-| transformation | Optional. An array of objects specifying the transformation to be applied in the URL. The transformation name and the value should be specified as a key-value pair in the object. Different steps of a [chained transformation](https://docs.imagekit.io/features/image-transformations/chained-transformations) can be specified as different objects of the array. The complete [List of supported transformations](#list-of-supported-transformations) in the SDK and some examples of using them are given later. If you use a transformation name that is not specified in the SDK, it gets applied as it is in the URL. |
-| transformationPosition | Optional. The default value is `path` which places the transformation string as a path parameter in the URL. It can also be specified as `query`, which adds the transformation string as the query parameter `tr` in the URL. The transformation string is always added as a query parameter if you use the `src` parameter to create the URL. |
-| queryParameters | Optional. These are the other query parameters that you want to add to the final URL. These can be any query parameters and are not necessarily related to ImageKit. Especially useful if you want to add some versioning parameters to your URLs. |
-| signed | Optional. Boolean. The default value is `false`. If set to `true`, the SDK generates a signed image URL adding the image signature to the image URL. |
-| expireSeconds | Optional. Integer. It is used along with the `signed` parameter. It specifies the time in seconds from now when the signed URL will expire. If specified, the URL contains the expiry timestamp in the URL, and the image signature is modified accordingly.
-
-### Applying chained transformations, common image manipulations & signed URL
-
-This section covers the basics:
-
-* [Chained Transformations as a query parameter](#1-chained-transformations-as-a-query-parameter)
-* [Image enhancement & color manipulation](#2-image-enhancement-and-color-manipulation)
-* [Resizing images and videos](#3-resizing-images-and-videos)
-* [Quality manipulation](#4-quality-manipulation)
-* [Adding overlays](#5-adding-overlays)
-* [Signed URL](#6-signed-url)
-The PHP SDK gives a name to each transformation parameter e.g. `height` for `h` and `width` for `w` parameter. It makes your code more readable. See the [Full list of supported transformations](#list-of-supported-transformations).
-
-👉 If the property does not match any of the available options, it is added as it is. For example:
-```php
-[
- 'effectGray' => 'e-grayscale'
-]
-// and
-[
- 'e-grayscale' => ''
-]
-// works the same
-```
-👉 Note that you can also use the `h` and `w` parameters instead of `height` and `width`.
-
-For more examples, check the [Demo Application](https://github.com/imagekit-developer/imagekit-php/tree/master/sample).
-
-
-### 1. Chained transformations as a query parameter
-
-#### Example
-```php
-$imageURL = $imageKit->url([
- 'path' => '/default-image.jpg',
- 'urlEndpoint' => 'https://ik.imagekit.io/your_imagekit_id/endpoint/',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400'
- ],
- [
- 'rotation' => 90
- ],
- ],
- 'transformationPosition' => 'query'
-]);
-```
-#### Response
-```
-https://ik.imagekit.io/your_imagekit_id/endpoint/default-image.jpg?tr=h-300,w-400:rt-90
-```
-
-### 2. Image enhancement and color manipulation
-
-Some transformations like [contrast stretch](https://docs.imagekit.io/features/image-transformations/image-enhancement-and-color-manipulation#contrast-stretch-e-contrast) , [sharpen](https://docs.imagekit.io/features/image-transformations/image-enhancement-and-color-manipulation#sharpen-e-sharpen) and [unsharp mask](https://docs.imagekit.io/features/image-transformations/image-enhancement-and-color-manipulation#unsharp-mask-e-usm) can be added to the URL with or without any other value. To use such transforms without specifying a value, specify the value as "-" in the transformation object. Otherwise, specify the value that you want to be added to this transformation.
-
-#### Example
-```php
-$imageURL = $imageKit->url([
- 'src' => 'https://ik.imagekit.io/your_imagekit_id/endpoint/default-image.jpg',
- 'transformation' =>
- [
- [
- 'format' => 'jpg',
- 'progressive' => true,
- 'effectSharpen' => '-',
- 'effectContrast' => '1'
- ]
- ]
-]);
-```
-#### Response
-```
-https://ik.imagekit.io/your_imagekit_id/endpoint/tr:f-jpg,pr-true,e-sharpen,e-contrast-1/default-image.jpg
-```
-
-### 3. Resizing images and videos
-Let's resize the image to `width` 400 and `height` 300.
-Check detailed instructions on [resize, crop, and other Common transformations](https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations)
-
-#### Example
-```php
-$imageURL = $imageKit->url(array(
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- ]
- ]
-));
-```
-#### Response
-```
-https://ik.imagekit.io/your_imagekit_id/tr:w-400,h-300/default-image.jpg
-```
-
-### 4. Quality manipulation
-You can use the [quality parameter](https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#quality-q) to change quality like this.
-
-#### Example
-```php
-$imageURL = $imageKit->url(array(
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'quality' => '40',
- ]
- ]
-));
-```
+$response = $client->files->upload(
+ file: FileParam::fromString('https://www.example.com/public-url.jpg', filename: uniqid('file-upload-', true)),
+ fileName: 'file-name.jpg',
+);
-#### Response
-```
-https://ik.imagekit.io/your_imagekit_id/tr:q-40/default-image.jpg
+var_dump($response->videoCodec);
```
-### 5. Adding overlays
-
-ImageKit.io enables you to apply overlays to [images](https://docs.imagekit.io/features/image-transformations/overlay-using-layers) and [videos](https://docs.imagekit.io/features/video-transformation/overlay) using the raw parameter with the concept of [layers](https://docs.imagekit.io/features/image-transformations/overlay-using-layers#layers). The raw parameter facilitates incorporating transformations directly in the URL. A layer is a distinct type of transformation that allows you to define an asset to serve as an overlay, along with its positioning and additional transformations.
-
-#### Text as overlays
+### Value Objects
-You can add any text string over a base video or image using a text layer (l-text).
-
-For example:
-
-```php
-$imageURL = $imageKit->url(array(
- 'path' => '/default-image.jpg',
- 'urlEndpoint' => 'https://ik.imagekit.io/your_imagekit_id'
-
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- 'raw': "l-text,i-Imagekit,fs-50,l-end"
- ]
- ]
-));
-```
-#### Sample Result URL
-```
-https://ik.imagekit.io/your_imagekit_id/tr:h-300,w-400,l-text,i-Imagekit,fs-50,l-end/default-image.jpg
-```
+It is recommended to use the static `with` constructor `Dog::with(name: "Joey")`
+and named parameters to initialize value objects.
-#### Image as overlays
+However, builders are also provided `(new Dog)->withName("Joey")`.
-You can add an image over a base video or image using an image layer (l-image).
+### Handling errors
-For example:
+When the library is unable to connect to the API, or if the API returns a non-success status code (i.e., 4xx or 5xx response), a subclass of `ImageKit\Core\Exceptions\APIException` will be thrown:
```php
-$imageURL = $imageKit->url(array(
- 'path' => '/default-image.jpg',
- 'urlEndpoint' => 'https://ik.imagekit.io/your_imagekit_id'
-
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- 'raw': "l-image,i-default-image.jpg,w-100,b-10_CDDC39,l-end"
- ]
- ]
-));
-```
-#### Sample Result URL
-```
-https://ik.imagekit.io/your_imagekit_id/tr:h-300,w-400,l-image,i-default-image.jpg,w-100,b-10_CDDC39,l-end/default-image.jpg
-```
+url(array(
- 'path' => '/img/sample-video.mp4',
- 'urlEndpoint' => 'https://ik.imagekit.io/your_imagekit_id'
-
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- 'raw': "l-image,i-ik_canvas,bg-FF0000,w-300,h-100,l-end"
- ]
- ]
-));
-```
-#### Sample Result URL
-```
-https://ik.imagekit.io/your_imagekit_id/tr:h-300,w-400,l-image,i-ik_canvas,bg-FF0000,w-300,h-100,l-end/img/sample-video.mp4
-```
-
-### 6. Arithmetic expressions in transformations
-
-ImageKit allows use of [arithmetic expressions](https://docs.imagekit.io/features/arithmetic-expressions-in-transformations) in certain dimension and position-related parameters, making media transformations more flexible and dynamic.
-
-For example:
-
-```php
-$imageURL = $imageKit->url(array(
- 'path' => '/default-image.jpg',
- 'urlEndpoint' => 'https://ik.imagekit.io/your_imagekit_id'
- 'transformation' => [
- [
- "height": "ih_div_2",
- "width": "iw_div_4",
- "border": "cw_mul_0.05_yellow"
- ]
- ]
-));
-```
-
-#### Sample Result URL
-```
-https://ik.imagekit.io/your_imagekit_id/default-image.jpg?tr=w-iw_div_4,h-ih_div_2,b-cw_mul_0.05_yellow
-``
-
-### 7. Signed URL
-
-For example, the signed URL expires in 300 seconds with the default URL endpoint and other query parameters.
-For a detailed explanation of the signed URL, refer to this [documentation](https://docs.imagekit.io/features/security/signed-urls).
-
-#### Example
-```php
-$imageURL = $imageKit->url([
- "path" => "/default-image.jpg",
- "queryParameters" =>
- [
- "v" => "123"
- ],
- "transformation" => [
- [
- "height" => "300",
- "width" => "400"
- ]
- ],
- "signed" => true,
- "expireSeconds" => 300,
-]);
-```
-#### Response
-```
-https://ik.imagekit.io/your_imagekit_id/tr:h-300,w-400/default-image.jpg?v=123&ik-t=1654183277&ik-s=f98618f264a9ccb3c017e7b7441e86d1bc9a7ebb
-```
-
-You can manage [security settings](https://docs.imagekit.io/features/security#restricting-unsigned-urls) from the dashboard to prevent unsigned URLs usage. In that case, if the URL doesn't have a signature `ik-s` parameter or the signature is invalid, ImageKit will return a forbidden error instead of an actual image.
-
-### List of supported transformations
-
-The complete list of transformations supported and their usage in ImageKit can be found in the docs for [images](https://docs.imagekit.io/features/image-transformations) and [videos](https://docs.imagekit.io/features/video-transformation). The SDK gives a name to each transformation parameter, making the code simpler, making the code simpler, and readable.
-
-If a transformation is supported in ImageKit, but a name for it cannot be found in the table below, then use the transformation code from ImageKit docs as the name when using the `url` function.
-
-If you want to generate transformations in your application and add them to the URL as it is, use the `raw` parameter.
-
-| Supported Transformation Name | Translates to parameter |
-|-------------------------------|-------------------------|
-| height | h |
-| width | w |
-| aspectRatio | ar |
-| quality | q |
-| crop | c |
-| cropMode | cm |
-| x | x |
-| y | y |
-| focus | fo |
-| format | f |
-| radius | r |
-| background | bg |
-| border | b |
-| rotation | rt |
-| blur | bl |
-| named | n |
-| progressive | pr |
-| lossless | lo |
-| trim | t |
-| metadata | md |
-| colorProfile | cp |
-| defaultImage | di |
-| dpr | dpr |
-| effectSharpen | e-sharpen |
-| effectUSM | e-usm |
-| effectContrast | e-contrast |
-| effectGray | e-grayscale |
-| effectShadow | e-shadow |
-| effectGradient | e-gradient |
-| original | orig |
-| raw | `replaced by the parameter value` |
-
-
-## Server-side File Upload
-
-The SDK provides a simple interface using the `$imageKit->uploadFile()` method to upload files to the [ImageKit Media Library](https://imagekit.io/dashboard/media-library).
-
-- [Server-side file upload API](https://docs.imagekit.io/api-reference/upload-file-api/server-side-file-upload).
-- [Supported file types and extensions](https://docs.imagekit.io/api-reference/upload-file-api#allowed-file-types-for-uploading).
-
-#### Basic Usage
-```php
-$uploadFile = $imageKit->uploadFile([
- 'file' => 'your_file', // required, "binary","base64" or "file url"
- 'fileName' => 'your_file_name.jpg', // required
- 'checks' => '"file.size" < "1mb"', // optional `checks` parameters can be used to run server-side checks before files are uploaded to the Media Library.
-]);
-```
-#### Response
-```json
-{
- "error": null,
- "result": {
- "fileId": "6286329dfef1b033aee60211",
- "name": "your_file_name_S-PgGysnR.jpg",
- "size": 94466,
- "versionInfo": {
- "id": "6286329dfef1b033aee60211",
- "name": "Version 1"
- },
- "filePath": "/your_file_name_S-PgGysnR.jpg",
- "url": "https://ik.imagekit.io/demo/your_file_name_S-PgGysnR.jpg",
- "fileType": "image",
- "height": 640,
- "width": 960,
- "thumbnailUrl": "https://ik.imagekit.io/demo/tr:n-ik_ml_thumbnail/your_file_name_S-PgGysnR.jpg",
- "tags": [],
- "AITags": null,
- "customMetadata": { },
- "extensionStatus": {}
- },
- "responseMetadata":{
- "headers":{
- "access-control-allow-origin": "*",
- "x-ik-requestid": "e98f2464-2a86-4934-a5ab-9a226df012c9",
- "content-type": "application/json; charset=utf-8",
- "content-length": "434",
- "etag": 'W/"1b2-reNzjRCFNt45rEyD7yFY/dk+Ghg"',
- "date": "Thu, 16 Jun 2022 14:22:01 GMT",
- "x-request-id": "e98f2464-2a86-4934-a5ab-9a226df012c9"
- },
- "raw":{
- "fileId": "6286329dfef1b033aee60211",
- "name": "your_file_name_S-PgGysnR.jpg",
- "size": 94466,
- "versionInfo": {
- "id": "6286329dfef1b033aee60211",
- "name": "Version 1"
- },
- "filePath": "/your_file_name_S-PgGysnR.jpg",
- "url": "https://ik.imagekit.io/demo/your_file_name_S-PgGysnR.jpg",
- "fileType": "image",
- "height": 640,
- "width": 960,
- "thumbnailUrl": "https://ik.imagekit.io/demo/tr:n-ik_ml_thumbnail/your_file_name_S-PgGysnR.jpg",
- "tags": [],
- "AITags": null,
- "customMetadata": { },
- "extensionStatus": {}
- },
- "statusCode":200
- }
+try {
+ $response = $client->files->upload(
+ file: FileParam::fromString('https://www.example.com/public-url.jpg', filename: uniqid('file-upload-', true)),
+ fileName: 'file-name.jpg',
+ );
+} catch (APIConnectionException $e) {
+ echo "The server could not be reached", PHP_EOL;
+ var_dump($e->getPrevious());
+} catch (RateLimitException $e) {
+ echo "A 429 status code was received; we should back off a bit.", PHP_EOL;
+} catch (APIStatusException $e) {
+ echo "Another non-200-range status code was received", PHP_EOL;
+ echo $e->getMessage();
}
```
-#### Optional Parameters
-Please refer to [server-side file upload API request structure](https://docs.imagekit.io/api-reference/upload-file-api/server-side-file-upload#request-structure-multipart-form-data) for a detailed explanation of mandatory and optional parameters.
-
-```php
-// Attempt File Uplaod
-$uploadFile = $imageKit->uploadFile([
- 'file' => 'your_file', // required, "binary","base64" or "file url"
- 'fileName' => 'your_file_name.jpg', // required
- // Optional Parameters
- "useUniqueFileName" => true, // true|false
- "tags" => implode(",",["abd", "def"]), // max: 500 chars
- "folder" => "/sample-folder",
- "isPrivateFile" => false, // true|false
- "customCoordinates" => implode(",", ["10", "10", "100", "100"]), // max: 500 chars
- "responseFields" => implode(",", ["tags", "customMetadata"]),
- "extensions" => [
- [
- "name" => "remove-bg",
- "options" => [ // refer https://docs.imagekit.io/extensions/overview
- "add_shadow" => true
- ]
- ]
- ],
- "webhookUrl" => "https://example.com/webhook",
- "overwriteFile" => true, // in case of false useUniqueFileName should be true
- "overwriteAITags" => true, // set to false in order to preserve overwriteAITags
- "overwriteTags" => true,
- "overwriteCustomMetadata" => true,
- 'transformation' => [
- 'pre' => 'l-text,i-Imagekit,fs-50,l-end',
- 'post' => [
- [
- 'type' => 'transformation',
- 'value' => 'h-100'
- ]
- ]
- ],
- 'checks' => '"file.size" < "1mb"', // optional `checks` parameters can be used to run server-side checks before files are uploaded to the Media Library.
- 'isPublished' => true,
- // "customMetadata" => [
- // "SKU" => "VS882HJ2JD",
- // "price" => 599.99,
- // ]
-]);
-```
-
-## File Management
-
-The SDK provides a simple interface for all the following [Media APIs](https://docs.imagekit.io/api-reference/media-api) to manage your files.
-
-### 1. List and Search Files
-
-This API can list all the uploaded files and folders in your [ImageKit.io](https://docs.imagekit.io/api-reference/media-api) media library.
-
-Refer to the [list and search file API](https://docs.imagekit.io/api-reference/media-api/list-and-search-files) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$listFiles = $imageKit->listFiles();
-```
-#### Applying Filters
-Filter out the files with an object specifying the parameters.
-
-```php
-$listFiles = $imageKit->listFiles([
- "type" => "file", // file, file-version or folder
- "sort" => "ASC_CREATED",
- "path" => "/", // folder path
- "fileType" => "all", // all, image, non-image
- "limit" => 10, // min:1, max:1000
- "skip" => 0, // min:0
-]);
-```
-
-#### Advance Search
-In addition, you can fine-tune your query by specifying various filters by generating a query string in a Lucene-like syntax and providing this generated string as the value of the `searchQuery`.
-
-```php
-$listFiles = $imageKit->listFiles([
- "searchQuery" => '(size < "1mb" AND width > 500) OR (tags IN ["summer-sale","banner"])',
-]);
-```
-Detailed documentation can be found here for [advance search queries](https://docs.imagekit.io/api-reference/media-api/list-and-search-files#advanced-search-queries).
-### 2. Get File Details
+Error codes are as follows:
-This API will get all the details and attributes of the current version of the asset.
+| Cause | Error Type |
+| ---------------- | ------------------------------ |
+| HTTP 400 | `BadRequestException` |
+| HTTP 401 | `AuthenticationException` |
+| HTTP 403 | `PermissionDeniedException` |
+| HTTP 404 | `NotFoundException` |
+| HTTP 409 | `ConflictException` |
+| HTTP 422 | `UnprocessableEntityException` |
+| HTTP 429 | `RateLimitException` |
+| HTTP >= 500 | `InternalServerException` |
+| Other HTTP error | `APIStatusException` |
+| Timeout | `APITimeoutException` |
+| Network error | `APIConnectionException` |
-Refer to the [get file details API](https://docs.imagekit.io/api-reference/media-api/get-file-details) for a better understanding of the **request & response structure**.
+### Retries
-#### Example
-```php
-$getFileDetails = $imageKit->getFileDetails('file_id');
-```
+Certain errors will be automatically retried 2 times by default, with a short exponential backoff.
-### 3. Get File Version Details
+Connection errors (for example, due to a network connectivity problem), 408 Request Timeout, 409 Conflict, 429 Rate Limit, >=500 Internal errors, and timeouts will all be retried by default.
-This API can get you all the details and attributes for the provided version of the file.
+You can use the `maxRetries` option to configure or disable this:
-Refer to the [get file version details API](https://docs.imagekit.io/api-reference/media-api/get-file-version-details) for a better understanding of the **request & response structure**.
-
-#### Example
```php
-$getFileVersionDetails = $imageKit->getFileVersionDetails('file_id','version_id');
-```
+getFileVersions('file_id');
-```
-
-### 5. Update File Details
-
-Update file details such as `tags`, `customCoordinates` attributes, remove existing `AITags`, and apply [extensions](https://docs.imagekit.io/extensions/overview) using update file details API. This operation can only be performed only on the current version of an asset.
-
-Refer to the [update file details API](https://docs.imagekit.io/api-reference/media-api/update-file-details) for better understanding about the **request & response structure**.
-
-#### Example
-```php
-// Update parameters
-$updateData = [
- "removeAITags" => "all", // "all" or ["tag1","tag2"]
- "webhookUrl" => "https://example.com/webhook",
- "extensions" => [
- [
- "name" => "remove-bg",
- "options" => [ // refer https://docs.imagekit.io/extensions/overview
- "add_shadow" => true
- ]
- ],
- [
- "name" => "google-auto-tagging",
- ]
- ],
- "tags" => ["tag1", "tag2"],
- "customCoordinates" => "10,10,100,100",
- // "customMetadata" => [
- // "SKU" => "VS882HJ2JD",
- // "price" => 599.99,
- // ]
-];
+// Configure the default for all requests:
+$client = new Client(requestOptions: ['maxRetries' => 0]);
-// Attempt Update
-$updateFileDetails = $imageKit->updateFileDetails(
- 'file_id',
- $updateData
+// Or, configure per-request:
+$result = $client->files->upload(
+ file: FileParam::fromString('https://www.example.com/public-url.jpg', filename: uniqid('file-upload-', true)),
+ fileName: 'file-name.jpg',
+ requestOptions: ['maxRetries' => 5],
);
```
-**Update publish status**
-
-If `publish` is included in the update options, no other parameters are allowed. If any are present, an error will be returned: `Your request cannot contain any other parameters when publish is present`.
-
-#### Example
-```php
-// Update parameters
-$updateData = [
- "publish" => [
- "isPublished" => true,
- "includeFileVersions" => true
- ]
-];
-
-// Attempt Update
-$updateFileDetails = $imageKit->updateFileDetails(
- 'file_id',
- $updateData
-);
-```
-
-### 6. Add Tags (Bulk) API
-
-Add tags to multiple files in a single request. The method accepts an array of `fileIds` of the files and an array of `tags` that have to be added to those files.
-
-Refer to the [add tags (Bulk) API](https://docs.imagekit.io/api-reference/media-api/add-tags-bulk) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$fileIds = ['file_id1','file_id2'];
-$tags = ['image_tag_1', 'image_tag_2'];
-
-$bulkAddTags = $imageKit->bulkAddTags($fileIds, $tags);
-```
-
-### 7. Remove Tags (Bulk) API
-
-Remove tags from multiple files in a single request. The method accepts an array of `fileIds` of the files and an array of `tags` that have to be removed from those files.
-
-Refer to the [remove tags (Bulk) API](https://docs.imagekit.io/api-reference/media-api/remove-tags-bulk) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$fileIds = ['file_id1','file_id2'];
-$tags = ['image_tag_1', 'image_tag_2'];
-
-$bulkRemoveTags = $imageKit->bulkRemoveTags($fileIds, $tags);
-```
-
-### 8. Remove AI Tags (Bulk) API
-
-Remove AI tags from multiple files in a single request. The method accepts an array of `fileIds` of the files and an array of `AITags` that have to be removed from those files.
-
-Refer to the [remove AI Tags (Bulk) API](https://docs.imagekit.io/api-reference/media-api/remove-aitags-bulk) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$fileIds = ['file_id1','file_id2'];
-$AITags = ['image_AITag_1', 'image_AITag_2'];
-
-$bulkRemoveTags = $imageKit->bulkRemoveTags($fileIds, $AITags);
-```
-
-### 9. Delete File API
-
-You can programmatically delete uploaded files in the media library using delete file API.
-
-> If a file or specific transformation has been requested in the past, then the response is cached. Deleting a file does not purge the cache. However, you can purge the cache using [Purge Cache API](#21-purge-cache-api).
-
-Refer to the [delete file API](https://docs.imagekit.io/api-reference/media-api/delete-file) for better understanding about the **request & response structure**.
-
-#### Basic Usage
-```php
-$fileId = 'file_id';
-$deleteFile = $imageKit->deleteFile($fileId);
-```
-
-### 10. Delete File Version API
-
-Using the delete file version API, you can programmatically delete the uploaded file version in the media library.
-
-> You can delete only the non-current version of a file.
-
-Refer to the [delete file version API](https://docs.imagekit.io/api-reference/media-api/delete-file-version) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$fileId = 'file_id';
-$versionId = 'version_id';
-$deleteFileVersion = $imageKit->deleteFileVersion($fileId, $versionId);
-```
-
-### 11. Delete Files (Bulk) API
+### File uploads
-Deletes multiple files and their versions from the media library.
+Request parameters that correspond to file uploads can be passed as a resource returned by `fopen()`, a string of file contents, or a `FileParam` instance.
-Refer to the [delete files (Bulk) API](https://docs.imagekit.io/api-reference/media-api/delete-files-bulk) for a better understanding of the **request & response structure**.
-
-#### Example
```php
-$fileIds = ["5e1c13d0c55ec3437c451406", ...];
-$deleteFiles = $imageKit->bulkDeleteFiles($fileIds);
-```
-
-
-### 12. Copy File API
-
-This will copy a file from one folder to another.
-
-> If any file at the destination has the same name as the source file, then the source file and its versions (if `includeFileVersions` is set to true) will be appended to the destination file version history.
-
-Refer to the [copy file API](https://docs.imagekit.io/api-reference/media-api/copy-file) for a better understanding of the **request & response structure**.
-
-#### Basic Usage
-```php
-$sourceFilePath = '/sample-folder1/sample-file.jpg';
-$destinationPath = '/sample-folder2/';
-$includeFileVersions = false;
-
-$copyFile = $imageKit->copy([
- 'sourceFilePath' => $sourceFilePath,
- 'destinationPath' => $destinationPath,
- 'includeFileVersions' => $includeFileVersions
-]);
-```
-
-### 13. Move File API
-
-This will move a file and all its versions from one folder to another.
-
-> If any file at the destination has the same name as the source file, then the source file and its versions will be appended to the destination file.
+move([
- 'sourceFilePath' => $sourceFilePath,
- 'destinationPath' => $destinationPath
-]);
-```
-
-### 14. Rename File API
-
-Using Rename File API, you can programmatically rename an already existing file in the media library. This operation would rename all versions of the file.
-
-> The old URLs will stop working. However, the file/file version URLs cached on CDN will continue to work unless a purge is requested.
-
-Refer to the [rename file API](https://docs.imagekit.io/api-reference/media-api/rename-file) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-// Purge Cache would default to false
-
-$filePath = '/sample-folder/sample-file.jpg';
-$newFileName = 'sample-file2.jpg';
-$renameFile = $imageKit->rename([
- 'filePath' => $filePath,
- 'newFileName' => $newFileName,
-]);
-```
-When `purgeCache` is set to `true`, response will return `purgeRequestId`. This `purgeRequestId` can be used to get the purge request status.
-```php
-$filePath = '/sample-folder/sample-file.jpg';
-$newFileName = 'sample-file2.jpg';
-$renameFile = $imageKit->rename([
- 'filePath' => $filePath,
- 'newFileName' => $newFileName,
-],true);
-```
-
-### 15. Restore File Version API
-
-This will restore the provided file version to a different version of the file. The newly restored version of the file will be returned in the response.
-
-Refer to the [restore file version API](https://docs.imagekit.io/api-reference/media-api/restore-file-version) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$fileId = 'fileId';
-$versionId = 'versionId';
-$restoreFileVersion = $imageKit->restoreFileVersion([
- 'fileId' => $fileId,
- 'versionId' => $versionId,
-]);
-```
-
-### 16. Create Folder API
-
-This will create a new folder. You can specify the folder name and location of the parent folder where this new folder should be created.
-
-Refer to the [create folder API](https://docs.imagekit.io/api-reference/media-api/create-folder) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$folderName = 'new-folder';
-$parentFolderPath = '/';
-$createFolder = $imageKit->createFolder([
- 'folderName' => $folderName,
- 'parentFolderPath' => $parentFolderPath,
-]);
-```
-
-### 17. Delete Folder API
-
-This will delete the specified folder and all nested files, their versions & folders. This action cannot be undone.
-
-Refer to the [delete folder API](https://docs.imagekit.io/api-reference/media-api/delete-folder) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$folderPath = '/new-folder';
-$deleteFolder = $imageKit->deleteFolder($folderPath);
-```
-
-### 18. Copy Folder API
-
-This will copy one folder into another.
-
-Refer to the [copy folder API](https://docs.imagekit.io/api-reference/media-api/copy-folder) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$sourceFolderPath = '/source-folder/';
-$destinationPath = '/destination-folder/';
-$includeFileVersions = false;
-$copyFolder = $imageKit->copyFolder([
- 'sourceFolderPath' => $sourceFolderPath,
- 'destinationPath' => $destinationPath,
- 'includeFileVersions' => $includeFileVersions
-]);
-```
-
-### 19. Move Folder API
-
-This will move one folder into another. The selected folder, its nested folders, files, and their versions are moved in this operation.
-
-> If any file at the destination has the same name as the source file, then the source file and its versions will be appended to the destination file version history.
-
-Refer to the [move folder API](https://docs.imagekit.io/api-reference/media-api/move-folder) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$sourceFolderPath = '/sample-folder/';
-$destinationPath = '/destination-folder/';
-$moveFolder = $imageKit->moveFolder([
- 'sourceFolderPath' => $sourceFolderPath,
- 'destinationPath' => $destinationPath
-]);
-```
-
-### 20. Bulk Job Status API
-
-This endpoint allows you to get the status of a bulk operation e.g. [Copy Folder API](#18-copy-folder-api) or [Move Folder API](#19-move-folder-api).
-
-Refer to the [bulk job status API](https://docs.imagekit.io/api-reference/media-api/copy-move-folder-status) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$jobId = 'jobId';
-$bulkJobStatus = $imageKit->getBulkJobStatus($jobId);
-```
-
-### 21. Purge Cache API
-
-This will purge CDN and ImageKit.io's internal cache. In response, `requestId` is returned, which can be used to fetch the status of the submitted purge request with [Purge Cache Status API](#22-purge-cache-status-api).
-
-Refer to the [Purge Cache API](https://docs.imagekit.io/api-reference/media-api/purge-cache) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$image_url = 'https://ik.imagekit.io/demo/sample-folder/sample-file.jpg';
-$purgeCache = $imageKit->purgeCache($image_url);
-```
-
-You can purge the cache for multiple files. Check [purge cache multiple files](https://docs.imagekit.io/api-reference/media-api/purge-cache#purge-cache-for-multiple-files).
-
-### 22. Purge Cache Status API
-
-Get the purge cache request status using the `requestId` returned when a purge cache request gets submitted with [Purge Cache API](#21-purge-cache-api)
-
-Refer to the [Purge Cache Status API](https://docs.imagekit.io/api-reference/media-api/purge-cache-status) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$cacheRequestId = '598821f949c0a938d57563bd';
-$purgeCacheStatus = $imageKit->purgeCacheStatus($cacheRequestId);
-```
-
-### 23. Get File Metadata API (From File ID)
-
-Get the image EXIF, pHash, and other metadata for uploaded files in the ImageKit.io media library using this API.
-
-Refer to the [get image metadata for uploaded media files API](https://docs.imagekit.io/api-reference/metadata-api/get-image-metadata-for-uploaded-media-files) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$fileId = '598821f949c0a938d57563bd';
-$getFileMetadata = $imageKit->getFileMetaData($fileId);
-```
-
-### 24. Get File Metadata API (From Remote URL)
-
-Get image EXIF, pHash, and other metadata from ImageKit.io powered remote URL using this API.
-
-Refer to the [get image metadata from remote URL API](https://docs.imagekit.io/api-reference/metadata-api/get-image-metadata-from-remote-url) for a better understanding of the **request & response structure**.
+// Pass a string with filename and content type:
+$contents = file_get_contents('/path/to/file');
+// Pass a string with filename and content type:
+$response = $client->files->upload(
+ file: FileParam::fromString($contents, filename: '/path/to/file', contentType: '…'),
+);
-#### Example
-```php
-$image_url = 'https://ik.imagekit.io/demo/sample-folder/sample-file.jpg';
-$getFileMetadataFromRemoteURL = $imageKit->getFileMetadataFromRemoteURL($image_url);
+// Pass in only a string (where applicable)
+$response = $client->files->upload(file: '…');
+
+// Pass an open resource:
+$fd = fopen('/path/to/file', 'r');
+try {
+ $response = $client->files->upload(
+ file: FileParam::fromResource($fd, filename: '/path/to/file', contentType: '…'),
+ );
+} finally {
+ fclose($fd);
+}
```
-## Custom Metadata Fields API
-
-Imagekit.io allows you to define a `schema` for your metadata keys, and the value filled against that key will have to adhere to those rules. You can [create](#1-create-fields), [read](#2-get-fields) and [update](#3-update-fields) custom metadata rules and update your file with custom metadata value in [file update API](#5-update-file-details) or [file upload API](#server-side-file-upload).
-For a detailed explanation, refer to the [custom metadata fields documentation](https://docs.imagekit.io/api-reference/custom-metadata-fields-api).
+## Advanced concepts
+### Making custom or undocumented requests
-### 1. Create Fields
+#### Undocumented properties
-Create a custom metadata field with this API.
+You can send undocumented parameters to any endpoint, and read undocumented response properties, like so:
-Refer to the [create custom metadata fields API](https://docs.imagekit.io/api-reference/custom-metadata-fields-api/create-custom-metadata-field) for a better understanding of the **request & response structure**.
+Note: the `extra*` parameters of the same name overrides the documented parameters.
-#### Example
```php
-$body = [
- "name" => "price", // required
- "label" => "Unit Price", // required
- "schema" => [ // required
- "type" => 'Number', // required
- "minValue" => 1000,
- "maxValue" => 5000,
- ],
-];
-
-$createCustomMetadataField = $imageKit->createCustomMetadataField($body);
-```
-
-Check for the [allowed values in the schema](https://docs.imagekit.io/api-reference/custom-metadata-fields-api/create-custom-metadata-field#allowed-values-in-the-schema-object).
+getCustomMetadataField($includeDeleted);
-```
+use ImageKit\Core\FileParam;
-### 3. Update Fields
-
-Update an existing custom metadata field's `label` or `schema`.
-
-Refer to the [update custom metadata fields API](https://docs.imagekit.io/api-reference/custom-metadata-fields-api/update-custom-metadata-field) for a better understanding of the **request & response structure**.
-
-#### Example
-```php
-$customMetadataFieldId = '598821f949c0a938d57563dd';
-$body = [
- "label" => "Net Price",
- "schema" => [
- "type"=>'Number'
- ],
-];
-
-$updateCustomMetadataField = $imageKit->updateCustomMetadataField($customMetadataFieldId, $body);
+$response = $client->files->upload(
+ file: FileParam::fromString('https://www.example.com/public-url.jpg', filename: uniqid('file-upload-', true)),
+ fileName: 'file-name.jpg',
+ requestOptions: [
+ 'extraQueryParams' => ['my_query_parameter' => 'value'],
+ 'extraBodyParams' => ['my_body_parameter' => 'value'],
+ 'extraHeaders' => ['my-header' => 'value'],
+ ],
+);
```
-Check for the [allowed values in the schema](https://docs.imagekit.io/api-reference/custom-metadata-fields-api/create-custom-metadata-field#allowed-values-in-the-schema-object).
-
+#### Undocumented request params
-### 4. Delete Fields
+If you want to explicitly send an extra param, you can do so with the `extra_query`, `extra_body`, and `extra_headers` under the `request_options:` parameter when making a request, as seen in the examples above.
-Delete a custom metadata field.
+#### Undocumented endpoints
-Refer to the [delete custom metadata fields API](https://docs.imagekit.io/api-reference/custom-metadata-fields-api/delete-custom-metadata-field) for a better understanding of the **request & response structure**.
+To make requests to undocumented endpoints while retaining the benefit of auth, retries, and so on, you can make requests using `client.request`, like so:
-#### Example
```php
-$customMetadataFieldId = '598821f949c0a938d57563dd';
+deleteCustomMetadataField($customMetadataFieldId);
+$response = $client->request(
+ method: "post",
+ path: '/undocumented/endpoint',
+ query: ['dog' => 'woof'],
+ headers: ['useful-header' => 'interesting-value'],
+ body: ['hello' => 'world']
+);
```
+## Versioning
-## Utility functions
-
-We have included the following commonly used utility functions in this SDK.
+This package follows [SemVer](https://semver.org/spec/v2.0.0.html) conventions. As the library is in initial development and has a major version of `0`, APIs may change at any time.
-### Authentication parameter generation
+This package considers improvements to the (non-runtime) PHPDoc type definitions to be non-breaking changes.
-If you want to implement client-side file upload, you will need a `token`, `expiry` timestamp, and a valid `signature` for that upload. The SDK provides a simple method you can use in your code to generate these authentication parameters.
-
-_Note: The Private API Key should never be exposed in any client-side code. You must always generate these authentication parameters on the server-side_
-
-```php
-$imageKit->getAuthenticationParameters($token = "", $expire = 0);
-```
-
-Returns
-
-```json
-{
- "token": "5d1c4a22-54f2-40bb-9e8c-99daaeeb7307",
- "expire": 1654207193,
- "signature": "a03a88b814570a3d92919c16a1b8bd4491f053c3"
-}
-```
-
-Both the `token` and `expire` parameters are optional. If not specified, the SDK internally generates a random token and a valid expiry timestamp. The value of the `token` and `expire` used to create the signature is always returned in the response, whether they are provided in input or not.
-
-### Distance calculation between two pHash values
-
-Perceptual hashing allows you to construct a hash value that uniquely identifies an input image based on the contents of an image. [ImageKit.io metadata API](https://docs.imagekit.io/api-reference/metadata-api) returns the pHash value of an image in the response. You can use this value to find a duplicate (or similar) image by calculating the distance between the pHash value of the two images.
-
-This SDK exposes `pHashDistance` function to calculate the distance between two pHash values. It accepts two pHash hexadecimal strings and returns a numeric value indicative of the level of difference between the two images.
-
-```php
- $imageKit->pHashDistance($firstHash ,$secondHash);
-```
-
-#### Distance calculation examples
-
-```php
-$imageKit->pHashDistance('f06830ca9f1e3e90', 'f06830ca9f1e3e90');
-// output: 0 (same image)
-
-$imageKit->pHashDistance('2d5ad3936d2e015b', '2d6ed293db36a4fb');
-// output: 17 (similar images)
-
-$imageKit->pHashDistance('a4a65595ac94518b', '7838873e791f8400');
-// output: 37 (dissimilar images)
-```
-
-## Opening Issues
-If you encounter a bug with `imagekit-php` we would like to hear about it. Search the existing issues and try to make sure your problem doesn't already exist before opening a new issue. It's helpful if you include the version of `imagekit-php`, PHP version, and OS you're using. Please include a stack trace and a simple workflow to reproduce the case when appropriate, too.
-
-
-## Support
-
-For any feedback or to report any issues or general implementation support, please reach out to [support@imagekit.io](mailto:support@imagekit.io)
-
-## Resources
+## Requirements
-- [Main website](https://imagekit.io) - Main Website.
-- [Documentation](https://docs.imagekit.io) - For both getting started and in-depth SDK usage information.
-- [PHP quick start guide](https://docs.imagekit.io/getting-started/quickstart-guides/php)
+PHP 8.1.0 or higher.
-## License
+## Contributing
-Released under the MIT license.
\ No newline at end of file
+See [the contributing documentation](https://github.com/imagekit-developer/imagekit-php/tree/master/CONTRIBUTING.md).
diff --git a/SECURITY.md b/SECURITY.md
new file mode 100644
index 00000000..8e64327a
--- /dev/null
+++ b/SECURITY.md
@@ -0,0 +1,27 @@
+# Security Policy
+
+## Reporting Security Issues
+
+This SDK is generated by [Stainless Software Inc](http://stainless.com). Stainless takes security seriously, and encourages you to report any security vulnerability promptly so that appropriate action can be taken.
+
+To report a security issue, please contact the Stainless team at security@stainless.com.
+
+## Responsible Disclosure
+
+We appreciate the efforts of security researchers and individuals who help us maintain the security of
+SDKs we generate. If you believe you have found a security vulnerability, please adhere to responsible
+disclosure practices by allowing us a reasonable amount of time to investigate and address the issue
+before making any information public.
+
+## Reporting Non-SDK Related Security Issues
+
+If you encounter security issues that are not directly related to SDKs but pertain to the services
+or products provided by Image Kit, please follow the respective company's security reporting guidelines.
+
+### Image Kit Terms and Policies
+
+Please contact developer@imagekit.io for any questions or concerns regarding the security of our services.
+
+---
+
+Thank you for helping us keep the SDKs and systems they interact with secure.
diff --git a/bin/check-release-environment b/bin/check-release-environment
new file mode 100644
index 00000000..85c90ff5
--- /dev/null
+++ b/bin/check-release-environment
@@ -0,0 +1,29 @@
+#!/usr/bin/env bash
+
+errors=()
+
+if [ -z "${RELEASE_PLEASE_TOKEN}" ]; then
+ errors+=("The RELEASE_PLEASE_TOKEN secret has not been set. Create a fine-grained GitHub PAT and add it as a repository secret.")
+fi
+
+if [ -z "${PACKAGIST_USERNAME}" ]; then
+ errors+=("The PACKAGIST_USERNAME secret has not been set. Please set it in either this repository's secrets or your organization secrets")
+fi
+
+if [ -z "${PACKAGIST_SAFE_KEY}" ]; then
+ errors+=("The PACKAGIST_SAFE_KEY secret has not been set. Please set it in either this repository's secrets or your organization secrets")
+fi
+
+lenErrors=${#errors[@]}
+
+if [[ lenErrors -gt 0 ]]; then
+ echo -e "Found the following errors in the release environment:\n"
+
+ for error in "${errors[@]}"; do
+ echo -e "- $error\n"
+ done
+
+ exit 1
+fi
+
+echo "The environment is ready to push releases!"
diff --git a/composer.json b/composer.json
index 32efa114..28e6cfee 100644
--- a/composer.json
+++ b/composer.json
@@ -1,46 +1,57 @@
{
- "authors": [
- {
- "name": "Imagekit",
- "homepage": "https://github.com/imagekit-developer/imagekit-php/graphs/contributors"
- }
+ "$schema": "https://getcomposer.org/schema.json",
+ "license": "Apache-2.0",
+ "autoload": {
+ "files": [
+ "src/Version.php"
],
- "autoload": {
- "psr-4": {
- "ImageKit\\": "src/ImageKit/"
- }
+ "psr-4": {
+ "ImageKit\\": "src/"
+ }
+ },
+ "autoload-dev": {
+ "psr-4": {
+ "Tests\\": "tests/"
+ }
+ },
+ "config": {
+ "allow-plugins": {
+ "pestphp/pest-plugin": true,
+ "php-http/discovery": false,
+ "phpstan/extension-installer": true
},
- "autoload-dev": {
- "psr-4": {
- "ImageKit\\Tests\\": "tests/"
- }
+ "platform": {
+ "php": "8.3"
},
- "description": "PHP library for Imagekit",
- "homepage": "https://github.com/imagekit-developer/imagekit-php",
- "keywords": [
- "library",
- "imagekit",
- "image management"
- ],
- "license": "MIT",
- "name": "imagekit/imagekit",
- "require": {
- "php": ">=5.6.0",
- "ext-curl": "*",
- "guzzlehttp/guzzle": "~6.0 || ~7.0",
- "ext-json": "*",
- "beberlei/assert": "^2.9.9"
- },
- "config": {
- "platform": {
- "php": "5.6"
- }
- },
- "require-dev": {
- "phpunit/phpunit": "^5.7.27"
- },
- "support": {
- "email": "support@imagekit.io"
- },
- "type": "library"
+ "preferred-install": "dist",
+ "sort-packages": true
+ },
+ "description": "Image Kit PHP SDK",
+ "name": "imagekit/imagekit",
+ "require": {
+ "php": "^8.1",
+ "php-http/discovery": "^1",
+ "psr/http-client": "^1",
+ "psr/http-client-implementation": "^1",
+ "psr/http-factory-implementation": "^1",
+ "psr/http-message": "^1|^2",
+ "standard-webhooks/standard-webhooks": "^1"
+ },
+ "require-dev": {
+ "friendsofphp/php-cs-fixer": "^3",
+ "guzzlehttp/guzzle": "^7",
+ "nyholm/psr7": "^1",
+ "pestphp/pest": "^3",
+ "php-http/mock-client": "^1",
+ "phpstan/extension-installer": "^1",
+ "phpstan/phpstan": "^2",
+ "phpstan/phpstan-phpunit": "^2",
+ "phpunit/phpunit": "^11",
+ "symfony/http-client": "^7"
+ },
+ "scripts": {
+ "build:docs": "curl --etag-save ./vendor/ag.etags --etag-compare ./vendor/ag.etags --create-dirs --remote-name --output-dir ./vendor/bin --no-progress-meter -- https://github.com/ApiGen/ApiGen/releases/latest/download/apigen.phar && php ./vendor/bin/apigen.phar --output docs -- src",
+ "lint": "./scripts/lint",
+ "test": "./scripts/test"
+ }
}
diff --git a/composer.lock b/composer.lock
index 7594938f..d86fa57a 100644
--- a/composer.lock
+++ b/composer.lock
@@ -1,2395 +1,7099 @@
{
- "_readme": [
- "This file locks the dependencies of your project to a known state",
- "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
- "This file is @generated automatically"
- ],
- "content-hash": "39a1be44588c84272c5860de8d14993c",
- "packages": [
- {
- "name": "beberlei/assert",
- "version": "v2.9.9",
- "source": {
- "type": "git",
- "url": "https://github.com/beberlei/assert.git",
- "reference": "124317de301b7c91d5fce34c98bba2c6925bec95"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/beberlei/assert/zipball/124317de301b7c91d5fce34c98bba2c6925bec95",
- "reference": "124317de301b7c91d5fce34c98bba2c6925bec95",
- "shasum": ""
- },
- "require": {
- "ext-mbstring": "*",
- "php": ">=5.3"
- },
- "require-dev": {
- "friendsofphp/php-cs-fixer": "^2.1.1",
- "phpunit/phpunit": "^4.8.35|^5.7"
- },
- "type": "library",
- "autoload": {
- "files": [
- "lib/Assert/functions.php"
- ],
- "psr-4": {
- "Assert\\": "lib/Assert"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-2-Clause"
- ],
- "authors": [
- {
- "name": "Benjamin Eberlei",
- "email": "kontakt@beberlei.de",
- "role": "Lead Developer"
- },
- {
- "name": "Richard Quadling",
- "email": "rquadling@gmail.com",
- "role": "Collaborator"
- }
- ],
- "description": "Thin assertion library for input validation in business models.",
- "keywords": [
- "assert",
- "assertion",
- "validation"
- ],
- "support": {
- "issues": "https://github.com/beberlei/assert/issues",
- "source": "https://github.com/beberlei/assert/tree/v2.9.9"
- },
- "time": "2019-05-28T15:27:37+00:00"
- },
- {
- "name": "guzzlehttp/guzzle",
- "version": "6.5.8",
- "source": {
- "type": "git",
- "url": "https://github.com/guzzle/guzzle.git",
- "reference": "a52f0440530b54fa079ce76e8c5d196a42cad981"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/guzzle/guzzle/zipball/a52f0440530b54fa079ce76e8c5d196a42cad981",
- "reference": "a52f0440530b54fa079ce76e8c5d196a42cad981",
- "shasum": ""
- },
- "require": {
- "ext-json": "*",
- "guzzlehttp/promises": "^1.0",
- "guzzlehttp/psr7": "^1.9",
- "php": ">=5.5",
- "symfony/polyfill-intl-idn": "^1.17"
- },
- "require-dev": {
- "ext-curl": "*",
- "phpunit/phpunit": "^4.8.35 || ^5.7 || ^6.4 || ^7.0",
- "psr/log": "^1.1"
- },
- "suggest": {
- "psr/log": "Required for using the Log middleware"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "6.5-dev"
- }
- },
- "autoload": {
- "files": [
- "src/functions_include.php"
- ],
- "psr-4": {
- "GuzzleHttp\\": "src/"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Graham Campbell",
- "email": "hello@gjcampbell.co.uk",
- "homepage": "https://github.com/GrahamCampbell"
- },
- {
- "name": "Michael Dowling",
- "email": "mtdowling@gmail.com",
- "homepage": "https://github.com/mtdowling"
- },
- {
- "name": "Jeremy Lindblom",
- "email": "jeremeamia@gmail.com",
- "homepage": "https://github.com/jeremeamia"
- },
- {
- "name": "George Mponos",
- "email": "gmponos@gmail.com",
- "homepage": "https://github.com/gmponos"
- },
- {
- "name": "Tobias Nyholm",
- "email": "tobias.nyholm@gmail.com",
- "homepage": "https://github.com/Nyholm"
- },
- {
- "name": "Márk Sági-Kazár",
- "email": "mark.sagikazar@gmail.com",
- "homepage": "https://github.com/sagikazarmark"
- },
- {
- "name": "Tobias Schultze",
- "email": "webmaster@tubo-world.de",
- "homepage": "https://github.com/Tobion"
- }
- ],
- "description": "Guzzle is a PHP HTTP client library",
- "homepage": "http://guzzlephp.org/",
- "keywords": [
- "client",
- "curl",
- "framework",
- "http",
- "http client",
- "rest",
- "web service"
- ],
- "support": {
- "issues": "https://github.com/guzzle/guzzle/issues",
- "source": "https://github.com/guzzle/guzzle/tree/6.5.8"
- },
- "funding": [
- {
- "url": "https://github.com/GrahamCampbell",
- "type": "github"
- },
- {
- "url": "https://github.com/Nyholm",
- "type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/guzzle",
- "type": "tidelift"
- }
- ],
- "time": "2022-06-20T22:16:07+00:00"
- },
- {
- "name": "guzzlehttp/promises",
- "version": "1.5.3",
- "source": {
- "type": "git",
- "url": "https://github.com/guzzle/promises.git",
- "reference": "67ab6e18aaa14d753cc148911d273f6e6cb6721e"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/guzzle/promises/zipball/67ab6e18aaa14d753cc148911d273f6e6cb6721e",
- "reference": "67ab6e18aaa14d753cc148911d273f6e6cb6721e",
- "shasum": ""
- },
- "require": {
- "php": ">=5.5"
- },
- "require-dev": {
- "symfony/phpunit-bridge": "^4.4 || ^5.1"
- },
- "type": "library",
- "autoload": {
- "files": [
- "src/functions_include.php"
- ],
- "psr-4": {
- "GuzzleHttp\\Promise\\": "src/"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Graham Campbell",
- "email": "hello@gjcampbell.co.uk",
- "homepage": "https://github.com/GrahamCampbell"
- },
- {
- "name": "Michael Dowling",
- "email": "mtdowling@gmail.com",
- "homepage": "https://github.com/mtdowling"
- },
- {
- "name": "Tobias Nyholm",
- "email": "tobias.nyholm@gmail.com",
- "homepage": "https://github.com/Nyholm"
- },
- {
- "name": "Tobias Schultze",
- "email": "webmaster@tubo-world.de",
- "homepage": "https://github.com/Tobion"
- }
- ],
- "description": "Guzzle promises library",
- "keywords": [
- "promise"
- ],
- "support": {
- "issues": "https://github.com/guzzle/promises/issues",
- "source": "https://github.com/guzzle/promises/tree/1.5.3"
- },
- "funding": [
- {
- "url": "https://github.com/GrahamCampbell",
- "type": "github"
- },
- {
- "url": "https://github.com/Nyholm",
- "type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/promises",
- "type": "tidelift"
- }
- ],
- "time": "2023-05-21T12:31:43+00:00"
- },
- {
- "name": "guzzlehttp/psr7",
- "version": "1.9.1",
- "source": {
- "type": "git",
- "url": "https://github.com/guzzle/psr7.git",
- "reference": "e4490cabc77465aaee90b20cfc9a770f8c04be6b"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/guzzle/psr7/zipball/e4490cabc77465aaee90b20cfc9a770f8c04be6b",
- "reference": "e4490cabc77465aaee90b20cfc9a770f8c04be6b",
- "shasum": ""
- },
- "require": {
- "php": ">=5.4.0",
- "psr/http-message": "~1.0",
- "ralouphie/getallheaders": "^2.0.5 || ^3.0.0"
- },
- "provide": {
- "psr/http-message-implementation": "1.0"
- },
- "require-dev": {
- "ext-zlib": "*",
- "phpunit/phpunit": "~4.8.36 || ^5.7.27 || ^6.5.14 || ^7.5.20 || ^8.5.8 || ^9.3.10"
- },
- "suggest": {
- "laminas/laminas-httphandlerrunner": "Emit PSR-7 responses"
- },
- "type": "library",
- "autoload": {
- "files": [
- "src/functions_include.php"
- ],
- "psr-4": {
- "GuzzleHttp\\Psr7\\": "src/"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Graham Campbell",
- "email": "hello@gjcampbell.co.uk",
- "homepage": "https://github.com/GrahamCampbell"
- },
- {
- "name": "Michael Dowling",
- "email": "mtdowling@gmail.com",
- "homepage": "https://github.com/mtdowling"
- },
- {
- "name": "George Mponos",
- "email": "gmponos@gmail.com",
- "homepage": "https://github.com/gmponos"
- },
- {
- "name": "Tobias Nyholm",
- "email": "tobias.nyholm@gmail.com",
- "homepage": "https://github.com/Nyholm"
- },
- {
- "name": "Márk Sági-Kazár",
- "email": "mark.sagikazar@gmail.com",
- "homepage": "https://github.com/sagikazarmark"
- },
- {
- "name": "Tobias Schultze",
- "email": "webmaster@tubo-world.de",
- "homepage": "https://github.com/Tobion"
- }
- ],
- "description": "PSR-7 message implementation that also provides common utility methods",
- "keywords": [
- "http",
- "message",
- "psr-7",
- "request",
- "response",
- "stream",
- "uri",
- "url"
- ],
- "support": {
- "issues": "https://github.com/guzzle/psr7/issues",
- "source": "https://github.com/guzzle/psr7/tree/1.9.1"
- },
- "funding": [
- {
- "url": "https://github.com/GrahamCampbell",
- "type": "github"
- },
- {
- "url": "https://github.com/Nyholm",
- "type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/psr7",
- "type": "tidelift"
- }
- ],
- "time": "2023-04-17T16:00:37+00:00"
- },
- {
- "name": "paragonie/random_compat",
- "version": "v2.0.21",
- "source": {
- "type": "git",
- "url": "https://github.com/paragonie/random_compat.git",
- "reference": "96c132c7f2f7bc3230723b66e89f8f150b29d5ae"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/paragonie/random_compat/zipball/96c132c7f2f7bc3230723b66e89f8f150b29d5ae",
- "reference": "96c132c7f2f7bc3230723b66e89f8f150b29d5ae",
- "shasum": ""
- },
- "require": {
- "php": ">=5.2.0"
- },
- "require-dev": {
- "phpunit/phpunit": "*"
- },
- "suggest": {
- "ext-libsodium": "Provides a modern crypto API that can be used to generate random bytes."
- },
- "type": "library",
- "autoload": {
- "files": [
- "lib/random.php"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Paragon Initiative Enterprises",
- "email": "security@paragonie.com",
- "homepage": "https://paragonie.com"
- }
- ],
- "description": "PHP 5.x polyfill for random_bytes() and random_int() from PHP 7",
- "keywords": [
- "csprng",
- "polyfill",
- "pseudorandom",
- "random"
- ],
- "support": {
- "email": "info@paragonie.com",
- "issues": "https://github.com/paragonie/random_compat/issues",
- "source": "https://github.com/paragonie/random_compat"
- },
- "time": "2022-02-16T17:07:03+00:00"
- },
- {
- "name": "psr/http-message",
- "version": "1.0.1",
- "source": {
- "type": "git",
- "url": "https://github.com/php-fig/http-message.git",
- "reference": "f6561bf28d520154e4b0ec72be95418abe6d9363"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/php-fig/http-message/zipball/f6561bf28d520154e4b0ec72be95418abe6d9363",
- "reference": "f6561bf28d520154e4b0ec72be95418abe6d9363",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.0"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.0.x-dev"
- }
- },
- "autoload": {
- "psr-4": {
- "Psr\\Http\\Message\\": "src/"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "PHP-FIG",
- "homepage": "http://www.php-fig.org/"
- }
- ],
- "description": "Common interface for HTTP messages",
- "homepage": "https://github.com/php-fig/http-message",
- "keywords": [
- "http",
- "http-message",
- "psr",
- "psr-7",
- "request",
- "response"
- ],
- "support": {
- "source": "https://github.com/php-fig/http-message/tree/master"
- },
- "time": "2016-08-06T14:39:51+00:00"
- },
- {
- "name": "ralouphie/getallheaders",
- "version": "3.0.3",
- "source": {
- "type": "git",
- "url": "https://github.com/ralouphie/getallheaders.git",
- "reference": "120b605dfeb996808c31b6477290a714d356e822"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/ralouphie/getallheaders/zipball/120b605dfeb996808c31b6477290a714d356e822",
- "reference": "120b605dfeb996808c31b6477290a714d356e822",
- "shasum": ""
- },
- "require": {
- "php": ">=5.6"
- },
- "require-dev": {
- "php-coveralls/php-coveralls": "^2.1",
- "phpunit/phpunit": "^5 || ^6.5"
- },
- "type": "library",
- "autoload": {
- "files": [
- "src/getallheaders.php"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Ralph Khattar",
- "email": "ralph.khattar@gmail.com"
- }
- ],
- "description": "A polyfill for getallheaders.",
- "support": {
- "issues": "https://github.com/ralouphie/getallheaders/issues",
- "source": "https://github.com/ralouphie/getallheaders/tree/develop"
- },
- "time": "2019-03-08T08:55:37+00:00"
- },
- {
- "name": "symfony/polyfill-intl-idn",
- "version": "v1.19.0",
- "source": {
- "type": "git",
- "url": "https://github.com/symfony/polyfill-intl-idn.git",
- "reference": "4ad5115c0f5d5172a9fe8147675ec6de266d8826"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-intl-idn/zipball/4ad5115c0f5d5172a9fe8147675ec6de266d8826",
- "reference": "4ad5115c0f5d5172a9fe8147675ec6de266d8826",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.3",
- "symfony/polyfill-intl-normalizer": "^1.10",
- "symfony/polyfill-php70": "^1.10",
- "symfony/polyfill-php72": "^1.10"
- },
- "suggest": {
- "ext-intl": "For best performance"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-main": "1.19-dev"
- },
- "thanks": {
- "name": "symfony/polyfill",
- "url": "https://github.com/symfony/polyfill"
- }
- },
- "autoload": {
- "files": [
- "bootstrap.php"
- ],
- "psr-4": {
- "Symfony\\Polyfill\\Intl\\Idn\\": ""
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Laurent Bassin",
- "email": "laurent@bassin.info"
- },
- {
- "name": "Trevor Rowbotham",
- "email": "trevor.rowbotham@pm.me"
- },
- {
- "name": "Symfony Community",
- "homepage": "https://symfony.com/contributors"
- }
- ],
- "description": "Symfony polyfill for intl's idn_to_ascii and idn_to_utf8 functions",
- "homepage": "https://symfony.com",
- "keywords": [
- "compatibility",
- "idn",
- "intl",
- "polyfill",
- "portable",
- "shim"
- ],
- "support": {
- "source": "https://github.com/symfony/polyfill-intl-idn/tree/v1.19.0"
- },
- "funding": [
- {
- "url": "https://symfony.com/sponsor",
- "type": "custom"
- },
- {
- "url": "https://github.com/fabpot",
- "type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
- "type": "tidelift"
- }
- ],
- "time": "2020-10-21T09:57:48+00:00"
- },
- {
- "name": "symfony/polyfill-intl-normalizer",
- "version": "v1.19.0",
- "source": {
- "type": "git",
- "url": "https://github.com/symfony/polyfill-intl-normalizer.git",
- "reference": "8db0ae7936b42feb370840cf24de1a144fb0ef27"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-intl-normalizer/zipball/8db0ae7936b42feb370840cf24de1a144fb0ef27",
- "reference": "8db0ae7936b42feb370840cf24de1a144fb0ef27",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.3"
- },
- "suggest": {
- "ext-intl": "For best performance"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-main": "1.19-dev"
- },
- "thanks": {
- "name": "symfony/polyfill",
- "url": "https://github.com/symfony/polyfill"
- }
- },
- "autoload": {
- "files": [
- "bootstrap.php"
- ],
- "psr-4": {
- "Symfony\\Polyfill\\Intl\\Normalizer\\": ""
- },
- "classmap": [
- "Resources/stubs"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Nicolas Grekas",
- "email": "p@tchwork.com"
- },
- {
- "name": "Symfony Community",
- "homepage": "https://symfony.com/contributors"
- }
- ],
- "description": "Symfony polyfill for intl's Normalizer class and related functions",
- "homepage": "https://symfony.com",
- "keywords": [
- "compatibility",
- "intl",
- "normalizer",
- "polyfill",
- "portable",
- "shim"
- ],
- "support": {
- "source": "https://github.com/symfony/polyfill-intl-normalizer/tree/v1.19.0"
- },
- "funding": [
- {
- "url": "https://symfony.com/sponsor",
- "type": "custom"
- },
- {
- "url": "https://github.com/fabpot",
- "type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
- "type": "tidelift"
- }
- ],
- "time": "2020-10-23T09:01:57+00:00"
- },
- {
- "name": "symfony/polyfill-php70",
- "version": "v1.19.0",
- "source": {
- "type": "git",
- "url": "https://github.com/symfony/polyfill-php70.git",
- "reference": "3fe414077251a81a1b15b1c709faf5c2fbae3d4e"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-php70/zipball/3fe414077251a81a1b15b1c709faf5c2fbae3d4e",
- "reference": "3fe414077251a81a1b15b1c709faf5c2fbae3d4e",
- "shasum": ""
- },
- "require": {
- "paragonie/random_compat": "~1.0|~2.0|~9.99",
- "php": ">=5.3.3"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-main": "1.19-dev"
- },
- "thanks": {
- "name": "symfony/polyfill",
- "url": "https://github.com/symfony/polyfill"
- }
- },
- "autoload": {
- "files": [
- "bootstrap.php"
- ],
- "psr-4": {
- "Symfony\\Polyfill\\Php70\\": ""
- },
- "classmap": [
- "Resources/stubs"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Nicolas Grekas",
- "email": "p@tchwork.com"
- },
- {
- "name": "Symfony Community",
- "homepage": "https://symfony.com/contributors"
- }
- ],
- "description": "Symfony polyfill backporting some PHP 7.0+ features to lower PHP versions",
- "homepage": "https://symfony.com",
- "keywords": [
- "compatibility",
- "polyfill",
- "portable",
- "shim"
- ],
- "support": {
- "source": "https://github.com/symfony/polyfill-php70/tree/v1.19.0"
- },
- "funding": [
- {
- "url": "https://symfony.com/sponsor",
- "type": "custom"
- },
- {
- "url": "https://github.com/fabpot",
- "type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
- "type": "tidelift"
- }
- ],
- "time": "2020-10-23T09:01:57+00:00"
- },
- {
- "name": "symfony/polyfill-php72",
- "version": "v1.19.0",
- "source": {
- "type": "git",
- "url": "https://github.com/symfony/polyfill-php72.git",
- "reference": "beecef6b463b06954638f02378f52496cb84bacc"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-php72/zipball/beecef6b463b06954638f02378f52496cb84bacc",
- "reference": "beecef6b463b06954638f02378f52496cb84bacc",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.3"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-main": "1.19-dev"
- },
- "thanks": {
- "name": "symfony/polyfill",
- "url": "https://github.com/symfony/polyfill"
- }
- },
- "autoload": {
- "files": [
- "bootstrap.php"
- ],
- "psr-4": {
- "Symfony\\Polyfill\\Php72\\": ""
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Nicolas Grekas",
- "email": "p@tchwork.com"
- },
- {
- "name": "Symfony Community",
- "homepage": "https://symfony.com/contributors"
- }
- ],
- "description": "Symfony polyfill backporting some PHP 7.2+ features to lower PHP versions",
- "homepage": "https://symfony.com",
- "keywords": [
- "compatibility",
- "polyfill",
- "portable",
- "shim"
- ],
- "support": {
- "source": "https://github.com/symfony/polyfill-php72/tree/v1.19.0"
- },
- "funding": [
- {
- "url": "https://symfony.com/sponsor",
- "type": "custom"
- },
- {
- "url": "https://github.com/fabpot",
- "type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
- "type": "tidelift"
- }
- ],
- "time": "2020-10-23T09:01:57+00:00"
- }
- ],
- "packages-dev": [
- {
- "name": "doctrine/instantiator",
- "version": "1.0.5",
- "source": {
- "type": "git",
- "url": "https://github.com/doctrine/instantiator.git",
- "reference": "8e884e78f9f0eb1329e445619e04456e64d8051d"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/doctrine/instantiator/zipball/8e884e78f9f0eb1329e445619e04456e64d8051d",
- "reference": "8e884e78f9f0eb1329e445619e04456e64d8051d",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3,<8.0-DEV"
- },
- "require-dev": {
- "athletic/athletic": "~0.1.8",
- "ext-pdo": "*",
- "ext-phar": "*",
- "phpunit/phpunit": "~4.0",
- "squizlabs/php_codesniffer": "~2.0"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.0.x-dev"
- }
- },
- "autoload": {
- "psr-4": {
- "Doctrine\\Instantiator\\": "src/Doctrine/Instantiator/"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Marco Pivetta",
- "email": "ocramius@gmail.com",
- "homepage": "http://ocramius.github.com/"
- }
- ],
- "description": "A small, lightweight utility to instantiate objects in PHP without invoking their constructors",
- "homepage": "https://github.com/doctrine/instantiator",
- "keywords": [
- "constructor",
- "instantiate"
- ],
- "support": {
- "issues": "https://github.com/doctrine/instantiator/issues",
- "source": "https://github.com/doctrine/instantiator/tree/1.0.5"
- },
- "funding": [
- {
- "url": "https://www.doctrine-project.org/sponsorship.html",
- "type": "custom"
- },
- {
- "url": "https://www.patreon.com/phpdoctrine",
- "type": "patreon"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/doctrine%2Finstantiator",
- "type": "tidelift"
- }
- ],
- "time": "2015-06-14T21:17:01+00:00"
- },
- {
- "name": "myclabs/deep-copy",
- "version": "1.7.0",
- "source": {
- "type": "git",
- "url": "https://github.com/myclabs/DeepCopy.git",
- "reference": "3b8a3a99ba1f6a3952ac2747d989303cbd6b7a3e"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/myclabs/DeepCopy/zipball/3b8a3a99ba1f6a3952ac2747d989303cbd6b7a3e",
- "reference": "3b8a3a99ba1f6a3952ac2747d989303cbd6b7a3e",
- "shasum": ""
- },
- "require": {
- "php": "^5.6 || ^7.0"
- },
- "require-dev": {
- "doctrine/collections": "^1.0",
- "doctrine/common": "^2.6",
- "phpunit/phpunit": "^4.1"
- },
- "type": "library",
- "autoload": {
- "files": [
- "src/DeepCopy/deep_copy.php"
- ],
- "psr-4": {
- "DeepCopy\\": "src/DeepCopy/"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "description": "Create deep copies (clones) of your objects",
- "keywords": [
- "clone",
- "copy",
- "duplicate",
- "object",
- "object graph"
- ],
- "support": {
- "issues": "https://github.com/myclabs/DeepCopy/issues",
- "source": "https://github.com/myclabs/DeepCopy/tree/1.x"
- },
- "time": "2017-10-19T19:58:43+00:00"
- },
- {
- "name": "phpdocumentor/reflection-common",
- "version": "1.0.1",
- "source": {
- "type": "git",
- "url": "https://github.com/phpDocumentor/ReflectionCommon.git",
- "reference": "21bdeb5f65d7ebf9f43b1b25d404f87deab5bfb6"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/phpDocumentor/ReflectionCommon/zipball/21bdeb5f65d7ebf9f43b1b25d404f87deab5bfb6",
- "reference": "21bdeb5f65d7ebf9f43b1b25d404f87deab5bfb6",
- "shasum": ""
- },
- "require": {
- "php": ">=5.5"
- },
- "require-dev": {
- "phpunit/phpunit": "^4.6"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.0.x-dev"
- }
- },
- "autoload": {
- "psr-4": {
- "phpDocumentor\\Reflection\\": [
- "src"
- ]
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Jaap van Otterdijk",
- "email": "opensource@ijaap.nl"
- }
- ],
- "description": "Common reflection classes used by phpdocumentor to reflect the code structure",
- "homepage": "http://www.phpdoc.org",
- "keywords": [
- "FQSEN",
- "phpDocumentor",
- "phpdoc",
- "reflection",
- "static analysis"
- ],
- "support": {
- "issues": "https://github.com/phpDocumentor/ReflectionCommon/issues",
- "source": "https://github.com/phpDocumentor/ReflectionCommon/tree/master"
- },
- "time": "2017-09-11T18:02:19+00:00"
- },
- {
- "name": "phpdocumentor/reflection-docblock",
- "version": "3.3.2",
- "source": {
- "type": "git",
- "url": "https://github.com/phpDocumentor/ReflectionDocBlock.git",
- "reference": "bf329f6c1aadea3299f08ee804682b7c45b326a2"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/phpDocumentor/ReflectionDocBlock/zipball/bf329f6c1aadea3299f08ee804682b7c45b326a2",
- "reference": "bf329f6c1aadea3299f08ee804682b7c45b326a2",
- "shasum": ""
- },
- "require": {
- "php": "^5.6 || ^7.0",
- "phpdocumentor/reflection-common": "^1.0.0",
- "phpdocumentor/type-resolver": "^0.4.0",
- "webmozart/assert": "^1.0"
- },
- "require-dev": {
- "mockery/mockery": "^0.9.4",
- "phpunit/phpunit": "^4.4"
- },
- "type": "library",
- "autoload": {
- "psr-4": {
- "phpDocumentor\\Reflection\\": [
- "src/"
- ]
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Mike van Riel",
- "email": "me@mikevanriel.com"
- }
- ],
- "description": "With this component, a library can provide support for annotations via DocBlocks or otherwise retrieve information that is embedded in a DocBlock.",
- "support": {
- "issues": "https://github.com/phpDocumentor/ReflectionDocBlock/issues",
- "source": "https://github.com/phpDocumentor/ReflectionDocBlock/tree/release/3.x"
- },
- "time": "2017-11-10T14:09:06+00:00"
- },
- {
- "name": "phpdocumentor/type-resolver",
- "version": "0.4.0",
- "source": {
- "type": "git",
- "url": "https://github.com/phpDocumentor/TypeResolver.git",
- "reference": "9c977708995954784726e25d0cd1dddf4e65b0f7"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/phpDocumentor/TypeResolver/zipball/9c977708995954784726e25d0cd1dddf4e65b0f7",
- "reference": "9c977708995954784726e25d0cd1dddf4e65b0f7",
- "shasum": ""
- },
- "require": {
- "php": "^5.5 || ^7.0",
- "phpdocumentor/reflection-common": "^1.0"
- },
- "require-dev": {
- "mockery/mockery": "^0.9.4",
- "phpunit/phpunit": "^5.2||^4.8.24"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.0.x-dev"
- }
- },
- "autoload": {
- "psr-4": {
- "phpDocumentor\\Reflection\\": [
- "src/"
- ]
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Mike van Riel",
- "email": "me@mikevanriel.com"
- }
- ],
- "support": {
- "issues": "https://github.com/phpDocumentor/TypeResolver/issues",
- "source": "https://github.com/phpDocumentor/TypeResolver/tree/master"
- },
- "time": "2017-07-14T14:27:02+00:00"
- },
- {
- "name": "phpspec/prophecy",
- "version": "v1.10.3",
- "source": {
- "type": "git",
- "url": "https://github.com/phpspec/prophecy.git",
- "reference": "451c3cd1418cf640de218914901e51b064abb093"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/phpspec/prophecy/zipball/451c3cd1418cf640de218914901e51b064abb093",
- "reference": "451c3cd1418cf640de218914901e51b064abb093",
- "shasum": ""
- },
- "require": {
- "doctrine/instantiator": "^1.0.2",
- "php": "^5.3|^7.0",
- "phpdocumentor/reflection-docblock": "^2.0|^3.0.2|^4.0|^5.0",
- "sebastian/comparator": "^1.2.3|^2.0|^3.0|^4.0",
- "sebastian/recursion-context": "^1.0|^2.0|^3.0|^4.0"
- },
- "require-dev": {
- "phpspec/phpspec": "^2.5 || ^3.2",
- "phpunit/phpunit": "^4.8.35 || ^5.7 || ^6.5 || ^7.1"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.10.x-dev"
- }
- },
- "autoload": {
- "psr-4": {
- "Prophecy\\": "src/Prophecy"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Konstantin Kudryashov",
- "email": "ever.zet@gmail.com",
- "homepage": "http://everzet.com"
- },
- {
- "name": "Marcello Duarte",
- "email": "marcello.duarte@gmail.com"
- }
- ],
- "description": "Highly opinionated mocking framework for PHP 5.3+",
- "homepage": "https://github.com/phpspec/prophecy",
- "keywords": [
- "Double",
- "Dummy",
- "fake",
- "mock",
- "spy",
- "stub"
- ],
- "support": {
- "issues": "https://github.com/phpspec/prophecy/issues",
- "source": "https://github.com/phpspec/prophecy/tree/v1.10.3"
- },
- "time": "2020-03-05T15:02:03+00:00"
- },
- {
- "name": "phpunit/php-code-coverage",
- "version": "4.0.8",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/php-code-coverage.git",
- "reference": "ef7b2f56815df854e66ceaee8ebe9393ae36a40d"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/ef7b2f56815df854e66ceaee8ebe9393ae36a40d",
- "reference": "ef7b2f56815df854e66ceaee8ebe9393ae36a40d",
- "shasum": ""
- },
- "require": {
- "ext-dom": "*",
- "ext-xmlwriter": "*",
- "php": "^5.6 || ^7.0",
- "phpunit/php-file-iterator": "^1.3",
- "phpunit/php-text-template": "^1.2",
- "phpunit/php-token-stream": "^1.4.2 || ^2.0",
- "sebastian/code-unit-reverse-lookup": "^1.0",
- "sebastian/environment": "^1.3.2 || ^2.0",
- "sebastian/version": "^1.0 || ^2.0"
- },
- "require-dev": {
- "ext-xdebug": "^2.1.4",
- "phpunit/phpunit": "^5.7"
- },
- "suggest": {
- "ext-xdebug": "^2.5.1"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "4.0.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sb@sebastian-bergmann.de",
- "role": "lead"
- }
- ],
- "description": "Library that provides collection, processing, and rendering functionality for PHP code coverage information.",
- "homepage": "https://github.com/sebastianbergmann/php-code-coverage",
- "keywords": [
- "coverage",
- "testing",
- "xunit"
- ],
- "support": {
- "irc": "irc://irc.freenode.net/phpunit",
- "issues": "https://github.com/sebastianbergmann/php-code-coverage/issues",
- "source": "https://github.com/sebastianbergmann/php-code-coverage/tree/4.0"
- },
- "time": "2017-04-02T07:44:40+00:00"
- },
- {
- "name": "phpunit/php-file-iterator",
- "version": "1.4.5",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/php-file-iterator.git",
- "reference": "730b01bc3e867237eaac355e06a36b85dd93a8b4"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/730b01bc3e867237eaac355e06a36b85dd93a8b4",
- "reference": "730b01bc3e867237eaac355e06a36b85dd93a8b4",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.3"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.4.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sb@sebastian-bergmann.de",
- "role": "lead"
- }
- ],
- "description": "FilterIterator implementation that filters files based on a list of suffixes.",
- "homepage": "https://github.com/sebastianbergmann/php-file-iterator/",
- "keywords": [
- "filesystem",
- "iterator"
- ],
- "support": {
- "irc": "irc://irc.freenode.net/phpunit",
- "issues": "https://github.com/sebastianbergmann/php-file-iterator/issues",
- "source": "https://github.com/sebastianbergmann/php-file-iterator/tree/1.4.5"
- },
- "time": "2017-11-27T13:52:08+00:00"
- },
- {
- "name": "phpunit/php-text-template",
- "version": "1.2.1",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/php-text-template.git",
- "reference": "31f8b717e51d9a2afca6c9f046f5d69fc27c8686"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/31f8b717e51d9a2afca6c9f046f5d69fc27c8686",
- "reference": "31f8b717e51d9a2afca6c9f046f5d69fc27c8686",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.3"
- },
- "type": "library",
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de",
- "role": "lead"
- }
- ],
- "description": "Simple template engine.",
- "homepage": "https://github.com/sebastianbergmann/php-text-template/",
- "keywords": [
- "template"
- ],
- "support": {
- "issues": "https://github.com/sebastianbergmann/php-text-template/issues",
- "source": "https://github.com/sebastianbergmann/php-text-template/tree/1.2.1"
- },
- "time": "2015-06-21T13:50:34+00:00"
- },
- {
- "name": "phpunit/php-timer",
- "version": "1.0.9",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/php-timer.git",
- "reference": "3dcf38ca72b158baf0bc245e9184d3fdffa9c46f"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/3dcf38ca72b158baf0bc245e9184d3fdffa9c46f",
- "reference": "3dcf38ca72b158baf0bc245e9184d3fdffa9c46f",
- "shasum": ""
- },
- "require": {
- "php": "^5.3.3 || ^7.0"
- },
- "require-dev": {
- "phpunit/phpunit": "^4.8.35 || ^5.7 || ^6.0"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.0-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sb@sebastian-bergmann.de",
- "role": "lead"
- }
- ],
- "description": "Utility class for timing",
- "homepage": "https://github.com/sebastianbergmann/php-timer/",
- "keywords": [
- "timer"
- ],
- "support": {
- "issues": "https://github.com/sebastianbergmann/php-timer/issues",
- "source": "https://github.com/sebastianbergmann/php-timer/tree/master"
- },
- "time": "2017-02-26T11:10:40+00:00"
- },
- {
- "name": "phpunit/php-token-stream",
- "version": "1.4.12",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/php-token-stream.git",
- "reference": "1ce90ba27c42e4e44e6d8458241466380b51fa16"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/php-token-stream/zipball/1ce90ba27c42e4e44e6d8458241466380b51fa16",
- "reference": "1ce90ba27c42e4e44e6d8458241466380b51fa16",
- "shasum": ""
- },
- "require": {
- "ext-tokenizer": "*",
- "php": ">=5.3.3"
- },
- "require-dev": {
- "phpunit/phpunit": "~4.2"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.4-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de"
- }
- ],
- "description": "Wrapper around PHP's tokenizer extension.",
- "homepage": "https://github.com/sebastianbergmann/php-token-stream/",
- "keywords": [
- "tokenizer"
- ],
- "support": {
- "issues": "https://github.com/sebastianbergmann/php-token-stream/issues",
- "source": "https://github.com/sebastianbergmann/php-token-stream/tree/1.4"
- },
- "abandoned": true,
- "time": "2017-12-04T08:55:13+00:00"
- },
- {
- "name": "phpunit/phpunit",
- "version": "5.7.27",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/phpunit.git",
- "reference": "b7803aeca3ccb99ad0a506fa80b64cd6a56bbc0c"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/b7803aeca3ccb99ad0a506fa80b64cd6a56bbc0c",
- "reference": "b7803aeca3ccb99ad0a506fa80b64cd6a56bbc0c",
- "shasum": ""
- },
- "require": {
- "ext-dom": "*",
- "ext-json": "*",
- "ext-libxml": "*",
- "ext-mbstring": "*",
- "ext-xml": "*",
- "myclabs/deep-copy": "~1.3",
- "php": "^5.6 || ^7.0",
- "phpspec/prophecy": "^1.6.2",
- "phpunit/php-code-coverage": "^4.0.4",
- "phpunit/php-file-iterator": "~1.4",
- "phpunit/php-text-template": "~1.2",
- "phpunit/php-timer": "^1.0.6",
- "phpunit/phpunit-mock-objects": "^3.2",
- "sebastian/comparator": "^1.2.4",
- "sebastian/diff": "^1.4.3",
- "sebastian/environment": "^1.3.4 || ^2.0",
- "sebastian/exporter": "~2.0",
- "sebastian/global-state": "^1.1",
- "sebastian/object-enumerator": "~2.0",
- "sebastian/resource-operations": "~1.0",
- "sebastian/version": "^1.0.6|^2.0.1",
- "symfony/yaml": "~2.1|~3.0|~4.0"
- },
- "conflict": {
- "phpdocumentor/reflection-docblock": "3.0.2"
- },
- "require-dev": {
- "ext-pdo": "*"
- },
- "suggest": {
- "ext-xdebug": "*",
- "phpunit/php-invoker": "~1.1"
- },
- "bin": [
- "phpunit"
- ],
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "5.7.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de",
- "role": "lead"
- }
- ],
- "description": "The PHP Unit Testing framework.",
- "homepage": "https://phpunit.de/",
- "keywords": [
- "phpunit",
- "testing",
- "xunit"
- ],
- "support": {
- "issues": "https://github.com/sebastianbergmann/phpunit/issues",
- "source": "https://github.com/sebastianbergmann/phpunit/tree/5.7.27"
- },
- "time": "2018-02-01T05:50:59+00:00"
- },
- {
- "name": "phpunit/phpunit-mock-objects",
- "version": "3.4.4",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/phpunit-mock-objects.git",
- "reference": "a23b761686d50a560cc56233b9ecf49597cc9118"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/a23b761686d50a560cc56233b9ecf49597cc9118",
- "reference": "a23b761686d50a560cc56233b9ecf49597cc9118",
- "shasum": ""
- },
- "require": {
- "doctrine/instantiator": "^1.0.2",
- "php": "^5.6 || ^7.0",
- "phpunit/php-text-template": "^1.2",
- "sebastian/exporter": "^1.2 || ^2.0"
- },
- "conflict": {
- "phpunit/phpunit": "<5.4.0"
- },
- "require-dev": {
- "phpunit/phpunit": "^5.4"
- },
- "suggest": {
- "ext-soap": "*"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "3.2.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sb@sebastian-bergmann.de",
- "role": "lead"
- }
- ],
- "description": "Mock Object library for PHPUnit",
- "homepage": "https://github.com/sebastianbergmann/phpunit-mock-objects/",
- "keywords": [
- "mock",
- "xunit"
- ],
- "support": {
- "irc": "irc://irc.freenode.net/phpunit",
- "issues": "https://github.com/sebastianbergmann/phpunit-mock-objects/issues",
- "source": "https://github.com/sebastianbergmann/phpunit-mock-objects/tree/3.4"
- },
- "abandoned": true,
- "time": "2017-06-30T09:13:00+00:00"
- },
- {
- "name": "sebastian/code-unit-reverse-lookup",
- "version": "1.0.2",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/code-unit-reverse-lookup.git",
- "reference": "1de8cd5c010cb153fcd68b8d0f64606f523f7619"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/code-unit-reverse-lookup/zipball/1de8cd5c010cb153fcd68b8d0f64606f523f7619",
- "reference": "1de8cd5c010cb153fcd68b8d0f64606f523f7619",
- "shasum": ""
- },
- "require": {
- "php": ">=5.6"
- },
- "require-dev": {
- "phpunit/phpunit": "^8.5"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.0.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de"
- }
- ],
- "description": "Looks up which function or method a line of code belongs to",
- "homepage": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/",
- "support": {
- "issues": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/issues",
- "source": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/tree/1.0.2"
- },
- "funding": [
- {
- "url": "https://github.com/sebastianbergmann",
- "type": "github"
- }
- ],
- "time": "2020-11-30T08:15:22+00:00"
- },
- {
- "name": "sebastian/comparator",
- "version": "1.2.4",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/comparator.git",
- "reference": "2b7424b55f5047b47ac6e5ccb20b2aea4011d9be"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/2b7424b55f5047b47ac6e5ccb20b2aea4011d9be",
- "reference": "2b7424b55f5047b47ac6e5ccb20b2aea4011d9be",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.3",
- "sebastian/diff": "~1.2",
- "sebastian/exporter": "~1.2 || ~2.0"
- },
- "require-dev": {
- "phpunit/phpunit": "~4.4"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.2.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Jeff Welch",
- "email": "whatthejeff@gmail.com"
- },
- {
- "name": "Volker Dusch",
- "email": "github@wallbash.com"
- },
- {
- "name": "Bernhard Schussek",
- "email": "bschussek@2bepublished.at"
- },
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de"
- }
- ],
- "description": "Provides the functionality to compare PHP values for equality",
- "homepage": "http://www.github.com/sebastianbergmann/comparator",
- "keywords": [
- "comparator",
- "compare",
- "equality"
- ],
- "support": {
- "issues": "https://github.com/sebastianbergmann/comparator/issues",
- "source": "https://github.com/sebastianbergmann/comparator/tree/1.2"
- },
- "time": "2017-01-29T09:50:25+00:00"
- },
- {
- "name": "sebastian/diff",
- "version": "1.4.3",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/diff.git",
- "reference": "7f066a26a962dbe58ddea9f72a4e82874a3975a4"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/7f066a26a962dbe58ddea9f72a4e82874a3975a4",
- "reference": "7f066a26a962dbe58ddea9f72a4e82874a3975a4",
- "shasum": ""
- },
- "require": {
- "php": "^5.3.3 || ^7.0"
- },
- "require-dev": {
- "phpunit/phpunit": "^4.8.35 || ^5.7 || ^6.0"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.4-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Kore Nordmann",
- "email": "mail@kore-nordmann.de"
- },
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de"
- }
- ],
- "description": "Diff implementation",
- "homepage": "https://github.com/sebastianbergmann/diff",
- "keywords": [
- "diff"
- ],
- "support": {
- "issues": "https://github.com/sebastianbergmann/diff/issues",
- "source": "https://github.com/sebastianbergmann/diff/tree/1.4"
- },
- "time": "2017-05-22T07:24:03+00:00"
- },
- {
- "name": "sebastian/environment",
- "version": "2.0.0",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/environment.git",
- "reference": "5795ffe5dc5b02460c3e34222fee8cbe245d8fac"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/5795ffe5dc5b02460c3e34222fee8cbe245d8fac",
- "reference": "5795ffe5dc5b02460c3e34222fee8cbe245d8fac",
- "shasum": ""
- },
- "require": {
- "php": "^5.6 || ^7.0"
- },
- "require-dev": {
- "phpunit/phpunit": "^5.0"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "2.0.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de"
- }
- ],
- "description": "Provides functionality to handle HHVM/PHP environments",
- "homepage": "http://www.github.com/sebastianbergmann/environment",
- "keywords": [
- "Xdebug",
- "environment",
- "hhvm"
- ],
- "support": {
- "issues": "https://github.com/sebastianbergmann/environment/issues",
- "source": "https://github.com/sebastianbergmann/environment/tree/master"
- },
- "time": "2016-11-26T07:53:53+00:00"
- },
- {
- "name": "sebastian/exporter",
- "version": "2.0.0",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/exporter.git",
- "reference": "ce474bdd1a34744d7ac5d6aad3a46d48d9bac4c4"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/ce474bdd1a34744d7ac5d6aad3a46d48d9bac4c4",
- "reference": "ce474bdd1a34744d7ac5d6aad3a46d48d9bac4c4",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.3",
- "sebastian/recursion-context": "~2.0"
- },
- "require-dev": {
- "ext-mbstring": "*",
- "phpunit/phpunit": "~4.4"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "2.0.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Jeff Welch",
- "email": "whatthejeff@gmail.com"
- },
- {
- "name": "Volker Dusch",
- "email": "github@wallbash.com"
- },
- {
- "name": "Bernhard Schussek",
- "email": "bschussek@2bepublished.at"
- },
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de"
- },
- {
- "name": "Adam Harvey",
- "email": "aharvey@php.net"
- }
- ],
- "description": "Provides the functionality to export PHP variables for visualization",
- "homepage": "http://www.github.com/sebastianbergmann/exporter",
- "keywords": [
- "export",
- "exporter"
- ],
- "support": {
- "issues": "https://github.com/sebastianbergmann/exporter/issues",
- "source": "https://github.com/sebastianbergmann/exporter/tree/master"
- },
- "time": "2016-11-19T08:54:04+00:00"
- },
- {
- "name": "sebastian/global-state",
- "version": "1.1.1",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/global-state.git",
- "reference": "bc37d50fea7d017d3d340f230811c9f1d7280af4"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/global-state/zipball/bc37d50fea7d017d3d340f230811c9f1d7280af4",
- "reference": "bc37d50fea7d017d3d340f230811c9f1d7280af4",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.3"
- },
- "require-dev": {
- "phpunit/phpunit": "~4.2"
- },
- "suggest": {
- "ext-uopz": "*"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.0-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de"
- }
- ],
- "description": "Snapshotting of global state",
- "homepage": "http://www.github.com/sebastianbergmann/global-state",
- "keywords": [
- "global state"
- ],
- "support": {
- "issues": "https://github.com/sebastianbergmann/global-state/issues",
- "source": "https://github.com/sebastianbergmann/global-state/tree/1.1.1"
- },
- "time": "2015-10-12T03:26:01+00:00"
- },
- {
- "name": "sebastian/object-enumerator",
- "version": "2.0.1",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/object-enumerator.git",
- "reference": "1311872ac850040a79c3c058bea3e22d0f09cbb7"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/object-enumerator/zipball/1311872ac850040a79c3c058bea3e22d0f09cbb7",
- "reference": "1311872ac850040a79c3c058bea3e22d0f09cbb7",
- "shasum": ""
- },
- "require": {
- "php": ">=5.6",
- "sebastian/recursion-context": "~2.0"
- },
- "require-dev": {
- "phpunit/phpunit": "~5"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "2.0.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de"
- }
- ],
- "description": "Traverses array structures and object graphs to enumerate all referenced objects",
- "homepage": "https://github.com/sebastianbergmann/object-enumerator/",
- "support": {
- "issues": "https://github.com/sebastianbergmann/object-enumerator/issues",
- "source": "https://github.com/sebastianbergmann/object-enumerator/tree/master"
- },
- "time": "2017-02-18T15:18:39+00:00"
- },
- {
- "name": "sebastian/recursion-context",
- "version": "2.0.0",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/recursion-context.git",
- "reference": "2c3ba150cbec723aa057506e73a8d33bdb286c9a"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/recursion-context/zipball/2c3ba150cbec723aa057506e73a8d33bdb286c9a",
- "reference": "2c3ba150cbec723aa057506e73a8d33bdb286c9a",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.3"
- },
- "require-dev": {
- "phpunit/phpunit": "~4.4"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "2.0.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Jeff Welch",
- "email": "whatthejeff@gmail.com"
- },
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de"
- },
- {
- "name": "Adam Harvey",
- "email": "aharvey@php.net"
- }
- ],
- "description": "Provides functionality to recursively process PHP variables",
- "homepage": "http://www.github.com/sebastianbergmann/recursion-context",
- "support": {
- "issues": "https://github.com/sebastianbergmann/recursion-context/issues",
- "source": "https://github.com/sebastianbergmann/recursion-context/tree/master"
- },
- "time": "2016-11-19T07:33:16+00:00"
- },
- {
- "name": "sebastian/resource-operations",
- "version": "1.0.0",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/resource-operations.git",
- "reference": "ce990bb21759f94aeafd30209e8cfcdfa8bc3f52"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/resource-operations/zipball/ce990bb21759f94aeafd30209e8cfcdfa8bc3f52",
- "reference": "ce990bb21759f94aeafd30209e8cfcdfa8bc3f52",
- "shasum": ""
- },
- "require": {
- "php": ">=5.6.0"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "1.0.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de"
- }
- ],
- "description": "Provides a list of PHP built-in functions that operate on resources",
- "homepage": "https://www.github.com/sebastianbergmann/resource-operations",
- "support": {
- "issues": "https://github.com/sebastianbergmann/resource-operations/issues",
- "source": "https://github.com/sebastianbergmann/resource-operations/tree/master"
- },
- "time": "2015-07-28T20:34:47+00:00"
- },
- {
- "name": "sebastian/version",
- "version": "2.0.1",
- "source": {
- "type": "git",
- "url": "https://github.com/sebastianbergmann/version.git",
- "reference": "99732be0ddb3361e16ad77b68ba41efc8e979019"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/version/zipball/99732be0ddb3361e16ad77b68ba41efc8e979019",
- "reference": "99732be0ddb3361e16ad77b68ba41efc8e979019",
- "shasum": ""
- },
- "require": {
- "php": ">=5.6"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "2.0.x-dev"
- }
- },
- "autoload": {
- "classmap": [
- "src/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "BSD-3-Clause"
- ],
- "authors": [
- {
- "name": "Sebastian Bergmann",
- "email": "sebastian@phpunit.de",
- "role": "lead"
- }
- ],
- "description": "Library that helps with managing the version number of Git-hosted PHP projects",
- "homepage": "https://github.com/sebastianbergmann/version",
- "support": {
- "issues": "https://github.com/sebastianbergmann/version/issues",
- "source": "https://github.com/sebastianbergmann/version/tree/master"
- },
- "time": "2016-10-03T07:35:21+00:00"
- },
- {
- "name": "symfony/polyfill-ctype",
- "version": "v1.19.0",
- "source": {
- "type": "git",
- "url": "https://github.com/symfony/polyfill-ctype.git",
- "reference": "aed596913b70fae57be53d86faa2e9ef85a2297b"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/aed596913b70fae57be53d86faa2e9ef85a2297b",
- "reference": "aed596913b70fae57be53d86faa2e9ef85a2297b",
- "shasum": ""
- },
- "require": {
- "php": ">=5.3.3"
- },
- "suggest": {
- "ext-ctype": "For best performance"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-main": "1.19-dev"
- },
- "thanks": {
- "name": "symfony/polyfill",
- "url": "https://github.com/symfony/polyfill"
- }
- },
- "autoload": {
- "files": [
- "bootstrap.php"
- ],
- "psr-4": {
- "Symfony\\Polyfill\\Ctype\\": ""
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Gert de Pagter",
- "email": "BackEndTea@gmail.com"
- },
- {
- "name": "Symfony Community",
- "homepage": "https://symfony.com/contributors"
- }
- ],
- "description": "Symfony polyfill for ctype functions",
- "homepage": "https://symfony.com",
- "keywords": [
- "compatibility",
- "ctype",
- "polyfill",
- "portable"
- ],
- "support": {
- "source": "https://github.com/symfony/polyfill-ctype/tree/v1.19.0"
- },
- "funding": [
- {
- "url": "https://symfony.com/sponsor",
- "type": "custom"
- },
- {
- "url": "https://github.com/fabpot",
- "type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
- "type": "tidelift"
- }
- ],
- "time": "2020-10-23T09:01:57+00:00"
- },
- {
- "name": "symfony/yaml",
- "version": "v3.4.47",
- "source": {
- "type": "git",
- "url": "https://github.com/symfony/yaml.git",
- "reference": "88289caa3c166321883f67fe5130188ebbb47094"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/symfony/yaml/zipball/88289caa3c166321883f67fe5130188ebbb47094",
- "reference": "88289caa3c166321883f67fe5130188ebbb47094",
- "shasum": ""
- },
- "require": {
- "php": "^5.5.9|>=7.0.8",
- "symfony/polyfill-ctype": "~1.8"
- },
- "conflict": {
- "symfony/console": "<3.4"
- },
- "require-dev": {
- "symfony/console": "~3.4|~4.0"
- },
- "suggest": {
- "symfony/console": "For validating YAML files using the lint command"
- },
- "type": "library",
- "autoload": {
- "psr-4": {
- "Symfony\\Component\\Yaml\\": ""
- },
- "exclude-from-classmap": [
- "/Tests/"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Fabien Potencier",
- "email": "fabien@symfony.com"
- },
- {
- "name": "Symfony Community",
- "homepage": "https://symfony.com/contributors"
- }
- ],
- "description": "Symfony Yaml Component",
- "homepage": "https://symfony.com",
- "support": {
- "source": "https://github.com/symfony/yaml/tree/v3.4.47"
- },
- "funding": [
- {
- "url": "https://symfony.com/sponsor",
- "type": "custom"
- },
- {
- "url": "https://github.com/fabpot",
- "type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
- "type": "tidelift"
- }
- ],
- "time": "2020-10-24T10:57:07+00:00"
- },
- {
- "name": "webmozart/assert",
- "version": "1.9.1",
- "source": {
- "type": "git",
- "url": "https://github.com/webmozarts/assert.git",
- "reference": "bafc69caeb4d49c39fd0779086c03a3738cbb389"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/webmozarts/assert/zipball/bafc69caeb4d49c39fd0779086c03a3738cbb389",
- "reference": "bafc69caeb4d49c39fd0779086c03a3738cbb389",
- "shasum": ""
- },
- "require": {
- "php": "^5.3.3 || ^7.0 || ^8.0",
- "symfony/polyfill-ctype": "^1.8"
- },
- "conflict": {
- "phpstan/phpstan": "<0.12.20",
- "vimeo/psalm": "<3.9.1"
- },
- "require-dev": {
- "phpunit/phpunit": "^4.8.36 || ^7.5.13"
- },
- "type": "library",
- "autoload": {
- "psr-4": {
- "Webmozart\\Assert\\": "src/"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Bernhard Schussek",
- "email": "bschussek@gmail.com"
- }
- ],
- "description": "Assertions to validate method input/output with nice error messages.",
- "keywords": [
- "assert",
- "check",
- "validate"
- ],
- "support": {
- "issues": "https://github.com/webmozarts/assert/issues",
- "source": "https://github.com/webmozarts/assert/tree/1.9.1"
- },
- "time": "2020-07-08T17:02:28+00:00"
- }
- ],
- "aliases": [],
- "minimum-stability": "stable",
- "stability-flags": [],
- "prefer-stable": false,
- "prefer-lowest": false,
- "platform": {
- "php": ">=5.6.0",
+ "_readme": [
+ "This file locks the dependencies of your project to a known state",
+ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
+ "This file is @generated automatically"
+ ],
+ "content-hash": "ecd99353efa1e6aa997a3cdd27edad14",
+ "packages": [
+ {
+ "name": "php-http/discovery",
+ "version": "1.20.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-http/discovery.git",
+ "reference": "82fe4c73ef3363caed49ff8dd1539ba06044910d"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-http/discovery/zipball/82fe4c73ef3363caed49ff8dd1539ba06044910d",
+ "reference": "82fe4c73ef3363caed49ff8dd1539ba06044910d",
+ "shasum": ""
+ },
+ "require": {
+ "composer-plugin-api": "^1.0|^2.0",
+ "php": "^7.1 || ^8.0"
+ },
+ "conflict": {
+ "nyholm/psr7": "<1.0",
+ "zendframework/zend-diactoros": "*"
+ },
+ "provide": {
+ "php-http/async-client-implementation": "*",
+ "php-http/client-implementation": "*",
+ "psr/http-client-implementation": "*",
+ "psr/http-factory-implementation": "*",
+ "psr/http-message-implementation": "*"
+ },
+ "require-dev": {
+ "composer/composer": "^1.0.2|^2.0",
+ "graham-campbell/phpspec-skip-example-extension": "^5.0",
+ "php-http/httplug": "^1.0 || ^2.0",
+ "php-http/message-factory": "^1.0",
+ "phpspec/phpspec": "^5.1 || ^6.1 || ^7.3",
+ "sebastian/comparator": "^3.0.5 || ^4.0.8",
+ "symfony/phpunit-bridge": "^6.4.4 || ^7.0.1"
+ },
+ "type": "composer-plugin",
+ "extra": {
+ "class": "Http\\Discovery\\Composer\\Plugin",
+ "plugin-optional": true
+ },
+ "autoload": {
+ "psr-4": {
+ "Http\\Discovery\\": "src/"
+ },
+ "exclude-from-classmap": [
+ "src/Composer/Plugin.php"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Márk Sági-Kazár",
+ "email": "mark.sagikazar@gmail.com"
+ }
+ ],
+ "description": "Finds and installs PSR-7, PSR-17, PSR-18 and HTTPlug implementations",
+ "homepage": "http://php-http.org",
+ "keywords": [
+ "adapter",
+ "client",
+ "discovery",
+ "factory",
+ "http",
+ "message",
+ "psr17",
+ "psr7"
+ ],
+ "support": {
+ "issues": "https://github.com/php-http/discovery/issues",
+ "source": "https://github.com/php-http/discovery/tree/1.20.0"
+ },
+ "time": "2024-10-02T11:20:13+00:00"
+ },
+ {
+ "name": "psr/http-client",
+ "version": "1.0.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-fig/http-client.git",
+ "reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-fig/http-client/zipball/bb5906edc1c324c9a05aa0873d40117941e5fa90",
+ "reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.0 || ^8.0",
+ "psr/http-message": "^1.0 || ^2.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Psr\\Http\\Client\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "PHP-FIG",
+ "homepage": "https://www.php-fig.org/"
+ }
+ ],
+ "description": "Common interface for HTTP clients",
+ "homepage": "https://github.com/php-fig/http-client",
+ "keywords": [
+ "http",
+ "http-client",
+ "psr",
+ "psr-18"
+ ],
+ "support": {
+ "source": "https://github.com/php-fig/http-client"
+ },
+ "time": "2023-09-23T14:17:50+00:00"
+ },
+ {
+ "name": "psr/http-message",
+ "version": "2.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-fig/http-message.git",
+ "reference": "402d35bcb92c70c026d1a6a9883f06b2ead23d71"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-fig/http-message/zipball/402d35bcb92c70c026d1a6a9883f06b2ead23d71",
+ "reference": "402d35bcb92c70c026d1a6a9883f06b2ead23d71",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.2 || ^8.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.0.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Psr\\Http\\Message\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "PHP-FIG",
+ "homepage": "https://www.php-fig.org/"
+ }
+ ],
+ "description": "Common interface for HTTP messages",
+ "homepage": "https://github.com/php-fig/http-message",
+ "keywords": [
+ "http",
+ "http-message",
+ "psr",
+ "psr-7",
+ "request",
+ "response"
+ ],
+ "support": {
+ "source": "https://github.com/php-fig/http-message/tree/2.0"
+ },
+ "time": "2023-04-04T09:54:51+00:00"
+ },
+ {
+ "name": "standard-webhooks/standard-webhooks",
+ "version": "v1.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/standard-webhooks/standard-webhooks.git",
+ "reference": "b03a68fe8b1904de92ba1df669dc8bd9c8226df3"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/standard-webhooks/standard-webhooks/zipball/b03a68fe8b1904de92ba1df669dc8bd9c8226df3",
+ "reference": "b03a68fe8b1904de92ba1df669dc8bd9c8226df3",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^8.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^9.0 || ^10.0"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "StandardWebhooks\\": "libraries/php/src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "Standard Webhooks - Open source tools and guidelines for sending webhooks easily, securely, and reliably",
+ "homepage": "https://www.standardwebhooks.com",
+ "keywords": [
+ "hmac",
+ "signature",
+ "standard-webhooks",
+ "verification",
+ "webhooks"
+ ],
+ "support": {
+ "issues": "https://github.com/standard-webhooks/standard-webhooks/issues",
+ "source": "https://github.com/standard-webhooks/standard-webhooks/tree/v1.0.0"
+ },
+ "time": "2025-12-10T17:57:04+00:00"
+ }
+ ],
+ "packages-dev": [
+ {
+ "name": "brianium/paratest",
+ "version": "v7.8.5",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/paratestphp/paratest.git",
+ "reference": "9b324c8fc319cf9728b581c7a90e1c8f6361c5e5"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/paratestphp/paratest/zipball/9b324c8fc319cf9728b581c7a90e1c8f6361c5e5",
+ "reference": "9b324c8fc319cf9728b581c7a90e1c8f6361c5e5",
+ "shasum": ""
+ },
+ "require": {
+ "ext-dom": "*",
+ "ext-pcre": "*",
+ "ext-reflection": "*",
+ "ext-simplexml": "*",
+ "fidry/cpu-core-counter": "^1.3.0",
+ "jean85/pretty-package-versions": "^2.1.1",
+ "php": "~8.2.0 || ~8.3.0 || ~8.4.0 || ~8.5.0",
+ "phpunit/php-code-coverage": "^11.0.12",
+ "phpunit/php-file-iterator": "^5.1.0",
+ "phpunit/php-timer": "^7.0.1",
+ "phpunit/phpunit": "^11.5.46",
+ "sebastian/environment": "^7.2.1",
+ "symfony/console": "^6.4.22 || ^7.3.4 || ^8.0.3",
+ "symfony/process": "^6.4.20 || ^7.3.4 || ^8.0.3"
+ },
+ "require-dev": {
+ "doctrine/coding-standard": "^12.0.0",
+ "ext-pcov": "*",
+ "ext-posix": "*",
+ "phpstan/phpstan": "^2.1.33",
+ "phpstan/phpstan-deprecation-rules": "^2.0.3",
+ "phpstan/phpstan-phpunit": "^2.0.11",
+ "phpstan/phpstan-strict-rules": "^2.0.7",
+ "squizlabs/php_codesniffer": "^3.13.5",
+ "symfony/filesystem": "^6.4.13 || ^7.3.2 || ^8.0.1"
+ },
+ "bin": [
+ "bin/paratest",
+ "bin/paratest_for_phpstorm"
+ ],
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "ParaTest\\": [
+ "src/"
+ ]
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Brian Scaturro",
+ "email": "scaturrob@gmail.com",
+ "role": "Developer"
+ },
+ {
+ "name": "Filippo Tessarotto",
+ "email": "zoeslam@gmail.com",
+ "role": "Developer"
+ }
+ ],
+ "description": "Parallel testing for PHP",
+ "homepage": "https://github.com/paratestphp/paratest",
+ "keywords": [
+ "concurrent",
+ "parallel",
+ "phpunit",
+ "testing"
+ ],
+ "support": {
+ "issues": "https://github.com/paratestphp/paratest/issues",
+ "source": "https://github.com/paratestphp/paratest/tree/v7.8.5"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sponsors/Slamdunk",
+ "type": "github"
+ },
+ {
+ "url": "https://paypal.me/filippotessarotto",
+ "type": "paypal"
+ }
+ ],
+ "time": "2026-01-08T08:02:38+00:00"
+ },
+ {
+ "name": "clue/ndjson-react",
+ "version": "v1.3.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/clue/reactphp-ndjson.git",
+ "reference": "392dc165fce93b5bb5c637b67e59619223c931b0"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/clue/reactphp-ndjson/zipball/392dc165fce93b5bb5c637b67e59619223c931b0",
+ "reference": "392dc165fce93b5bb5c637b67e59619223c931b0",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3",
+ "react/stream": "^1.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^9.5 || ^5.7 || ^4.8.35",
+ "react/event-loop": "^1.2"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Clue\\React\\NDJson\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Christian Lück",
+ "email": "christian@clue.engineering"
+ }
+ ],
+ "description": "Streaming newline-delimited JSON (NDJSON) parser and encoder for ReactPHP.",
+ "homepage": "https://github.com/clue/reactphp-ndjson",
+ "keywords": [
+ "NDJSON",
+ "json",
+ "jsonlines",
+ "newline",
+ "reactphp",
+ "streaming"
+ ],
+ "support": {
+ "issues": "https://github.com/clue/reactphp-ndjson/issues",
+ "source": "https://github.com/clue/reactphp-ndjson/tree/v1.3.0"
+ },
+ "funding": [
+ {
+ "url": "https://clue.engineering/support",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/clue",
+ "type": "github"
+ }
+ ],
+ "time": "2022-12-23T10:58:28+00:00"
+ },
+ {
+ "name": "clue/stream-filter",
+ "version": "v1.7.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/clue/stream-filter.git",
+ "reference": "049509fef80032cb3f051595029ab75b49a3c2f7"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/clue/stream-filter/zipball/049509fef80032cb3f051595029ab75b49a3c2f7",
+ "reference": "049509fef80032cb3f051595029ab75b49a3c2f7",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36"
+ },
+ "type": "library",
+ "autoload": {
+ "files": [
+ "src/functions_include.php"
+ ],
+ "psr-4": {
+ "Clue\\StreamFilter\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Christian Lück",
+ "email": "christian@clue.engineering"
+ }
+ ],
+ "description": "A simple and modern approach to stream filtering in PHP",
+ "homepage": "https://github.com/clue/stream-filter",
+ "keywords": [
+ "bucket brigade",
+ "callback",
+ "filter",
+ "php_user_filter",
+ "stream",
+ "stream_filter_append",
+ "stream_filter_register"
+ ],
+ "support": {
+ "issues": "https://github.com/clue/stream-filter/issues",
+ "source": "https://github.com/clue/stream-filter/tree/v1.7.0"
+ },
+ "funding": [
+ {
+ "url": "https://clue.engineering/support",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/clue",
+ "type": "github"
+ }
+ ],
+ "time": "2023-12-20T15:40:13+00:00"
+ },
+ {
+ "name": "composer/pcre",
+ "version": "3.3.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/composer/pcre.git",
+ "reference": "b2bed4734f0cc156ee1fe9c0da2550420d99a21e"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/composer/pcre/zipball/b2bed4734f0cc156ee1fe9c0da2550420d99a21e",
+ "reference": "b2bed4734f0cc156ee1fe9c0da2550420d99a21e",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.4 || ^8.0"
+ },
+ "conflict": {
+ "phpstan/phpstan": "<1.11.10"
+ },
+ "require-dev": {
+ "phpstan/phpstan": "^1.12 || ^2",
+ "phpstan/phpstan-strict-rules": "^1 || ^2",
+ "phpunit/phpunit": "^8 || ^9"
+ },
+ "type": "library",
+ "extra": {
+ "phpstan": {
+ "includes": [
+ "extension.neon"
+ ]
+ },
+ "branch-alias": {
+ "dev-main": "3.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Composer\\Pcre\\": "src"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Jordi Boggiano",
+ "email": "j.boggiano@seld.be",
+ "homepage": "http://seld.be"
+ }
+ ],
+ "description": "PCRE wrapping library that offers type-safe preg_* replacements.",
+ "keywords": [
+ "PCRE",
+ "preg",
+ "regex",
+ "regular expression"
+ ],
+ "support": {
+ "issues": "https://github.com/composer/pcre/issues",
+ "source": "https://github.com/composer/pcre/tree/3.3.2"
+ },
+ "funding": [
+ {
+ "url": "https://packagist.com",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/composer",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/composer/composer",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2024-11-12T16:29:46+00:00"
+ },
+ {
+ "name": "composer/semver",
+ "version": "3.4.4",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/composer/semver.git",
+ "reference": "198166618906cb2de69b95d7d47e5fa8aa1b2b95"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/composer/semver/zipball/198166618906cb2de69b95d7d47e5fa8aa1b2b95",
+ "reference": "198166618906cb2de69b95d7d47e5fa8aa1b2b95",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.3.2 || ^7.0 || ^8.0"
+ },
+ "require-dev": {
+ "phpstan/phpstan": "^1.11",
+ "symfony/phpunit-bridge": "^3 || ^7"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "3.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Composer\\Semver\\": "src"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nils Adermann",
+ "email": "naderman@naderman.de",
+ "homepage": "http://www.naderman.de"
+ },
+ {
+ "name": "Jordi Boggiano",
+ "email": "j.boggiano@seld.be",
+ "homepage": "http://seld.be"
+ },
+ {
+ "name": "Rob Bast",
+ "email": "rob.bast@gmail.com",
+ "homepage": "http://robbast.nl"
+ }
+ ],
+ "description": "Semver library that offers utilities, version constraint parsing and validation.",
+ "keywords": [
+ "semantic",
+ "semver",
+ "validation",
+ "versioning"
+ ],
+ "support": {
+ "irc": "ircs://irc.libera.chat:6697/composer",
+ "issues": "https://github.com/composer/semver/issues",
+ "source": "https://github.com/composer/semver/tree/3.4.4"
+ },
+ "funding": [
+ {
+ "url": "https://packagist.com",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/composer",
+ "type": "github"
+ }
+ ],
+ "time": "2025-08-20T19:15:30+00:00"
+ },
+ {
+ "name": "composer/xdebug-handler",
+ "version": "3.0.5",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/composer/xdebug-handler.git",
+ "reference": "6c1925561632e83d60a44492e0b344cf48ab85ef"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/composer/xdebug-handler/zipball/6c1925561632e83d60a44492e0b344cf48ab85ef",
+ "reference": "6c1925561632e83d60a44492e0b344cf48ab85ef",
+ "shasum": ""
+ },
+ "require": {
+ "composer/pcre": "^1 || ^2 || ^3",
+ "php": "^7.2.5 || ^8.0",
+ "psr/log": "^1 || ^2 || ^3"
+ },
+ "require-dev": {
+ "phpstan/phpstan": "^1.0",
+ "phpstan/phpstan-strict-rules": "^1.1",
+ "phpunit/phpunit": "^8.5 || ^9.6 || ^10.5"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Composer\\XdebugHandler\\": "src"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "John Stevenson",
+ "email": "john-stevenson@blueyonder.co.uk"
+ }
+ ],
+ "description": "Restarts a process without Xdebug.",
+ "keywords": [
+ "Xdebug",
+ "performance"
+ ],
+ "support": {
+ "irc": "ircs://irc.libera.chat:6697/composer",
+ "issues": "https://github.com/composer/xdebug-handler/issues",
+ "source": "https://github.com/composer/xdebug-handler/tree/3.0.5"
+ },
+ "funding": [
+ {
+ "url": "https://packagist.com",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/composer",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/composer/composer",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2024-05-06T16:37:16+00:00"
+ },
+ {
+ "name": "doctrine/deprecations",
+ "version": "1.1.5",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/doctrine/deprecations.git",
+ "reference": "459c2f5dd3d6a4633d3b5f46ee2b1c40f57d3f38"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/doctrine/deprecations/zipball/459c2f5dd3d6a4633d3b5f46ee2b1c40f57d3f38",
+ "reference": "459c2f5dd3d6a4633d3b5f46ee2b1c40f57d3f38",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.1 || ^8.0"
+ },
+ "conflict": {
+ "phpunit/phpunit": "<=7.5 || >=13"
+ },
+ "require-dev": {
+ "doctrine/coding-standard": "^9 || ^12 || ^13",
+ "phpstan/phpstan": "1.4.10 || 2.1.11",
+ "phpstan/phpstan-phpunit": "^1.0 || ^2",
+ "phpunit/phpunit": "^7.5 || ^8.5 || ^9.6 || ^10.5 || ^11.5 || ^12",
+ "psr/log": "^1 || ^2 || ^3"
+ },
+ "suggest": {
+ "psr/log": "Allows logging deprecations via PSR-3 logger implementation"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Doctrine\\Deprecations\\": "src"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "A small layer on top of trigger_error(E_USER_DEPRECATED) or PSR-3 logging with options to disable all deprecations or selectively for packages.",
+ "homepage": "https://www.doctrine-project.org/",
+ "support": {
+ "issues": "https://github.com/doctrine/deprecations/issues",
+ "source": "https://github.com/doctrine/deprecations/tree/1.1.5"
+ },
+ "time": "2025-04-07T20:06:18+00:00"
+ },
+ {
+ "name": "evenement/evenement",
+ "version": "v3.0.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/igorw/evenement.git",
+ "reference": "0a16b0d71ab13284339abb99d9d2bd813640efbc"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/igorw/evenement/zipball/0a16b0d71ab13284339abb99d9d2bd813640efbc",
+ "reference": "0a16b0d71ab13284339abb99d9d2bd813640efbc",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^9 || ^6"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Evenement\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Igor Wiedler",
+ "email": "igor@wiedler.ch"
+ }
+ ],
+ "description": "Événement is a very simple event dispatching library for PHP",
+ "keywords": [
+ "event-dispatcher",
+ "event-emitter"
+ ],
+ "support": {
+ "issues": "https://github.com/igorw/evenement/issues",
+ "source": "https://github.com/igorw/evenement/tree/v3.0.2"
+ },
+ "time": "2023-08-08T05:53:35+00:00"
+ },
+ {
+ "name": "fidry/cpu-core-counter",
+ "version": "1.3.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/theofidry/cpu-core-counter.git",
+ "reference": "db9508f7b1474469d9d3c53b86f817e344732678"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/theofidry/cpu-core-counter/zipball/db9508f7b1474469d9d3c53b86f817e344732678",
+ "reference": "db9508f7b1474469d9d3c53b86f817e344732678",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.2 || ^8.0"
+ },
+ "require-dev": {
+ "fidry/makefile": "^0.2.0",
+ "fidry/php-cs-fixer-config": "^1.1.2",
+ "phpstan/extension-installer": "^1.2.0",
+ "phpstan/phpstan": "^2.0",
+ "phpstan/phpstan-deprecation-rules": "^2.0.0",
+ "phpstan/phpstan-phpunit": "^2.0",
+ "phpstan/phpstan-strict-rules": "^2.0",
+ "phpunit/phpunit": "^8.5.31 || ^9.5.26",
+ "webmozarts/strict-phpunit": "^7.5"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Fidry\\CpuCoreCounter\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Théo FIDRY",
+ "email": "theo.fidry@gmail.com"
+ }
+ ],
+ "description": "Tiny utility to get the number of CPU cores.",
+ "keywords": [
+ "CPU",
+ "core"
+ ],
+ "support": {
+ "issues": "https://github.com/theofidry/cpu-core-counter/issues",
+ "source": "https://github.com/theofidry/cpu-core-counter/tree/1.3.0"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/theofidry",
+ "type": "github"
+ }
+ ],
+ "time": "2025-08-14T07:29:31+00:00"
+ },
+ {
+ "name": "filp/whoops",
+ "version": "2.18.4",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/filp/whoops.git",
+ "reference": "d2102955e48b9fd9ab24280a7ad12ed552752c4d"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/filp/whoops/zipball/d2102955e48b9fd9ab24280a7ad12ed552752c4d",
+ "reference": "d2102955e48b9fd9ab24280a7ad12ed552752c4d",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.1 || ^8.0",
+ "psr/log": "^1.0.1 || ^2.0 || ^3.0"
+ },
+ "require-dev": {
+ "mockery/mockery": "^1.0",
+ "phpunit/phpunit": "^7.5.20 || ^8.5.8 || ^9.3.3",
+ "symfony/var-dumper": "^4.0 || ^5.0"
+ },
+ "suggest": {
+ "symfony/var-dumper": "Pretty print complex values better with var-dumper available",
+ "whoops/soap": "Formats errors as SOAP responses"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.7-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Whoops\\": "src/Whoops/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Filipe Dobreira",
+ "homepage": "https://github.com/filp",
+ "role": "Developer"
+ }
+ ],
+ "description": "php error handling for cool kids",
+ "homepage": "https://filp.github.io/whoops/",
+ "keywords": [
+ "error",
+ "exception",
+ "handling",
+ "library",
+ "throwable",
+ "whoops"
+ ],
+ "support": {
+ "issues": "https://github.com/filp/whoops/issues",
+ "source": "https://github.com/filp/whoops/tree/2.18.4"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/denis-sokolov",
+ "type": "github"
+ }
+ ],
+ "time": "2025-08-08T12:00:00+00:00"
+ },
+ {
+ "name": "friendsofphp/php-cs-fixer",
+ "version": "v3.92.5",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer.git",
+ "reference": "260cc8c4a1d2f6d2f22cd4f9c70aa72e55ebac58"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/PHP-CS-Fixer/PHP-CS-Fixer/zipball/260cc8c4a1d2f6d2f22cd4f9c70aa72e55ebac58",
+ "reference": "260cc8c4a1d2f6d2f22cd4f9c70aa72e55ebac58",
+ "shasum": ""
+ },
+ "require": {
+ "clue/ndjson-react": "^1.3",
+ "composer/semver": "^3.4",
+ "composer/xdebug-handler": "^3.0.5",
+ "ext-filter": "*",
+ "ext-hash": "*",
+ "ext-json": "*",
+ "ext-tokenizer": "*",
+ "fidry/cpu-core-counter": "^1.3",
+ "php": "^7.4 || ^8.0",
+ "react/child-process": "^0.6.6",
+ "react/event-loop": "^1.5",
+ "react/socket": "^1.16",
+ "react/stream": "^1.4",
+ "sebastian/diff": "^4.0.6 || ^5.1.1 || ^6.0.2 || ^7.0",
+ "symfony/console": "^5.4.47 || ^6.4.24 || ^7.0 || ^8.0",
+ "symfony/event-dispatcher": "^5.4.45 || ^6.4.24 || ^7.0 || ^8.0",
+ "symfony/filesystem": "^5.4.45 || ^6.4.24 || ^7.0 || ^8.0",
+ "symfony/finder": "^5.4.45 || ^6.4.24 || ^7.0 || ^8.0",
+ "symfony/options-resolver": "^5.4.45 || ^6.4.24 || ^7.0 || ^8.0",
+ "symfony/polyfill-mbstring": "^1.33",
+ "symfony/polyfill-php80": "^1.33",
+ "symfony/polyfill-php81": "^1.33",
+ "symfony/polyfill-php84": "^1.33",
+ "symfony/process": "^5.4.47 || ^6.4.24 || ^7.2 || ^8.0",
+ "symfony/stopwatch": "^5.4.45 || ^6.4.24 || ^7.0 || ^8.0"
+ },
+ "require-dev": {
+ "facile-it/paraunit": "^1.3.1 || ^2.7",
+ "infection/infection": "^0.31",
+ "justinrainbow/json-schema": "^6.6",
+ "keradus/cli-executor": "^2.3",
+ "mikey179/vfsstream": "^1.6.12",
+ "php-coveralls/php-coveralls": "^2.9",
+ "php-cs-fixer/phpunit-constraint-isidenticalstring": "^1.6",
+ "php-cs-fixer/phpunit-constraint-xmlmatchesxsd": "^1.6",
+ "phpunit/phpunit": "^9.6.31 || ^10.5.60 || ^11.5.46",
+ "symfony/polyfill-php85": "^1.33",
+ "symfony/var-dumper": "^5.4.48 || ^6.4.26 || ^7.4.0 || ^8.0",
+ "symfony/yaml": "^5.4.45 || ^6.4.30 || ^7.4.1 || ^8.0"
+ },
+ "suggest": {
+ "ext-dom": "For handling output formats in XML",
+ "ext-mbstring": "For handling non-UTF8 characters."
+ },
+ "bin": [
+ "php-cs-fixer"
+ ],
+ "type": "application",
+ "autoload": {
+ "psr-4": {
+ "PhpCsFixer\\": "src/"
+ },
+ "exclude-from-classmap": [
+ "src/**/Internal/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Dariusz Rumiński",
+ "email": "dariusz.ruminski@gmail.com"
+ }
+ ],
+ "description": "A tool to automatically fix PHP code style",
+ "keywords": [
+ "Static code analysis",
+ "fixer",
+ "standards",
+ "static analysis"
+ ],
+ "support": {
+ "issues": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/issues",
+ "source": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/tree/v3.92.5"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/keradus",
+ "type": "github"
+ }
+ ],
+ "time": "2026-01-08T21:57:37+00:00"
+ },
+ {
+ "name": "guzzlehttp/guzzle",
+ "version": "7.10.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/guzzle/guzzle.git",
+ "reference": "b51ac707cfa420b7bfd4e4d5e510ba8008e822b4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/guzzle/guzzle/zipball/b51ac707cfa420b7bfd4e4d5e510ba8008e822b4",
+ "reference": "b51ac707cfa420b7bfd4e4d5e510ba8008e822b4",
+ "shasum": ""
+ },
+ "require": {
+ "ext-json": "*",
+ "guzzlehttp/promises": "^2.3",
+ "guzzlehttp/psr7": "^2.8",
+ "php": "^7.2.5 || ^8.0",
+ "psr/http-client": "^1.0",
+ "symfony/deprecation-contracts": "^2.2 || ^3.0"
+ },
+ "provide": {
+ "psr/http-client-implementation": "1.0"
+ },
+ "require-dev": {
+ "bamarni/composer-bin-plugin": "^1.8.2",
"ext-curl": "*",
- "ext-json": "*"
+ "guzzle/client-integration-tests": "3.0.2",
+ "php-http/message-factory": "^1.1",
+ "phpunit/phpunit": "^8.5.39 || ^9.6.20",
+ "psr/log": "^1.1 || ^2.0 || ^3.0"
+ },
+ "suggest": {
+ "ext-curl": "Required for CURL handler support",
+ "ext-intl": "Required for Internationalized Domain Name (IDN) support",
+ "psr/log": "Required for using the Log middleware"
+ },
+ "type": "library",
+ "extra": {
+ "bamarni-bin": {
+ "bin-links": true,
+ "forward-command": false
+ }
+ },
+ "autoload": {
+ "files": [
+ "src/functions_include.php"
+ ],
+ "psr-4": {
+ "GuzzleHttp\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Graham Campbell",
+ "email": "hello@gjcampbell.co.uk",
+ "homepage": "https://github.com/GrahamCampbell"
+ },
+ {
+ "name": "Michael Dowling",
+ "email": "mtdowling@gmail.com",
+ "homepage": "https://github.com/mtdowling"
+ },
+ {
+ "name": "Jeremy Lindblom",
+ "email": "jeremeamia@gmail.com",
+ "homepage": "https://github.com/jeremeamia"
+ },
+ {
+ "name": "George Mponos",
+ "email": "gmponos@gmail.com",
+ "homepage": "https://github.com/gmponos"
+ },
+ {
+ "name": "Tobias Nyholm",
+ "email": "tobias.nyholm@gmail.com",
+ "homepage": "https://github.com/Nyholm"
+ },
+ {
+ "name": "Márk Sági-Kazár",
+ "email": "mark.sagikazar@gmail.com",
+ "homepage": "https://github.com/sagikazarmark"
+ },
+ {
+ "name": "Tobias Schultze",
+ "email": "webmaster@tubo-world.de",
+ "homepage": "https://github.com/Tobion"
+ }
+ ],
+ "description": "Guzzle is a PHP HTTP client library",
+ "keywords": [
+ "client",
+ "curl",
+ "framework",
+ "http",
+ "http client",
+ "psr-18",
+ "psr-7",
+ "rest",
+ "web service"
+ ],
+ "support": {
+ "issues": "https://github.com/guzzle/guzzle/issues",
+ "source": "https://github.com/guzzle/guzzle/tree/7.10.0"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/GrahamCampbell",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/Nyholm",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/guzzle",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-08-23T22:36:01+00:00"
+ },
+ {
+ "name": "guzzlehttp/promises",
+ "version": "2.3.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/guzzle/promises.git",
+ "reference": "481557b130ef3790cf82b713667b43030dc9c957"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/guzzle/promises/zipball/481557b130ef3790cf82b713667b43030dc9c957",
+ "reference": "481557b130ef3790cf82b713667b43030dc9c957",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.2.5 || ^8.0"
+ },
+ "require-dev": {
+ "bamarni/composer-bin-plugin": "^1.8.2",
+ "phpunit/phpunit": "^8.5.44 || ^9.6.25"
+ },
+ "type": "library",
+ "extra": {
+ "bamarni-bin": {
+ "bin-links": true,
+ "forward-command": false
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "GuzzleHttp\\Promise\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Graham Campbell",
+ "email": "hello@gjcampbell.co.uk",
+ "homepage": "https://github.com/GrahamCampbell"
+ },
+ {
+ "name": "Michael Dowling",
+ "email": "mtdowling@gmail.com",
+ "homepage": "https://github.com/mtdowling"
+ },
+ {
+ "name": "Tobias Nyholm",
+ "email": "tobias.nyholm@gmail.com",
+ "homepage": "https://github.com/Nyholm"
+ },
+ {
+ "name": "Tobias Schultze",
+ "email": "webmaster@tubo-world.de",
+ "homepage": "https://github.com/Tobion"
+ }
+ ],
+ "description": "Guzzle promises library",
+ "keywords": [
+ "promise"
+ ],
+ "support": {
+ "issues": "https://github.com/guzzle/promises/issues",
+ "source": "https://github.com/guzzle/promises/tree/2.3.0"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/GrahamCampbell",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/Nyholm",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/promises",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-08-22T14:34:08+00:00"
+ },
+ {
+ "name": "guzzlehttp/psr7",
+ "version": "2.9.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/guzzle/psr7.git",
+ "reference": "7d0ed42f28e42d61352a7a79de682e5e67fec884"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/guzzle/psr7/zipball/7d0ed42f28e42d61352a7a79de682e5e67fec884",
+ "reference": "7d0ed42f28e42d61352a7a79de682e5e67fec884",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.2.5 || ^8.0",
+ "psr/http-factory": "^1.0",
+ "psr/http-message": "^1.1 || ^2.0",
+ "ralouphie/getallheaders": "^3.0"
+ },
+ "provide": {
+ "psr/http-factory-implementation": "1.0",
+ "psr/http-message-implementation": "1.0"
+ },
+ "require-dev": {
+ "bamarni/composer-bin-plugin": "^1.8.2",
+ "http-interop/http-factory-tests": "0.9.0",
+ "jshttp/mime-db": "1.54.0.1",
+ "phpunit/phpunit": "^8.5.44 || ^9.6.25"
+ },
+ "suggest": {
+ "laminas/laminas-httphandlerrunner": "Emit PSR-7 responses"
+ },
+ "type": "library",
+ "extra": {
+ "bamarni-bin": {
+ "bin-links": true,
+ "forward-command": false
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "GuzzleHttp\\Psr7\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Graham Campbell",
+ "email": "hello@gjcampbell.co.uk",
+ "homepage": "https://github.com/GrahamCampbell"
+ },
+ {
+ "name": "Michael Dowling",
+ "email": "mtdowling@gmail.com",
+ "homepage": "https://github.com/mtdowling"
+ },
+ {
+ "name": "George Mponos",
+ "email": "gmponos@gmail.com",
+ "homepage": "https://github.com/gmponos"
+ },
+ {
+ "name": "Tobias Nyholm",
+ "email": "tobias.nyholm@gmail.com",
+ "homepage": "https://github.com/Nyholm"
+ },
+ {
+ "name": "Márk Sági-Kazár",
+ "email": "mark.sagikazar@gmail.com",
+ "homepage": "https://github.com/sagikazarmark"
+ },
+ {
+ "name": "Tobias Schultze",
+ "email": "webmaster@tubo-world.de",
+ "homepage": "https://github.com/Tobion"
+ },
+ {
+ "name": "Márk Sági-Kazár",
+ "email": "mark.sagikazar@gmail.com",
+ "homepage": "https://sagikazarmark.hu"
+ }
+ ],
+ "description": "PSR-7 message implementation that also provides common utility methods",
+ "keywords": [
+ "http",
+ "message",
+ "psr-7",
+ "request",
+ "response",
+ "stream",
+ "uri",
+ "url"
+ ],
+ "support": {
+ "issues": "https://github.com/guzzle/psr7/issues",
+ "source": "https://github.com/guzzle/psr7/tree/2.9.0"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/GrahamCampbell",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/Nyholm",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/guzzlehttp/psr7",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2026-03-10T16:41:02+00:00"
+ },
+ {
+ "name": "jean85/pretty-package-versions",
+ "version": "2.1.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/Jean85/pretty-package-versions.git",
+ "reference": "4d7aa5dab42e2a76d99559706022885de0e18e1a"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/Jean85/pretty-package-versions/zipball/4d7aa5dab42e2a76d99559706022885de0e18e1a",
+ "reference": "4d7aa5dab42e2a76d99559706022885de0e18e1a",
+ "shasum": ""
+ },
+ "require": {
+ "composer-runtime-api": "^2.1.0",
+ "php": "^7.4|^8.0"
+ },
+ "require-dev": {
+ "friendsofphp/php-cs-fixer": "^3.2",
+ "jean85/composer-provided-replaced-stub-package": "^1.0",
+ "phpstan/phpstan": "^2.0",
+ "phpunit/phpunit": "^7.5|^8.5|^9.6",
+ "rector/rector": "^2.0",
+ "vimeo/psalm": "^4.3 || ^5.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Jean85\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Alessandro Lai",
+ "email": "alessandro.lai85@gmail.com"
+ }
+ ],
+ "description": "A library to get pretty versions strings of installed dependencies",
+ "keywords": [
+ "composer",
+ "package",
+ "release",
+ "versions"
+ ],
+ "support": {
+ "issues": "https://github.com/Jean85/pretty-package-versions/issues",
+ "source": "https://github.com/Jean85/pretty-package-versions/tree/2.1.1"
+ },
+ "time": "2025-03-19T14:43:43+00:00"
+ },
+ {
+ "name": "myclabs/deep-copy",
+ "version": "1.13.4",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/myclabs/DeepCopy.git",
+ "reference": "07d290f0c47959fd5eed98c95ee5602db07e0b6a"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/myclabs/DeepCopy/zipball/07d290f0c47959fd5eed98c95ee5602db07e0b6a",
+ "reference": "07d290f0c47959fd5eed98c95ee5602db07e0b6a",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.1 || ^8.0"
+ },
+ "conflict": {
+ "doctrine/collections": "<1.6.8",
+ "doctrine/common": "<2.13.3 || >=3 <3.2.2"
+ },
+ "require-dev": {
+ "doctrine/collections": "^1.6.8",
+ "doctrine/common": "^2.13.3 || ^3.2.2",
+ "phpspec/prophecy": "^1.10",
+ "phpunit/phpunit": "^7.5.20 || ^8.5.23 || ^9.5.13"
+ },
+ "type": "library",
+ "autoload": {
+ "files": [
+ "src/DeepCopy/deep_copy.php"
+ ],
+ "psr-4": {
+ "DeepCopy\\": "src/DeepCopy/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "Create deep copies (clones) of your objects",
+ "keywords": [
+ "clone",
+ "copy",
+ "duplicate",
+ "object",
+ "object graph"
+ ],
+ "support": {
+ "issues": "https://github.com/myclabs/DeepCopy/issues",
+ "source": "https://github.com/myclabs/DeepCopy/tree/1.13.4"
+ },
+ "funding": [
+ {
+ "url": "https://tidelift.com/funding/github/packagist/myclabs/deep-copy",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-08-01T08:46:24+00:00"
+ },
+ {
+ "name": "nikic/php-parser",
+ "version": "v5.7.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/nikic/PHP-Parser.git",
+ "reference": "dca41cd15c2ac9d055ad70dbfd011130757d1f82"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/dca41cd15c2ac9d055ad70dbfd011130757d1f82",
+ "reference": "dca41cd15c2ac9d055ad70dbfd011130757d1f82",
+ "shasum": ""
+ },
+ "require": {
+ "ext-ctype": "*",
+ "ext-json": "*",
+ "ext-tokenizer": "*",
+ "php": ">=7.4"
+ },
+ "require-dev": {
+ "ircmaxell/php-yacc": "^0.0.7",
+ "phpunit/phpunit": "^9.0"
+ },
+ "bin": [
+ "bin/php-parse"
+ ],
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "PhpParser\\": "lib/PhpParser"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Nikita Popov"
+ }
+ ],
+ "description": "A PHP parser written in PHP",
+ "keywords": [
+ "parser",
+ "php"
+ ],
+ "support": {
+ "issues": "https://github.com/nikic/PHP-Parser/issues",
+ "source": "https://github.com/nikic/PHP-Parser/tree/v5.7.0"
+ },
+ "time": "2025-12-06T11:56:16+00:00"
+ },
+ {
+ "name": "nunomaduro/collision",
+ "version": "v8.8.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/nunomaduro/collision.git",
+ "reference": "1dc9e88d105699d0fee8bb18890f41b274f6b4c4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/nunomaduro/collision/zipball/1dc9e88d105699d0fee8bb18890f41b274f6b4c4",
+ "reference": "1dc9e88d105699d0fee8bb18890f41b274f6b4c4",
+ "shasum": ""
+ },
+ "require": {
+ "filp/whoops": "^2.18.1",
+ "nunomaduro/termwind": "^2.3.1",
+ "php": "^8.2.0",
+ "symfony/console": "^7.3.0"
+ },
+ "conflict": {
+ "laravel/framework": "<11.44.2 || >=13.0.0",
+ "phpunit/phpunit": "<11.5.15 || >=13.0.0"
+ },
+ "require-dev": {
+ "brianium/paratest": "^7.8.3",
+ "larastan/larastan": "^3.4.2",
+ "laravel/framework": "^11.44.2 || ^12.18",
+ "laravel/pint": "^1.22.1",
+ "laravel/sail": "^1.43.1",
+ "laravel/sanctum": "^4.1.1",
+ "laravel/tinker": "^2.10.1",
+ "orchestra/testbench-core": "^9.12.0 || ^10.4",
+ "pestphp/pest": "^3.8.2 || ^4.0.0",
+ "sebastian/environment": "^7.2.1 || ^8.0"
+ },
+ "type": "library",
+ "extra": {
+ "laravel": {
+ "providers": [
+ "NunoMaduro\\Collision\\Adapters\\Laravel\\CollisionServiceProvider"
+ ]
+ },
+ "branch-alias": {
+ "dev-8.x": "8.x-dev"
+ }
+ },
+ "autoload": {
+ "files": [
+ "./src/Adapters/Phpunit/Autoload.php"
+ ],
+ "psr-4": {
+ "NunoMaduro\\Collision\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nuno Maduro",
+ "email": "enunomaduro@gmail.com"
+ }
+ ],
+ "description": "Cli error handling for console/command-line PHP applications.",
+ "keywords": [
+ "artisan",
+ "cli",
+ "command-line",
+ "console",
+ "dev",
+ "error",
+ "handling",
+ "laravel",
+ "laravel-zero",
+ "php",
+ "symfony"
+ ],
+ "support": {
+ "issues": "https://github.com/nunomaduro/collision/issues",
+ "source": "https://github.com/nunomaduro/collision"
+ },
+ "funding": [
+ {
+ "url": "https://www.paypal.com/paypalme/enunomaduro",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/nunomaduro",
+ "type": "github"
+ },
+ {
+ "url": "https://www.patreon.com/nunomaduro",
+ "type": "patreon"
+ }
+ ],
+ "time": "2025-11-20T02:55:25+00:00"
+ },
+ {
+ "name": "nunomaduro/termwind",
+ "version": "v2.3.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/nunomaduro/termwind.git",
+ "reference": "6fb2a640ff502caace8e05fd7be3b503a7e1c017"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/nunomaduro/termwind/zipball/6fb2a640ff502caace8e05fd7be3b503a7e1c017",
+ "reference": "6fb2a640ff502caace8e05fd7be3b503a7e1c017",
+ "shasum": ""
+ },
+ "require": {
+ "ext-mbstring": "*",
+ "php": "^8.2",
+ "symfony/console": "^7.3.6"
+ },
+ "require-dev": {
+ "illuminate/console": "^11.46.1",
+ "laravel/pint": "^1.25.1",
+ "mockery/mockery": "^1.6.12",
+ "pestphp/pest": "^2.36.0 || ^3.8.4 || ^4.1.3",
+ "phpstan/phpstan": "^1.12.32",
+ "phpstan/phpstan-strict-rules": "^1.6.2",
+ "symfony/var-dumper": "^7.3.5",
+ "thecodingmachine/phpstan-strict-rules": "^1.0.0"
+ },
+ "type": "library",
+ "extra": {
+ "laravel": {
+ "providers": [
+ "Termwind\\Laravel\\TermwindServiceProvider"
+ ]
+ },
+ "branch-alias": {
+ "dev-2.x": "2.x-dev"
+ }
+ },
+ "autoload": {
+ "files": [
+ "src/Functions.php"
+ ],
+ "psr-4": {
+ "Termwind\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nuno Maduro",
+ "email": "enunomaduro@gmail.com"
+ }
+ ],
+ "description": "Its like Tailwind CSS, but for the console.",
+ "keywords": [
+ "cli",
+ "console",
+ "css",
+ "package",
+ "php",
+ "style"
+ ],
+ "support": {
+ "issues": "https://github.com/nunomaduro/termwind/issues",
+ "source": "https://github.com/nunomaduro/termwind/tree/v2.3.3"
+ },
+ "funding": [
+ {
+ "url": "https://www.paypal.com/paypalme/enunomaduro",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/nunomaduro",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/xiCO2k",
+ "type": "github"
+ }
+ ],
+ "time": "2025-11-20T02:34:59+00:00"
+ },
+ {
+ "name": "nyholm/psr7",
+ "version": "1.8.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/Nyholm/psr7.git",
+ "reference": "a71f2b11690f4b24d099d6b16690a90ae14fc6f3"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/Nyholm/psr7/zipball/a71f2b11690f4b24d099d6b16690a90ae14fc6f3",
+ "reference": "a71f2b11690f4b24d099d6b16690a90ae14fc6f3",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.2",
+ "psr/http-factory": "^1.0",
+ "psr/http-message": "^1.1 || ^2.0"
+ },
+ "provide": {
+ "php-http/message-factory-implementation": "1.0",
+ "psr/http-factory-implementation": "1.0",
+ "psr/http-message-implementation": "1.0"
+ },
+ "require-dev": {
+ "http-interop/http-factory-tests": "^0.9",
+ "php-http/message-factory": "^1.0",
+ "php-http/psr7-integration-tests": "^1.0",
+ "phpunit/phpunit": "^7.5 || ^8.5 || ^9.4",
+ "symfony/error-handler": "^4.4"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.8-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Nyholm\\Psr7\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Tobias Nyholm",
+ "email": "tobias.nyholm@gmail.com"
+ },
+ {
+ "name": "Martijn van der Ven",
+ "email": "martijn@vanderven.se"
+ }
+ ],
+ "description": "A fast PHP7 implementation of PSR-7",
+ "homepage": "https://tnyholm.se",
+ "keywords": [
+ "psr-17",
+ "psr-7"
+ ],
+ "support": {
+ "issues": "https://github.com/Nyholm/psr7/issues",
+ "source": "https://github.com/Nyholm/psr7/tree/1.8.2"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/Zegnat",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nyholm",
+ "type": "github"
+ }
+ ],
+ "time": "2024-09-09T07:06:30+00:00"
+ },
+ {
+ "name": "pestphp/pest",
+ "version": "v3.8.5",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/pestphp/pest.git",
+ "reference": "7796630eafcfd1c02660cecdde3bc6984fbf01f4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/pestphp/pest/zipball/7796630eafcfd1c02660cecdde3bc6984fbf01f4",
+ "reference": "7796630eafcfd1c02660cecdde3bc6984fbf01f4",
+ "shasum": ""
+ },
+ "require": {
+ "brianium/paratest": "^7.8.5",
+ "nunomaduro/collision": "^8.8.3",
+ "nunomaduro/termwind": "^2.3.3",
+ "pestphp/pest-plugin": "^3.0.0",
+ "pestphp/pest-plugin-arch": "^3.1.1",
+ "pestphp/pest-plugin-mutate": "^3.0.5",
+ "php": "^8.2.0",
+ "phpunit/phpunit": "^11.5.50"
+ },
+ "conflict": {
+ "filp/whoops": "<2.16.0",
+ "phpunit/phpunit": ">11.5.50",
+ "sebastian/exporter": "<6.0.0",
+ "webmozart/assert": "<1.11.0"
+ },
+ "require-dev": {
+ "pestphp/pest-dev-tools": "^3.4.0",
+ "pestphp/pest-plugin-type-coverage": "^3.6.1",
+ "symfony/process": "^7.4.4"
+ },
+ "bin": [
+ "bin/pest"
+ ],
+ "type": "library",
+ "extra": {
+ "pest": {
+ "plugins": [
+ "Pest\\Mutate\\Plugins\\Mutate",
+ "Pest\\Plugins\\Configuration",
+ "Pest\\Plugins\\Bail",
+ "Pest\\Plugins\\Cache",
+ "Pest\\Plugins\\Coverage",
+ "Pest\\Plugins\\Init",
+ "Pest\\Plugins\\Environment",
+ "Pest\\Plugins\\Help",
+ "Pest\\Plugins\\Memory",
+ "Pest\\Plugins\\Only",
+ "Pest\\Plugins\\Printer",
+ "Pest\\Plugins\\ProcessIsolation",
+ "Pest\\Plugins\\Profile",
+ "Pest\\Plugins\\Retry",
+ "Pest\\Plugins\\Snapshot",
+ "Pest\\Plugins\\Verbose",
+ "Pest\\Plugins\\Version",
+ "Pest\\Plugins\\Parallel"
+ ]
+ },
+ "phpstan": {
+ "includes": [
+ "extension.neon"
+ ]
+ }
+ },
+ "autoload": {
+ "files": [
+ "src/Functions.php",
+ "src/Pest.php"
+ ],
+ "psr-4": {
+ "Pest\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nuno Maduro",
+ "email": "enunomaduro@gmail.com"
+ }
+ ],
+ "description": "The elegant PHP Testing Framework.",
+ "keywords": [
+ "framework",
+ "pest",
+ "php",
+ "test",
+ "testing",
+ "unit"
+ ],
+ "support": {
+ "issues": "https://github.com/pestphp/pest/issues",
+ "source": "https://github.com/pestphp/pest/tree/v3.8.5"
+ },
+ "funding": [
+ {
+ "url": "https://www.paypal.com/paypalme/enunomaduro",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/nunomaduro",
+ "type": "github"
+ }
+ ],
+ "time": "2026-01-28T01:33:45+00:00"
},
- "platform-dev": [],
- "platform-overrides": {
- "php": "5.6"
+ {
+ "name": "pestphp/pest-plugin",
+ "version": "v3.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/pestphp/pest-plugin.git",
+ "reference": "e79b26c65bc11c41093b10150c1341cc5cdbea83"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/pestphp/pest-plugin/zipball/e79b26c65bc11c41093b10150c1341cc5cdbea83",
+ "reference": "e79b26c65bc11c41093b10150c1341cc5cdbea83",
+ "shasum": ""
+ },
+ "require": {
+ "composer-plugin-api": "^2.0.0",
+ "composer-runtime-api": "^2.2.2",
+ "php": "^8.2"
+ },
+ "conflict": {
+ "pestphp/pest": "<3.0.0"
+ },
+ "require-dev": {
+ "composer/composer": "^2.7.9",
+ "pestphp/pest": "^3.0.0",
+ "pestphp/pest-dev-tools": "^3.0.0"
+ },
+ "type": "composer-plugin",
+ "extra": {
+ "class": "Pest\\Plugin\\Manager"
+ },
+ "autoload": {
+ "psr-4": {
+ "Pest\\Plugin\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "The Pest plugin manager",
+ "keywords": [
+ "framework",
+ "manager",
+ "pest",
+ "php",
+ "plugin",
+ "test",
+ "testing",
+ "unit"
+ ],
+ "support": {
+ "source": "https://github.com/pestphp/pest-plugin/tree/v3.0.0"
+ },
+ "funding": [
+ {
+ "url": "https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=66BYDWAT92N6L",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/nunomaduro",
+ "type": "github"
+ },
+ {
+ "url": "https://www.patreon.com/nunomaduro",
+ "type": "patreon"
+ }
+ ],
+ "time": "2024-09-08T23:21:41+00:00"
+ },
+ {
+ "name": "pestphp/pest-plugin-arch",
+ "version": "v3.1.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/pestphp/pest-plugin-arch.git",
+ "reference": "db7bd9cb1612b223e16618d85475c6f63b9c8daa"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/pestphp/pest-plugin-arch/zipball/db7bd9cb1612b223e16618d85475c6f63b9c8daa",
+ "reference": "db7bd9cb1612b223e16618d85475c6f63b9c8daa",
+ "shasum": ""
+ },
+ "require": {
+ "pestphp/pest-plugin": "^3.0.0",
+ "php": "^8.2",
+ "ta-tikoma/phpunit-architecture-test": "^0.8.4"
+ },
+ "require-dev": {
+ "pestphp/pest": "^3.8.1",
+ "pestphp/pest-dev-tools": "^3.4.0"
+ },
+ "type": "library",
+ "extra": {
+ "pest": {
+ "plugins": [
+ "Pest\\Arch\\Plugin"
+ ]
+ }
+ },
+ "autoload": {
+ "files": [
+ "src/Autoload.php"
+ ],
+ "psr-4": {
+ "Pest\\Arch\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "The Arch plugin for Pest PHP.",
+ "keywords": [
+ "arch",
+ "architecture",
+ "framework",
+ "pest",
+ "php",
+ "plugin",
+ "test",
+ "testing",
+ "unit"
+ ],
+ "support": {
+ "source": "https://github.com/pestphp/pest-plugin-arch/tree/v3.1.1"
+ },
+ "funding": [
+ {
+ "url": "https://www.paypal.com/paypalme/enunomaduro",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/nunomaduro",
+ "type": "github"
+ }
+ ],
+ "time": "2025-04-16T22:59:48+00:00"
+ },
+ {
+ "name": "pestphp/pest-plugin-mutate",
+ "version": "v3.0.5",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/pestphp/pest-plugin-mutate.git",
+ "reference": "e10dbdc98c9e2f3890095b4fe2144f63a5717e08"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/pestphp/pest-plugin-mutate/zipball/e10dbdc98c9e2f3890095b4fe2144f63a5717e08",
+ "reference": "e10dbdc98c9e2f3890095b4fe2144f63a5717e08",
+ "shasum": ""
+ },
+ "require": {
+ "nikic/php-parser": "^5.2.0",
+ "pestphp/pest-plugin": "^3.0.0",
+ "php": "^8.2",
+ "psr/simple-cache": "^3.0.0"
+ },
+ "require-dev": {
+ "pestphp/pest": "^3.0.8",
+ "pestphp/pest-dev-tools": "^3.0.0",
+ "pestphp/pest-plugin-type-coverage": "^3.0.0"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Pest\\Mutate\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Sandro Gehri",
+ "email": "sandrogehri@gmail.com"
+ }
+ ],
+ "description": "Mutates your code to find untested cases",
+ "keywords": [
+ "framework",
+ "mutate",
+ "mutation",
+ "pest",
+ "php",
+ "plugin",
+ "test",
+ "testing",
+ "unit"
+ ],
+ "support": {
+ "source": "https://github.com/pestphp/pest-plugin-mutate/tree/v3.0.5"
+ },
+ "funding": [
+ {
+ "url": "https://www.paypal.com/paypalme/enunomaduro",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/gehrisandro",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nunomaduro",
+ "type": "github"
+ }
+ ],
+ "time": "2024-09-22T07:54:40+00:00"
},
- "plugin-api-version": "2.2.0"
+ {
+ "name": "phar-io/manifest",
+ "version": "2.0.4",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phar-io/manifest.git",
+ "reference": "54750ef60c58e43759730615a392c31c80e23176"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phar-io/manifest/zipball/54750ef60c58e43759730615a392c31c80e23176",
+ "reference": "54750ef60c58e43759730615a392c31c80e23176",
+ "shasum": ""
+ },
+ "require": {
+ "ext-dom": "*",
+ "ext-libxml": "*",
+ "ext-phar": "*",
+ "ext-xmlwriter": "*",
+ "phar-io/version": "^3.0.1",
+ "php": "^7.2 || ^8.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.0.x-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Arne Blankerts",
+ "email": "arne@blankerts.de",
+ "role": "Developer"
+ },
+ {
+ "name": "Sebastian Heuer",
+ "email": "sebastian@phpeople.de",
+ "role": "Developer"
+ },
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "Developer"
+ }
+ ],
+ "description": "Component for reading phar.io manifest information from a PHP Archive (PHAR)",
+ "support": {
+ "issues": "https://github.com/phar-io/manifest/issues",
+ "source": "https://github.com/phar-io/manifest/tree/2.0.4"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/theseer",
+ "type": "github"
+ }
+ ],
+ "time": "2024-03-03T12:33:53+00:00"
+ },
+ {
+ "name": "phar-io/version",
+ "version": "3.2.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phar-io/version.git",
+ "reference": "4f7fd7836c6f332bb2933569e566a0d6c4cbed74"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phar-io/version/zipball/4f7fd7836c6f332bb2933569e566a0d6c4cbed74",
+ "reference": "4f7fd7836c6f332bb2933569e566a0d6c4cbed74",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.2 || ^8.0"
+ },
+ "type": "library",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Arne Blankerts",
+ "email": "arne@blankerts.de",
+ "role": "Developer"
+ },
+ {
+ "name": "Sebastian Heuer",
+ "email": "sebastian@phpeople.de",
+ "role": "Developer"
+ },
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "Developer"
+ }
+ ],
+ "description": "Library for handling version information and constraints",
+ "support": {
+ "issues": "https://github.com/phar-io/version/issues",
+ "source": "https://github.com/phar-io/version/tree/3.2.1"
+ },
+ "time": "2022-02-21T01:04:05+00:00"
+ },
+ {
+ "name": "php-http/client-common",
+ "version": "2.7.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-http/client-common.git",
+ "reference": "dcc6de29c90dd74faab55f71b79d89409c4bf0c1"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-http/client-common/zipball/dcc6de29c90dd74faab55f71b79d89409c4bf0c1",
+ "reference": "dcc6de29c90dd74faab55f71b79d89409c4bf0c1",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.1 || ^8.0",
+ "php-http/httplug": "^2.0",
+ "php-http/message": "^1.6",
+ "psr/http-client": "^1.0",
+ "psr/http-factory": "^1.0",
+ "psr/http-message": "^1.0 || ^2.0",
+ "symfony/options-resolver": "~4.0.15 || ~4.1.9 || ^4.2.1 || ^5.0 || ^6.0 || ^7.0 || ^8.0",
+ "symfony/polyfill-php80": "^1.17"
+ },
+ "require-dev": {
+ "doctrine/instantiator": "^1.1",
+ "guzzlehttp/psr7": "^1.4",
+ "nyholm/psr7": "^1.2",
+ "phpunit/phpunit": "^7.5.20 || ^8.5.33 || ^9.6.7"
+ },
+ "suggest": {
+ "ext-json": "To detect JSON responses with the ContentTypePlugin",
+ "ext-libxml": "To detect XML responses with the ContentTypePlugin",
+ "php-http/cache-plugin": "PSR-6 Cache plugin",
+ "php-http/logger-plugin": "PSR-3 Logger plugin",
+ "php-http/stopwatch-plugin": "Symfony Stopwatch plugin"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Http\\Client\\Common\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Márk Sági-Kazár",
+ "email": "mark.sagikazar@gmail.com"
+ }
+ ],
+ "description": "Common HTTP Client implementations and tools for HTTPlug",
+ "homepage": "http://httplug.io",
+ "keywords": [
+ "client",
+ "common",
+ "http",
+ "httplug"
+ ],
+ "support": {
+ "issues": "https://github.com/php-http/client-common/issues",
+ "source": "https://github.com/php-http/client-common/tree/2.7.3"
+ },
+ "time": "2025-11-29T19:12:34+00:00"
+ },
+ {
+ "name": "php-http/httplug",
+ "version": "2.4.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-http/httplug.git",
+ "reference": "5cad731844891a4c282f3f3e1b582c46839d22f4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-http/httplug/zipball/5cad731844891a4c282f3f3e1b582c46839d22f4",
+ "reference": "5cad731844891a4c282f3f3e1b582c46839d22f4",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.1 || ^8.0",
+ "php-http/promise": "^1.1",
+ "psr/http-client": "^1.0",
+ "psr/http-message": "^1.0 || ^2.0"
+ },
+ "require-dev": {
+ "friends-of-phpspec/phpspec-code-coverage": "^4.1 || ^5.0 || ^6.0",
+ "phpspec/phpspec": "^5.1 || ^6.0 || ^7.0"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Http\\Client\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Eric GELOEN",
+ "email": "geloen.eric@gmail.com"
+ },
+ {
+ "name": "Márk Sági-Kazár",
+ "email": "mark.sagikazar@gmail.com",
+ "homepage": "https://sagikazarmark.hu"
+ }
+ ],
+ "description": "HTTPlug, the HTTP client abstraction for PHP",
+ "homepage": "http://httplug.io",
+ "keywords": [
+ "client",
+ "http"
+ ],
+ "support": {
+ "issues": "https://github.com/php-http/httplug/issues",
+ "source": "https://github.com/php-http/httplug/tree/2.4.1"
+ },
+ "time": "2024-09-23T11:39:58+00:00"
+ },
+ {
+ "name": "php-http/message",
+ "version": "1.16.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-http/message.git",
+ "reference": "06dd5e8562f84e641bf929bfe699ee0f5ce8080a"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-http/message/zipball/06dd5e8562f84e641bf929bfe699ee0f5ce8080a",
+ "reference": "06dd5e8562f84e641bf929bfe699ee0f5ce8080a",
+ "shasum": ""
+ },
+ "require": {
+ "clue/stream-filter": "^1.5",
+ "php": "^7.2 || ^8.0",
+ "psr/http-message": "^1.1 || ^2.0"
+ },
+ "provide": {
+ "php-http/message-factory-implementation": "1.0"
+ },
+ "require-dev": {
+ "ergebnis/composer-normalize": "^2.6",
+ "ext-zlib": "*",
+ "guzzlehttp/psr7": "^1.0 || ^2.0",
+ "laminas/laminas-diactoros": "^2.0 || ^3.0",
+ "php-http/message-factory": "^1.0.2",
+ "phpspec/phpspec": "^5.1 || ^6.3 || ^7.1",
+ "slim/slim": "^3.0"
+ },
+ "suggest": {
+ "ext-zlib": "Used with compressor/decompressor streams",
+ "guzzlehttp/psr7": "Used with Guzzle PSR-7 Factories",
+ "laminas/laminas-diactoros": "Used with Diactoros Factories",
+ "slim/slim": "Used with Slim Framework PSR-7 implementation"
+ },
+ "type": "library",
+ "autoload": {
+ "files": [
+ "src/filters.php"
+ ],
+ "psr-4": {
+ "Http\\Message\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Márk Sági-Kazár",
+ "email": "mark.sagikazar@gmail.com"
+ }
+ ],
+ "description": "HTTP Message related tools",
+ "homepage": "http://php-http.org",
+ "keywords": [
+ "http",
+ "message",
+ "psr-7"
+ ],
+ "support": {
+ "issues": "https://github.com/php-http/message/issues",
+ "source": "https://github.com/php-http/message/tree/1.16.2"
+ },
+ "time": "2024-10-02T11:34:13+00:00"
+ },
+ {
+ "name": "php-http/mock-client",
+ "version": "1.6.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-http/mock-client.git",
+ "reference": "81f558234421f7da58ed015604a03808996017d0"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-http/mock-client/zipball/81f558234421f7da58ed015604a03808996017d0",
+ "reference": "81f558234421f7da58ed015604a03808996017d0",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.1 || ^8.0",
+ "php-http/client-common": "^2.0",
+ "php-http/discovery": "^1.16",
+ "php-http/httplug": "^2.0",
+ "psr/http-client": "^1.0",
+ "psr/http-factory-implementation": "^1.0",
+ "psr/http-message": "^1.0 || ^2.0",
+ "symfony/polyfill-php80": "^1.17"
+ },
+ "provide": {
+ "php-http/async-client-implementation": "1.0",
+ "php-http/client-implementation": "1.0",
+ "psr/http-client-implementation": "1.0"
+ },
+ "require-dev": {
+ "phpspec/phpspec": "^5.1 || ^6.1 || ^7.3"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Http\\Mock\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "David de Boer",
+ "email": "david@ddeboer.nl"
+ }
+ ],
+ "description": "Mock HTTP client",
+ "homepage": "http://httplug.io",
+ "keywords": [
+ "client",
+ "http",
+ "mock",
+ "psr7"
+ ],
+ "support": {
+ "issues": "https://github.com/php-http/mock-client/issues",
+ "source": "https://github.com/php-http/mock-client/tree/1.6.1"
+ },
+ "time": "2024-10-31T10:30:18+00:00"
+ },
+ {
+ "name": "php-http/promise",
+ "version": "1.3.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-http/promise.git",
+ "reference": "fc85b1fba37c169a69a07ef0d5a8075770cc1f83"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-http/promise/zipball/fc85b1fba37c169a69a07ef0d5a8075770cc1f83",
+ "reference": "fc85b1fba37c169a69a07ef0d5a8075770cc1f83",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.1 || ^8.0"
+ },
+ "require-dev": {
+ "friends-of-phpspec/phpspec-code-coverage": "^4.3.2 || ^6.3",
+ "phpspec/phpspec": "^5.1.2 || ^6.2 || ^7.4"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Http\\Promise\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Joel Wurtz",
+ "email": "joel.wurtz@gmail.com"
+ },
+ {
+ "name": "Márk Sági-Kazár",
+ "email": "mark.sagikazar@gmail.com"
+ }
+ ],
+ "description": "Promise used for asynchronous HTTP requests",
+ "homepage": "http://httplug.io",
+ "keywords": [
+ "promise"
+ ],
+ "support": {
+ "issues": "https://github.com/php-http/promise/issues",
+ "source": "https://github.com/php-http/promise/tree/1.3.1"
+ },
+ "time": "2024-03-15T13:55:21+00:00"
+ },
+ {
+ "name": "phpdocumentor/reflection-common",
+ "version": "2.2.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phpDocumentor/ReflectionCommon.git",
+ "reference": "1d01c49d4ed62f25aa84a747ad35d5a16924662b"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpDocumentor/ReflectionCommon/zipball/1d01c49d4ed62f25aa84a747ad35d5a16924662b",
+ "reference": "1d01c49d4ed62f25aa84a747ad35d5a16924662b",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.2 || ^8.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-2.x": "2.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "phpDocumentor\\Reflection\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Jaap van Otterdijk",
+ "email": "opensource@ijaap.nl"
+ }
+ ],
+ "description": "Common reflection classes used by phpdocumentor to reflect the code structure",
+ "homepage": "http://www.phpdoc.org",
+ "keywords": [
+ "FQSEN",
+ "phpDocumentor",
+ "phpdoc",
+ "reflection",
+ "static analysis"
+ ],
+ "support": {
+ "issues": "https://github.com/phpDocumentor/ReflectionCommon/issues",
+ "source": "https://github.com/phpDocumentor/ReflectionCommon/tree/2.x"
+ },
+ "time": "2020-06-27T09:03:43+00:00"
+ },
+ {
+ "name": "phpdocumentor/reflection-docblock",
+ "version": "5.6.6",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phpDocumentor/ReflectionDocBlock.git",
+ "reference": "5cee1d3dfc2d2aa6599834520911d246f656bcb8"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpDocumentor/ReflectionDocBlock/zipball/5cee1d3dfc2d2aa6599834520911d246f656bcb8",
+ "reference": "5cee1d3dfc2d2aa6599834520911d246f656bcb8",
+ "shasum": ""
+ },
+ "require": {
+ "doctrine/deprecations": "^1.1",
+ "ext-filter": "*",
+ "php": "^7.4 || ^8.0",
+ "phpdocumentor/reflection-common": "^2.2",
+ "phpdocumentor/type-resolver": "^1.7",
+ "phpstan/phpdoc-parser": "^1.7|^2.0",
+ "webmozart/assert": "^1.9.1 || ^2"
+ },
+ "require-dev": {
+ "mockery/mockery": "~1.3.5 || ~1.6.0",
+ "phpstan/extension-installer": "^1.1",
+ "phpstan/phpstan": "^1.8",
+ "phpstan/phpstan-mockery": "^1.1",
+ "phpstan/phpstan-webmozart-assert": "^1.2",
+ "phpunit/phpunit": "^9.5",
+ "psalm/phar": "^5.26"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "phpDocumentor\\Reflection\\": "src"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Mike van Riel",
+ "email": "me@mikevanriel.com"
+ },
+ {
+ "name": "Jaap van Otterdijk",
+ "email": "opensource@ijaap.nl"
+ }
+ ],
+ "description": "With this component, a library can provide support for annotations via DocBlocks or otherwise retrieve information that is embedded in a DocBlock.",
+ "support": {
+ "issues": "https://github.com/phpDocumentor/ReflectionDocBlock/issues",
+ "source": "https://github.com/phpDocumentor/ReflectionDocBlock/tree/5.6.6"
+ },
+ "time": "2025-12-22T21:13:58+00:00"
+ },
+ {
+ "name": "phpdocumentor/type-resolver",
+ "version": "1.12.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phpDocumentor/TypeResolver.git",
+ "reference": "92a98ada2b93d9b201a613cb5a33584dde25f195"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpDocumentor/TypeResolver/zipball/92a98ada2b93d9b201a613cb5a33584dde25f195",
+ "reference": "92a98ada2b93d9b201a613cb5a33584dde25f195",
+ "shasum": ""
+ },
+ "require": {
+ "doctrine/deprecations": "^1.0",
+ "php": "^7.3 || ^8.0",
+ "phpdocumentor/reflection-common": "^2.0",
+ "phpstan/phpdoc-parser": "^1.18|^2.0"
+ },
+ "require-dev": {
+ "ext-tokenizer": "*",
+ "phpbench/phpbench": "^1.2",
+ "phpstan/extension-installer": "^1.1",
+ "phpstan/phpstan": "^1.8",
+ "phpstan/phpstan-phpunit": "^1.1",
+ "phpunit/phpunit": "^9.5",
+ "rector/rector": "^0.13.9",
+ "vimeo/psalm": "^4.25"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-1.x": "1.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "phpDocumentor\\Reflection\\": "src"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Mike van Riel",
+ "email": "me@mikevanriel.com"
+ }
+ ],
+ "description": "A PSR-5 based resolver of Class names, Types and Structural Element Names",
+ "support": {
+ "issues": "https://github.com/phpDocumentor/TypeResolver/issues",
+ "source": "https://github.com/phpDocumentor/TypeResolver/tree/1.12.0"
+ },
+ "time": "2025-11-21T15:09:14+00:00"
+ },
+ {
+ "name": "phpstan/extension-installer",
+ "version": "1.4.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phpstan/extension-installer.git",
+ "reference": "85e90b3942d06b2326fba0403ec24fe912372936"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpstan/extension-installer/zipball/85e90b3942d06b2326fba0403ec24fe912372936",
+ "reference": "85e90b3942d06b2326fba0403ec24fe912372936",
+ "shasum": ""
+ },
+ "require": {
+ "composer-plugin-api": "^2.0",
+ "php": "^7.2 || ^8.0",
+ "phpstan/phpstan": "^1.9.0 || ^2.0"
+ },
+ "require-dev": {
+ "composer/composer": "^2.0",
+ "php-parallel-lint/php-parallel-lint": "^1.2.0",
+ "phpstan/phpstan-strict-rules": "^0.11 || ^0.12 || ^1.0"
+ },
+ "type": "composer-plugin",
+ "extra": {
+ "class": "PHPStan\\ExtensionInstaller\\Plugin"
+ },
+ "autoload": {
+ "psr-4": {
+ "PHPStan\\ExtensionInstaller\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "Composer plugin for automatic installation of PHPStan extensions",
+ "keywords": [
+ "dev",
+ "static analysis"
+ ],
+ "support": {
+ "issues": "https://github.com/phpstan/extension-installer/issues",
+ "source": "https://github.com/phpstan/extension-installer/tree/1.4.3"
+ },
+ "time": "2024-09-04T20:21:43+00:00"
+ },
+ {
+ "name": "phpstan/phpdoc-parser",
+ "version": "2.3.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phpstan/phpdoc-parser.git",
+ "reference": "1e0cd5370df5dd2e556a36b9c62f62e555870495"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpstan/phpdoc-parser/zipball/1e0cd5370df5dd2e556a36b9c62f62e555870495",
+ "reference": "1e0cd5370df5dd2e556a36b9c62f62e555870495",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.4 || ^8.0"
+ },
+ "require-dev": {
+ "doctrine/annotations": "^2.0",
+ "nikic/php-parser": "^5.3.0",
+ "php-parallel-lint/php-parallel-lint": "^1.2",
+ "phpstan/extension-installer": "^1.0",
+ "phpstan/phpstan": "^2.0",
+ "phpstan/phpstan-phpunit": "^2.0",
+ "phpstan/phpstan-strict-rules": "^2.0",
+ "phpunit/phpunit": "^9.6",
+ "symfony/process": "^5.2"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "PHPStan\\PhpDocParser\\": [
+ "src/"
+ ]
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "PHPDoc parser with support for nullable, intersection and generic types",
+ "support": {
+ "issues": "https://github.com/phpstan/phpdoc-parser/issues",
+ "source": "https://github.com/phpstan/phpdoc-parser/tree/2.3.0"
+ },
+ "time": "2025-08-30T15:50:23+00:00"
+ },
+ {
+ "name": "phpstan/phpstan",
+ "version": "2.1.33",
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpstan/phpstan/zipball/9e800e6bee7d5bd02784d4c6069b48032d16224f",
+ "reference": "9e800e6bee7d5bd02784d4c6069b48032d16224f",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.4|^8.0"
+ },
+ "conflict": {
+ "phpstan/phpstan-shim": "*"
+ },
+ "bin": [
+ "phpstan",
+ "phpstan.phar"
+ ],
+ "type": "library",
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "PHPStan - PHP Static Analysis Tool",
+ "keywords": [
+ "dev",
+ "static analysis"
+ ],
+ "support": {
+ "docs": "https://phpstan.org/user-guide/getting-started",
+ "forum": "https://github.com/phpstan/phpstan/discussions",
+ "issues": "https://github.com/phpstan/phpstan/issues",
+ "security": "https://github.com/phpstan/phpstan/security/policy",
+ "source": "https://github.com/phpstan/phpstan-src"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/ondrejmirtes",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/phpstan",
+ "type": "github"
+ }
+ ],
+ "time": "2025-12-05T10:24:31+00:00"
+ },
+ {
+ "name": "phpstan/phpstan-phpunit",
+ "version": "2.0.11",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phpstan/phpstan-phpunit.git",
+ "reference": "5e30669bef866eff70db8b58d72a5c185aa82414"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpstan/phpstan-phpunit/zipball/5e30669bef866eff70db8b58d72a5c185aa82414",
+ "reference": "5e30669bef866eff70db8b58d72a5c185aa82414",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.4 || ^8.0",
+ "phpstan/phpstan": "^2.1.32"
+ },
+ "conflict": {
+ "phpunit/phpunit": "<7.0"
+ },
+ "require-dev": {
+ "nikic/php-parser": "^5",
+ "php-parallel-lint/php-parallel-lint": "^1.2",
+ "phpstan/phpstan-deprecation-rules": "^2.0",
+ "phpstan/phpstan-strict-rules": "^2.0",
+ "phpunit/phpunit": "^9.6"
+ },
+ "type": "phpstan-extension",
+ "extra": {
+ "phpstan": {
+ "includes": [
+ "extension.neon",
+ "rules.neon"
+ ]
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "PHPStan\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "PHPUnit extensions and rules for PHPStan",
+ "support": {
+ "issues": "https://github.com/phpstan/phpstan-phpunit/issues",
+ "source": "https://github.com/phpstan/phpstan-phpunit/tree/2.0.11"
+ },
+ "time": "2025-12-19T09:05:35+00:00"
+ },
+ {
+ "name": "phpunit/php-code-coverage",
+ "version": "11.0.12",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/php-code-coverage.git",
+ "reference": "2c1ed04922802c15e1de5d7447b4856de949cf56"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/2c1ed04922802c15e1de5d7447b4856de949cf56",
+ "reference": "2c1ed04922802c15e1de5d7447b4856de949cf56",
+ "shasum": ""
+ },
+ "require": {
+ "ext-dom": "*",
+ "ext-libxml": "*",
+ "ext-xmlwriter": "*",
+ "nikic/php-parser": "^5.7.0",
+ "php": ">=8.2",
+ "phpunit/php-file-iterator": "^5.1.0",
+ "phpunit/php-text-template": "^4.0.1",
+ "sebastian/code-unit-reverse-lookup": "^4.0.1",
+ "sebastian/complexity": "^4.0.1",
+ "sebastian/environment": "^7.2.1",
+ "sebastian/lines-of-code": "^3.0.1",
+ "sebastian/version": "^5.0.2",
+ "theseer/tokenizer": "^1.3.1"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.5.46"
+ },
+ "suggest": {
+ "ext-pcov": "PHP extension that provides line coverage",
+ "ext-xdebug": "PHP extension that provides line coverage as well as branch and path coverage"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "11.0.x-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Library that provides collection, processing, and rendering functionality for PHP code coverage information.",
+ "homepage": "https://github.com/sebastianbergmann/php-code-coverage",
+ "keywords": [
+ "coverage",
+ "testing",
+ "xunit"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/php-code-coverage/issues",
+ "security": "https://github.com/sebastianbergmann/php-code-coverage/security/policy",
+ "source": "https://github.com/sebastianbergmann/php-code-coverage/tree/11.0.12"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ },
+ {
+ "url": "https://liberapay.com/sebastianbergmann",
+ "type": "liberapay"
+ },
+ {
+ "url": "https://thanks.dev/u/gh/sebastianbergmann",
+ "type": "thanks_dev"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/phpunit/php-code-coverage",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-12-24T07:01:01+00:00"
+ },
+ {
+ "name": "phpunit/php-file-iterator",
+ "version": "5.1.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/php-file-iterator.git",
+ "reference": "2f3a64888c814fc235386b7387dd5b5ed92ad903"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/2f3a64888c814fc235386b7387dd5b5ed92ad903",
+ "reference": "2f3a64888c814fc235386b7387dd5b5ed92ad903",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.3"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "5.1-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "FilterIterator implementation that filters files based on a list of suffixes.",
+ "homepage": "https://github.com/sebastianbergmann/php-file-iterator/",
+ "keywords": [
+ "filesystem",
+ "iterator"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/php-file-iterator/issues",
+ "security": "https://github.com/sebastianbergmann/php-file-iterator/security/policy",
+ "source": "https://github.com/sebastianbergmann/php-file-iterator/tree/5.1.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ },
+ {
+ "url": "https://liberapay.com/sebastianbergmann",
+ "type": "liberapay"
+ },
+ {
+ "url": "https://thanks.dev/u/gh/sebastianbergmann",
+ "type": "thanks_dev"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/phpunit/php-file-iterator",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2026-02-02T13:52:54+00:00"
+ },
+ {
+ "name": "phpunit/php-invoker",
+ "version": "5.0.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/php-invoker.git",
+ "reference": "c1ca3814734c07492b3d4c5f794f4b0995333da2"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-invoker/zipball/c1ca3814734c07492b3d4c5f794f4b0995333da2",
+ "reference": "c1ca3814734c07492b3d4c5f794f4b0995333da2",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "ext-pcntl": "*",
+ "phpunit/phpunit": "^11.0"
+ },
+ "suggest": {
+ "ext-pcntl": "*"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "5.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Invoke callables with a timeout",
+ "homepage": "https://github.com/sebastianbergmann/php-invoker/",
+ "keywords": [
+ "process"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/php-invoker/issues",
+ "security": "https://github.com/sebastianbergmann/php-invoker/security/policy",
+ "source": "https://github.com/sebastianbergmann/php-invoker/tree/5.0.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T05:07:44+00:00"
+ },
+ {
+ "name": "phpunit/php-text-template",
+ "version": "4.0.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/php-text-template.git",
+ "reference": "3e0404dc6b300e6bf56415467ebcb3fe4f33e964"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/3e0404dc6b300e6bf56415467ebcb3fe4f33e964",
+ "reference": "3e0404dc6b300e6bf56415467ebcb3fe4f33e964",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "4.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Simple template engine.",
+ "homepage": "https://github.com/sebastianbergmann/php-text-template/",
+ "keywords": [
+ "template"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/php-text-template/issues",
+ "security": "https://github.com/sebastianbergmann/php-text-template/security/policy",
+ "source": "https://github.com/sebastianbergmann/php-text-template/tree/4.0.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T05:08:43+00:00"
+ },
+ {
+ "name": "phpunit/php-timer",
+ "version": "7.0.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/php-timer.git",
+ "reference": "3b415def83fbcb41f991d9ebf16ae4ad8b7837b3"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/3b415def83fbcb41f991d9ebf16ae4ad8b7837b3",
+ "reference": "3b415def83fbcb41f991d9ebf16ae4ad8b7837b3",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "7.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Utility class for timing",
+ "homepage": "https://github.com/sebastianbergmann/php-timer/",
+ "keywords": [
+ "timer"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/php-timer/issues",
+ "security": "https://github.com/sebastianbergmann/php-timer/security/policy",
+ "source": "https://github.com/sebastianbergmann/php-timer/tree/7.0.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T05:09:35+00:00"
+ },
+ {
+ "name": "phpunit/phpunit",
+ "version": "11.5.50",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/phpunit.git",
+ "reference": "fdfc727f0fcacfeb8fcb30c7e5da173125b58be3"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/fdfc727f0fcacfeb8fcb30c7e5da173125b58be3",
+ "reference": "fdfc727f0fcacfeb8fcb30c7e5da173125b58be3",
+ "shasum": ""
+ },
+ "require": {
+ "ext-dom": "*",
+ "ext-json": "*",
+ "ext-libxml": "*",
+ "ext-mbstring": "*",
+ "ext-xml": "*",
+ "ext-xmlwriter": "*",
+ "myclabs/deep-copy": "^1.13.4",
+ "phar-io/manifest": "^2.0.4",
+ "phar-io/version": "^3.2.1",
+ "php": ">=8.2",
+ "phpunit/php-code-coverage": "^11.0.12",
+ "phpunit/php-file-iterator": "^5.1.0",
+ "phpunit/php-invoker": "^5.0.1",
+ "phpunit/php-text-template": "^4.0.1",
+ "phpunit/php-timer": "^7.0.1",
+ "sebastian/cli-parser": "^3.0.2",
+ "sebastian/code-unit": "^3.0.3",
+ "sebastian/comparator": "^6.3.3",
+ "sebastian/diff": "^6.0.2",
+ "sebastian/environment": "^7.2.1",
+ "sebastian/exporter": "^6.3.2",
+ "sebastian/global-state": "^7.0.2",
+ "sebastian/object-enumerator": "^6.0.1",
+ "sebastian/type": "^5.1.3",
+ "sebastian/version": "^5.0.2",
+ "staabm/side-effects-detector": "^1.0.5"
+ },
+ "suggest": {
+ "ext-soap": "To be able to generate mocks based on WSDL files"
+ },
+ "bin": [
+ "phpunit"
+ ],
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "11.5-dev"
+ }
+ },
+ "autoload": {
+ "files": [
+ "src/Framework/Assert/Functions.php"
+ ],
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "The PHP Unit Testing framework.",
+ "homepage": "https://phpunit.de/",
+ "keywords": [
+ "phpunit",
+ "testing",
+ "xunit"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/phpunit/issues",
+ "security": "https://github.com/sebastianbergmann/phpunit/security/policy",
+ "source": "https://github.com/sebastianbergmann/phpunit/tree/11.5.50"
+ },
+ "funding": [
+ {
+ "url": "https://phpunit.de/sponsors.html",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ },
+ {
+ "url": "https://liberapay.com/sebastianbergmann",
+ "type": "liberapay"
+ },
+ {
+ "url": "https://thanks.dev/u/gh/sebastianbergmann",
+ "type": "thanks_dev"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/phpunit/phpunit",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2026-01-27T05:59:18+00:00"
+ },
+ {
+ "name": "psr/container",
+ "version": "2.0.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-fig/container.git",
+ "reference": "c71ecc56dfe541dbd90c5360474fbc405f8d5963"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-fig/container/zipball/c71ecc56dfe541dbd90c5360474fbc405f8d5963",
+ "reference": "c71ecc56dfe541dbd90c5360474fbc405f8d5963",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.4.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.0.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Psr\\Container\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "PHP-FIG",
+ "homepage": "https://www.php-fig.org/"
+ }
+ ],
+ "description": "Common Container Interface (PHP FIG PSR-11)",
+ "homepage": "https://github.com/php-fig/container",
+ "keywords": [
+ "PSR-11",
+ "container",
+ "container-interface",
+ "container-interop",
+ "psr"
+ ],
+ "support": {
+ "issues": "https://github.com/php-fig/container/issues",
+ "source": "https://github.com/php-fig/container/tree/2.0.2"
+ },
+ "time": "2021-11-05T16:47:00+00:00"
+ },
+ {
+ "name": "psr/event-dispatcher",
+ "version": "1.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-fig/event-dispatcher.git",
+ "reference": "dbefd12671e8a14ec7f180cab83036ed26714bb0"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-fig/event-dispatcher/zipball/dbefd12671e8a14ec7f180cab83036ed26714bb0",
+ "reference": "dbefd12671e8a14ec7f180cab83036ed26714bb0",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.2.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Psr\\EventDispatcher\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "PHP-FIG",
+ "homepage": "http://www.php-fig.org/"
+ }
+ ],
+ "description": "Standard interfaces for event handling.",
+ "keywords": [
+ "events",
+ "psr",
+ "psr-14"
+ ],
+ "support": {
+ "issues": "https://github.com/php-fig/event-dispatcher/issues",
+ "source": "https://github.com/php-fig/event-dispatcher/tree/1.0.0"
+ },
+ "time": "2019-01-08T18:20:26+00:00"
+ },
+ {
+ "name": "psr/http-factory",
+ "version": "1.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-fig/http-factory.git",
+ "reference": "2b4765fddfe3b508ac62f829e852b1501d3f6e8a"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-fig/http-factory/zipball/2b4765fddfe3b508ac62f829e852b1501d3f6e8a",
+ "reference": "2b4765fddfe3b508ac62f829e852b1501d3f6e8a",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.1",
+ "psr/http-message": "^1.0 || ^2.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Psr\\Http\\Message\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "PHP-FIG",
+ "homepage": "https://www.php-fig.org/"
+ }
+ ],
+ "description": "PSR-17: Common interfaces for PSR-7 HTTP message factories",
+ "keywords": [
+ "factory",
+ "http",
+ "message",
+ "psr",
+ "psr-17",
+ "psr-7",
+ "request",
+ "response"
+ ],
+ "support": {
+ "source": "https://github.com/php-fig/http-factory"
+ },
+ "time": "2024-04-15T12:06:14+00:00"
+ },
+ {
+ "name": "psr/log",
+ "version": "3.0.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-fig/log.git",
+ "reference": "f16e1d5863e37f8d8c2a01719f5b34baa2b714d3"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-fig/log/zipball/f16e1d5863e37f8d8c2a01719f5b34baa2b714d3",
+ "reference": "f16e1d5863e37f8d8c2a01719f5b34baa2b714d3",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.0.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "3.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Psr\\Log\\": "src"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "PHP-FIG",
+ "homepage": "https://www.php-fig.org/"
+ }
+ ],
+ "description": "Common interface for logging libraries",
+ "homepage": "https://github.com/php-fig/log",
+ "keywords": [
+ "log",
+ "psr",
+ "psr-3"
+ ],
+ "support": {
+ "source": "https://github.com/php-fig/log/tree/3.0.2"
+ },
+ "time": "2024-09-11T13:17:53+00:00"
+ },
+ {
+ "name": "psr/simple-cache",
+ "version": "3.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-fig/simple-cache.git",
+ "reference": "764e0b3939f5ca87cb904f570ef9be2d78a07865"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-fig/simple-cache/zipball/764e0b3939f5ca87cb904f570ef9be2d78a07865",
+ "reference": "764e0b3939f5ca87cb904f570ef9be2d78a07865",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.0.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "3.0.x-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Psr\\SimpleCache\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "PHP-FIG",
+ "homepage": "https://www.php-fig.org/"
+ }
+ ],
+ "description": "Common interfaces for simple caching",
+ "keywords": [
+ "cache",
+ "caching",
+ "psr",
+ "psr-16",
+ "simple-cache"
+ ],
+ "support": {
+ "source": "https://github.com/php-fig/simple-cache/tree/3.0.0"
+ },
+ "time": "2021-10-29T13:26:27+00:00"
+ },
+ {
+ "name": "ralouphie/getallheaders",
+ "version": "3.0.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/ralouphie/getallheaders.git",
+ "reference": "120b605dfeb996808c31b6477290a714d356e822"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/ralouphie/getallheaders/zipball/120b605dfeb996808c31b6477290a714d356e822",
+ "reference": "120b605dfeb996808c31b6477290a714d356e822",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.6"
+ },
+ "require-dev": {
+ "php-coveralls/php-coveralls": "^2.1",
+ "phpunit/phpunit": "^5 || ^6.5"
+ },
+ "type": "library",
+ "autoload": {
+ "files": [
+ "src/getallheaders.php"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Ralph Khattar",
+ "email": "ralph.khattar@gmail.com"
+ }
+ ],
+ "description": "A polyfill for getallheaders.",
+ "support": {
+ "issues": "https://github.com/ralouphie/getallheaders/issues",
+ "source": "https://github.com/ralouphie/getallheaders/tree/develop"
+ },
+ "time": "2019-03-08T08:55:37+00:00"
+ },
+ {
+ "name": "react/cache",
+ "version": "v1.2.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/reactphp/cache.git",
+ "reference": "d47c472b64aa5608225f47965a484b75c7817d5b"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/reactphp/cache/zipball/d47c472b64aa5608225f47965a484b75c7817d5b",
+ "reference": "d47c472b64aa5608225f47965a484b75c7817d5b",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.0",
+ "react/promise": "^3.0 || ^2.0 || ^1.1"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^9.5 || ^5.7 || ^4.8.35"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "React\\Cache\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Christian Lück",
+ "email": "christian@clue.engineering",
+ "homepage": "https://clue.engineering/"
+ },
+ {
+ "name": "Cees-Jan Kiewiet",
+ "email": "reactphp@ceesjankiewiet.nl",
+ "homepage": "https://wyrihaximus.net/"
+ },
+ {
+ "name": "Jan Sorgalla",
+ "email": "jsorgalla@gmail.com",
+ "homepage": "https://sorgalla.com/"
+ },
+ {
+ "name": "Chris Boden",
+ "email": "cboden@gmail.com",
+ "homepage": "https://cboden.dev/"
+ }
+ ],
+ "description": "Async, Promise-based cache interface for ReactPHP",
+ "keywords": [
+ "cache",
+ "caching",
+ "promise",
+ "reactphp"
+ ],
+ "support": {
+ "issues": "https://github.com/reactphp/cache/issues",
+ "source": "https://github.com/reactphp/cache/tree/v1.2.0"
+ },
+ "funding": [
+ {
+ "url": "https://opencollective.com/reactphp",
+ "type": "open_collective"
+ }
+ ],
+ "time": "2022-11-30T15:59:55+00:00"
+ },
+ {
+ "name": "react/child-process",
+ "version": "v0.6.7",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/reactphp/child-process.git",
+ "reference": "970f0e71945556422ee4570ccbabaedc3cf04ad3"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/reactphp/child-process/zipball/970f0e71945556422ee4570ccbabaedc3cf04ad3",
+ "reference": "970f0e71945556422ee4570ccbabaedc3cf04ad3",
+ "shasum": ""
+ },
+ "require": {
+ "evenement/evenement": "^3.0 || ^2.0 || ^1.0",
+ "php": ">=5.3.0",
+ "react/event-loop": "^1.2",
+ "react/stream": "^1.4"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36",
+ "react/socket": "^1.16",
+ "sebastian/environment": "^5.0 || ^3.0 || ^2.0 || ^1.0"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "React\\ChildProcess\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Christian Lück",
+ "email": "christian@clue.engineering",
+ "homepage": "https://clue.engineering/"
+ },
+ {
+ "name": "Cees-Jan Kiewiet",
+ "email": "reactphp@ceesjankiewiet.nl",
+ "homepage": "https://wyrihaximus.net/"
+ },
+ {
+ "name": "Jan Sorgalla",
+ "email": "jsorgalla@gmail.com",
+ "homepage": "https://sorgalla.com/"
+ },
+ {
+ "name": "Chris Boden",
+ "email": "cboden@gmail.com",
+ "homepage": "https://cboden.dev/"
+ }
+ ],
+ "description": "Event-driven library for executing child processes with ReactPHP.",
+ "keywords": [
+ "event-driven",
+ "process",
+ "reactphp"
+ ],
+ "support": {
+ "issues": "https://github.com/reactphp/child-process/issues",
+ "source": "https://github.com/reactphp/child-process/tree/v0.6.7"
+ },
+ "funding": [
+ {
+ "url": "https://opencollective.com/reactphp",
+ "type": "open_collective"
+ }
+ ],
+ "time": "2025-12-23T15:25:20+00:00"
+ },
+ {
+ "name": "react/dns",
+ "version": "v1.14.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/reactphp/dns.git",
+ "reference": "7562c05391f42701c1fccf189c8225fece1cd7c3"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/reactphp/dns/zipball/7562c05391f42701c1fccf189c8225fece1cd7c3",
+ "reference": "7562c05391f42701c1fccf189c8225fece1cd7c3",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.0",
+ "react/cache": "^1.0 || ^0.6 || ^0.5",
+ "react/event-loop": "^1.2",
+ "react/promise": "^3.2 || ^2.7 || ^1.2.1"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36",
+ "react/async": "^4.3 || ^3 || ^2",
+ "react/promise-timer": "^1.11"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "React\\Dns\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Christian Lück",
+ "email": "christian@clue.engineering",
+ "homepage": "https://clue.engineering/"
+ },
+ {
+ "name": "Cees-Jan Kiewiet",
+ "email": "reactphp@ceesjankiewiet.nl",
+ "homepage": "https://wyrihaximus.net/"
+ },
+ {
+ "name": "Jan Sorgalla",
+ "email": "jsorgalla@gmail.com",
+ "homepage": "https://sorgalla.com/"
+ },
+ {
+ "name": "Chris Boden",
+ "email": "cboden@gmail.com",
+ "homepage": "https://cboden.dev/"
+ }
+ ],
+ "description": "Async DNS resolver for ReactPHP",
+ "keywords": [
+ "async",
+ "dns",
+ "dns-resolver",
+ "reactphp"
+ ],
+ "support": {
+ "issues": "https://github.com/reactphp/dns/issues",
+ "source": "https://github.com/reactphp/dns/tree/v1.14.0"
+ },
+ "funding": [
+ {
+ "url": "https://opencollective.com/reactphp",
+ "type": "open_collective"
+ }
+ ],
+ "time": "2025-11-18T19:34:28+00:00"
+ },
+ {
+ "name": "react/event-loop",
+ "version": "v1.6.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/reactphp/event-loop.git",
+ "reference": "ba276bda6083df7e0050fd9b33f66ad7a4ac747a"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/reactphp/event-loop/zipball/ba276bda6083df7e0050fd9b33f66ad7a4ac747a",
+ "reference": "ba276bda6083df7e0050fd9b33f66ad7a4ac747a",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36"
+ },
+ "suggest": {
+ "ext-pcntl": "For signal handling support when using the StreamSelectLoop"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "React\\EventLoop\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Christian Lück",
+ "email": "christian@clue.engineering",
+ "homepage": "https://clue.engineering/"
+ },
+ {
+ "name": "Cees-Jan Kiewiet",
+ "email": "reactphp@ceesjankiewiet.nl",
+ "homepage": "https://wyrihaximus.net/"
+ },
+ {
+ "name": "Jan Sorgalla",
+ "email": "jsorgalla@gmail.com",
+ "homepage": "https://sorgalla.com/"
+ },
+ {
+ "name": "Chris Boden",
+ "email": "cboden@gmail.com",
+ "homepage": "https://cboden.dev/"
+ }
+ ],
+ "description": "ReactPHP's core reactor event loop that libraries can use for evented I/O.",
+ "keywords": [
+ "asynchronous",
+ "event-loop"
+ ],
+ "support": {
+ "issues": "https://github.com/reactphp/event-loop/issues",
+ "source": "https://github.com/reactphp/event-loop/tree/v1.6.0"
+ },
+ "funding": [
+ {
+ "url": "https://opencollective.com/reactphp",
+ "type": "open_collective"
+ }
+ ],
+ "time": "2025-11-17T20:46:25+00:00"
+ },
+ {
+ "name": "react/promise",
+ "version": "v3.3.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/reactphp/promise.git",
+ "reference": "23444f53a813a3296c1368bb104793ce8d88f04a"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/reactphp/promise/zipball/23444f53a813a3296c1368bb104793ce8d88f04a",
+ "reference": "23444f53a813a3296c1368bb104793ce8d88f04a",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.1.0"
+ },
+ "require-dev": {
+ "phpstan/phpstan": "1.12.28 || 1.4.10",
+ "phpunit/phpunit": "^9.6 || ^7.5"
+ },
+ "type": "library",
+ "autoload": {
+ "files": [
+ "src/functions_include.php"
+ ],
+ "psr-4": {
+ "React\\Promise\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Jan Sorgalla",
+ "email": "jsorgalla@gmail.com",
+ "homepage": "https://sorgalla.com/"
+ },
+ {
+ "name": "Christian Lück",
+ "email": "christian@clue.engineering",
+ "homepage": "https://clue.engineering/"
+ },
+ {
+ "name": "Cees-Jan Kiewiet",
+ "email": "reactphp@ceesjankiewiet.nl",
+ "homepage": "https://wyrihaximus.net/"
+ },
+ {
+ "name": "Chris Boden",
+ "email": "cboden@gmail.com",
+ "homepage": "https://cboden.dev/"
+ }
+ ],
+ "description": "A lightweight implementation of CommonJS Promises/A for PHP",
+ "keywords": [
+ "promise",
+ "promises"
+ ],
+ "support": {
+ "issues": "https://github.com/reactphp/promise/issues",
+ "source": "https://github.com/reactphp/promise/tree/v3.3.0"
+ },
+ "funding": [
+ {
+ "url": "https://opencollective.com/reactphp",
+ "type": "open_collective"
+ }
+ ],
+ "time": "2025-08-19T18:57:03+00:00"
+ },
+ {
+ "name": "react/socket",
+ "version": "v1.17.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/reactphp/socket.git",
+ "reference": "ef5b17b81f6f60504c539313f94f2d826c5faa08"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/reactphp/socket/zipball/ef5b17b81f6f60504c539313f94f2d826c5faa08",
+ "reference": "ef5b17b81f6f60504c539313f94f2d826c5faa08",
+ "shasum": ""
+ },
+ "require": {
+ "evenement/evenement": "^3.0 || ^2.0 || ^1.0",
+ "php": ">=5.3.0",
+ "react/dns": "^1.13",
+ "react/event-loop": "^1.2",
+ "react/promise": "^3.2 || ^2.6 || ^1.2.1",
+ "react/stream": "^1.4"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36",
+ "react/async": "^4.3 || ^3.3 || ^2",
+ "react/promise-stream": "^1.4",
+ "react/promise-timer": "^1.11"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "React\\Socket\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Christian Lück",
+ "email": "christian@clue.engineering",
+ "homepage": "https://clue.engineering/"
+ },
+ {
+ "name": "Cees-Jan Kiewiet",
+ "email": "reactphp@ceesjankiewiet.nl",
+ "homepage": "https://wyrihaximus.net/"
+ },
+ {
+ "name": "Jan Sorgalla",
+ "email": "jsorgalla@gmail.com",
+ "homepage": "https://sorgalla.com/"
+ },
+ {
+ "name": "Chris Boden",
+ "email": "cboden@gmail.com",
+ "homepage": "https://cboden.dev/"
+ }
+ ],
+ "description": "Async, streaming plaintext TCP/IP and secure TLS socket server and client connections for ReactPHP",
+ "keywords": [
+ "Connection",
+ "Socket",
+ "async",
+ "reactphp",
+ "stream"
+ ],
+ "support": {
+ "issues": "https://github.com/reactphp/socket/issues",
+ "source": "https://github.com/reactphp/socket/tree/v1.17.0"
+ },
+ "funding": [
+ {
+ "url": "https://opencollective.com/reactphp",
+ "type": "open_collective"
+ }
+ ],
+ "time": "2025-11-19T20:47:34+00:00"
+ },
+ {
+ "name": "react/stream",
+ "version": "v1.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/reactphp/stream.git",
+ "reference": "1e5b0acb8fe55143b5b426817155190eb6f5b18d"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/reactphp/stream/zipball/1e5b0acb8fe55143b5b426817155190eb6f5b18d",
+ "reference": "1e5b0acb8fe55143b5b426817155190eb6f5b18d",
+ "shasum": ""
+ },
+ "require": {
+ "evenement/evenement": "^3.0 || ^2.0 || ^1.0",
+ "php": ">=5.3.8",
+ "react/event-loop": "^1.2"
+ },
+ "require-dev": {
+ "clue/stream-filter": "~1.2",
+ "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "React\\Stream\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Christian Lück",
+ "email": "christian@clue.engineering",
+ "homepage": "https://clue.engineering/"
+ },
+ {
+ "name": "Cees-Jan Kiewiet",
+ "email": "reactphp@ceesjankiewiet.nl",
+ "homepage": "https://wyrihaximus.net/"
+ },
+ {
+ "name": "Jan Sorgalla",
+ "email": "jsorgalla@gmail.com",
+ "homepage": "https://sorgalla.com/"
+ },
+ {
+ "name": "Chris Boden",
+ "email": "cboden@gmail.com",
+ "homepage": "https://cboden.dev/"
+ }
+ ],
+ "description": "Event-driven readable and writable streams for non-blocking I/O in ReactPHP",
+ "keywords": [
+ "event-driven",
+ "io",
+ "non-blocking",
+ "pipe",
+ "reactphp",
+ "readable",
+ "stream",
+ "writable"
+ ],
+ "support": {
+ "issues": "https://github.com/reactphp/stream/issues",
+ "source": "https://github.com/reactphp/stream/tree/v1.4.0"
+ },
+ "funding": [
+ {
+ "url": "https://opencollective.com/reactphp",
+ "type": "open_collective"
+ }
+ ],
+ "time": "2024-06-11T12:45:25+00:00"
+ },
+ {
+ "name": "sebastian/cli-parser",
+ "version": "3.0.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/cli-parser.git",
+ "reference": "15c5dd40dc4f38794d383bb95465193f5e0ae180"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/cli-parser/zipball/15c5dd40dc4f38794d383bb95465193f5e0ae180",
+ "reference": "15c5dd40dc4f38794d383bb95465193f5e0ae180",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "3.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Library for parsing CLI options",
+ "homepage": "https://github.com/sebastianbergmann/cli-parser",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/cli-parser/issues",
+ "security": "https://github.com/sebastianbergmann/cli-parser/security/policy",
+ "source": "https://github.com/sebastianbergmann/cli-parser/tree/3.0.2"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T04:41:36+00:00"
+ },
+ {
+ "name": "sebastian/code-unit",
+ "version": "3.0.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/code-unit.git",
+ "reference": "54391c61e4af8078e5b276ab082b6d3c54c9ad64"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/code-unit/zipball/54391c61e4af8078e5b276ab082b6d3c54c9ad64",
+ "reference": "54391c61e4af8078e5b276ab082b6d3c54c9ad64",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.5"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "3.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Collection of value objects that represent the PHP code units",
+ "homepage": "https://github.com/sebastianbergmann/code-unit",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/code-unit/issues",
+ "security": "https://github.com/sebastianbergmann/code-unit/security/policy",
+ "source": "https://github.com/sebastianbergmann/code-unit/tree/3.0.3"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2025-03-19T07:56:08+00:00"
+ },
+ {
+ "name": "sebastian/code-unit-reverse-lookup",
+ "version": "4.0.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/code-unit-reverse-lookup.git",
+ "reference": "183a9b2632194febd219bb9246eee421dad8d45e"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/code-unit-reverse-lookup/zipball/183a9b2632194febd219bb9246eee421dad8d45e",
+ "reference": "183a9b2632194febd219bb9246eee421dad8d45e",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "4.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Looks up which function or method a line of code belongs to",
+ "homepage": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/issues",
+ "security": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/security/policy",
+ "source": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/tree/4.0.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T04:45:54+00:00"
+ },
+ {
+ "name": "sebastian/comparator",
+ "version": "6.3.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/comparator.git",
+ "reference": "2c95e1e86cb8dd41beb8d502057d1081ccc8eca9"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/2c95e1e86cb8dd41beb8d502057d1081ccc8eca9",
+ "reference": "2c95e1e86cb8dd41beb8d502057d1081ccc8eca9",
+ "shasum": ""
+ },
+ "require": {
+ "ext-dom": "*",
+ "ext-mbstring": "*",
+ "php": ">=8.2",
+ "sebastian/diff": "^6.0",
+ "sebastian/exporter": "^6.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.4"
+ },
+ "suggest": {
+ "ext-bcmath": "For comparing BcMath\\Number objects"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "6.3-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ },
+ {
+ "name": "Jeff Welch",
+ "email": "whatthejeff@gmail.com"
+ },
+ {
+ "name": "Volker Dusch",
+ "email": "github@wallbash.com"
+ },
+ {
+ "name": "Bernhard Schussek",
+ "email": "bschussek@2bepublished.at"
+ }
+ ],
+ "description": "Provides the functionality to compare PHP values for equality",
+ "homepage": "https://github.com/sebastianbergmann/comparator",
+ "keywords": [
+ "comparator",
+ "compare",
+ "equality"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/comparator/issues",
+ "security": "https://github.com/sebastianbergmann/comparator/security/policy",
+ "source": "https://github.com/sebastianbergmann/comparator/tree/6.3.3"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ },
+ {
+ "url": "https://liberapay.com/sebastianbergmann",
+ "type": "liberapay"
+ },
+ {
+ "url": "https://thanks.dev/u/gh/sebastianbergmann",
+ "type": "thanks_dev"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/sebastian/comparator",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2026-01-24T09:26:40+00:00"
+ },
+ {
+ "name": "sebastian/complexity",
+ "version": "4.0.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/complexity.git",
+ "reference": "ee41d384ab1906c68852636b6de493846e13e5a0"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/complexity/zipball/ee41d384ab1906c68852636b6de493846e13e5a0",
+ "reference": "ee41d384ab1906c68852636b6de493846e13e5a0",
+ "shasum": ""
+ },
+ "require": {
+ "nikic/php-parser": "^5.0",
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "4.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Library for calculating the complexity of PHP code units",
+ "homepage": "https://github.com/sebastianbergmann/complexity",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/complexity/issues",
+ "security": "https://github.com/sebastianbergmann/complexity/security/policy",
+ "source": "https://github.com/sebastianbergmann/complexity/tree/4.0.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T04:49:50+00:00"
+ },
+ {
+ "name": "sebastian/diff",
+ "version": "6.0.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/diff.git",
+ "reference": "b4ccd857127db5d41a5b676f24b51371d76d8544"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/b4ccd857127db5d41a5b676f24b51371d76d8544",
+ "reference": "b4ccd857127db5d41a5b676f24b51371d76d8544",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.0",
+ "symfony/process": "^4.2 || ^5"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "6.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ },
+ {
+ "name": "Kore Nordmann",
+ "email": "mail@kore-nordmann.de"
+ }
+ ],
+ "description": "Diff implementation",
+ "homepage": "https://github.com/sebastianbergmann/diff",
+ "keywords": [
+ "diff",
+ "udiff",
+ "unidiff",
+ "unified diff"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/diff/issues",
+ "security": "https://github.com/sebastianbergmann/diff/security/policy",
+ "source": "https://github.com/sebastianbergmann/diff/tree/6.0.2"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T04:53:05+00:00"
+ },
+ {
+ "name": "sebastian/environment",
+ "version": "7.2.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/environment.git",
+ "reference": "a5c75038693ad2e8d4b6c15ba2403532647830c4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/a5c75038693ad2e8d4b6c15ba2403532647830c4",
+ "reference": "a5c75038693ad2e8d4b6c15ba2403532647830c4",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.3"
+ },
+ "suggest": {
+ "ext-posix": "*"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "7.2-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Provides functionality to handle HHVM/PHP environments",
+ "homepage": "https://github.com/sebastianbergmann/environment",
+ "keywords": [
+ "Xdebug",
+ "environment",
+ "hhvm"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/environment/issues",
+ "security": "https://github.com/sebastianbergmann/environment/security/policy",
+ "source": "https://github.com/sebastianbergmann/environment/tree/7.2.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ },
+ {
+ "url": "https://liberapay.com/sebastianbergmann",
+ "type": "liberapay"
+ },
+ {
+ "url": "https://thanks.dev/u/gh/sebastianbergmann",
+ "type": "thanks_dev"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/sebastian/environment",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-05-21T11:55:47+00:00"
+ },
+ {
+ "name": "sebastian/exporter",
+ "version": "6.3.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/exporter.git",
+ "reference": "70a298763b40b213ec087c51c739efcaa90bcd74"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/70a298763b40b213ec087c51c739efcaa90bcd74",
+ "reference": "70a298763b40b213ec087c51c739efcaa90bcd74",
+ "shasum": ""
+ },
+ "require": {
+ "ext-mbstring": "*",
+ "php": ">=8.2",
+ "sebastian/recursion-context": "^6.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.3"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "6.3-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ },
+ {
+ "name": "Jeff Welch",
+ "email": "whatthejeff@gmail.com"
+ },
+ {
+ "name": "Volker Dusch",
+ "email": "github@wallbash.com"
+ },
+ {
+ "name": "Adam Harvey",
+ "email": "aharvey@php.net"
+ },
+ {
+ "name": "Bernhard Schussek",
+ "email": "bschussek@gmail.com"
+ }
+ ],
+ "description": "Provides the functionality to export PHP variables for visualization",
+ "homepage": "https://www.github.com/sebastianbergmann/exporter",
+ "keywords": [
+ "export",
+ "exporter"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/exporter/issues",
+ "security": "https://github.com/sebastianbergmann/exporter/security/policy",
+ "source": "https://github.com/sebastianbergmann/exporter/tree/6.3.2"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ },
+ {
+ "url": "https://liberapay.com/sebastianbergmann",
+ "type": "liberapay"
+ },
+ {
+ "url": "https://thanks.dev/u/gh/sebastianbergmann",
+ "type": "thanks_dev"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/sebastian/exporter",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-09-24T06:12:51+00:00"
+ },
+ {
+ "name": "sebastian/global-state",
+ "version": "7.0.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/global-state.git",
+ "reference": "3be331570a721f9a4b5917f4209773de17f747d7"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/global-state/zipball/3be331570a721f9a4b5917f4209773de17f747d7",
+ "reference": "3be331570a721f9a4b5917f4209773de17f747d7",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2",
+ "sebastian/object-reflector": "^4.0",
+ "sebastian/recursion-context": "^6.0"
+ },
+ "require-dev": {
+ "ext-dom": "*",
+ "phpunit/phpunit": "^11.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "7.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Snapshotting of global state",
+ "homepage": "https://www.github.com/sebastianbergmann/global-state",
+ "keywords": [
+ "global state"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/global-state/issues",
+ "security": "https://github.com/sebastianbergmann/global-state/security/policy",
+ "source": "https://github.com/sebastianbergmann/global-state/tree/7.0.2"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T04:57:36+00:00"
+ },
+ {
+ "name": "sebastian/lines-of-code",
+ "version": "3.0.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/lines-of-code.git",
+ "reference": "d36ad0d782e5756913e42ad87cb2890f4ffe467a"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/lines-of-code/zipball/d36ad0d782e5756913e42ad87cb2890f4ffe467a",
+ "reference": "d36ad0d782e5756913e42ad87cb2890f4ffe467a",
+ "shasum": ""
+ },
+ "require": {
+ "nikic/php-parser": "^5.0",
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "3.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Library for counting the lines of code in PHP source code",
+ "homepage": "https://github.com/sebastianbergmann/lines-of-code",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/lines-of-code/issues",
+ "security": "https://github.com/sebastianbergmann/lines-of-code/security/policy",
+ "source": "https://github.com/sebastianbergmann/lines-of-code/tree/3.0.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T04:58:38+00:00"
+ },
+ {
+ "name": "sebastian/object-enumerator",
+ "version": "6.0.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/object-enumerator.git",
+ "reference": "f5b498e631a74204185071eb41f33f38d64608aa"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/object-enumerator/zipball/f5b498e631a74204185071eb41f33f38d64608aa",
+ "reference": "f5b498e631a74204185071eb41f33f38d64608aa",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2",
+ "sebastian/object-reflector": "^4.0",
+ "sebastian/recursion-context": "^6.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "6.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Traverses array structures and object graphs to enumerate all referenced objects",
+ "homepage": "https://github.com/sebastianbergmann/object-enumerator/",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/object-enumerator/issues",
+ "security": "https://github.com/sebastianbergmann/object-enumerator/security/policy",
+ "source": "https://github.com/sebastianbergmann/object-enumerator/tree/6.0.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T05:00:13+00:00"
+ },
+ {
+ "name": "sebastian/object-reflector",
+ "version": "4.0.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/object-reflector.git",
+ "reference": "6e1a43b411b2ad34146dee7524cb13a068bb35f9"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/object-reflector/zipball/6e1a43b411b2ad34146dee7524cb13a068bb35f9",
+ "reference": "6e1a43b411b2ad34146dee7524cb13a068bb35f9",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.0"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "4.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Allows reflection of object attributes, including inherited and non-public ones",
+ "homepage": "https://github.com/sebastianbergmann/object-reflector/",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/object-reflector/issues",
+ "security": "https://github.com/sebastianbergmann/object-reflector/security/policy",
+ "source": "https://github.com/sebastianbergmann/object-reflector/tree/4.0.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-07-03T05:01:32+00:00"
+ },
+ {
+ "name": "sebastian/recursion-context",
+ "version": "6.0.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/recursion-context.git",
+ "reference": "f6458abbf32a6c8174f8f26261475dc133b3d9dc"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/recursion-context/zipball/f6458abbf32a6c8174f8f26261475dc133b3d9dc",
+ "reference": "f6458abbf32a6c8174f8f26261475dc133b3d9dc",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.3"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "6.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ },
+ {
+ "name": "Jeff Welch",
+ "email": "whatthejeff@gmail.com"
+ },
+ {
+ "name": "Adam Harvey",
+ "email": "aharvey@php.net"
+ }
+ ],
+ "description": "Provides functionality to recursively process PHP variables",
+ "homepage": "https://github.com/sebastianbergmann/recursion-context",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/recursion-context/issues",
+ "security": "https://github.com/sebastianbergmann/recursion-context/security/policy",
+ "source": "https://github.com/sebastianbergmann/recursion-context/tree/6.0.3"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ },
+ {
+ "url": "https://liberapay.com/sebastianbergmann",
+ "type": "liberapay"
+ },
+ {
+ "url": "https://thanks.dev/u/gh/sebastianbergmann",
+ "type": "thanks_dev"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/sebastian/recursion-context",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-08-13T04:42:22+00:00"
+ },
+ {
+ "name": "sebastian/type",
+ "version": "5.1.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/type.git",
+ "reference": "f77d2d4e78738c98d9a68d2596fe5e8fa380f449"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/type/zipball/f77d2d4e78738c98d9a68d2596fe5e8fa380f449",
+ "reference": "f77d2d4e78738c98d9a68d2596fe5e8fa380f449",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^11.3"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "5.1-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Collection of value objects that represent the types of the PHP type system",
+ "homepage": "https://github.com/sebastianbergmann/type",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/type/issues",
+ "security": "https://github.com/sebastianbergmann/type/security/policy",
+ "source": "https://github.com/sebastianbergmann/type/tree/5.1.3"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ },
+ {
+ "url": "https://liberapay.com/sebastianbergmann",
+ "type": "liberapay"
+ },
+ {
+ "url": "https://thanks.dev/u/gh/sebastianbergmann",
+ "type": "thanks_dev"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/sebastian/type",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-08-09T06:55:48+00:00"
+ },
+ {
+ "name": "sebastian/version",
+ "version": "5.0.2",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/version.git",
+ "reference": "c687e3387b99f5b03b6caa64c74b63e2936ff874"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/version/zipball/c687e3387b99f5b03b6caa64c74b63e2936ff874",
+ "reference": "c687e3387b99f5b03b6caa64c74b63e2936ff874",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "5.0-dev"
+ }
+ },
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Library that helps with managing the version number of Git-hosted PHP projects",
+ "homepage": "https://github.com/sebastianbergmann/version",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/version/issues",
+ "security": "https://github.com/sebastianbergmann/version/security/policy",
+ "source": "https://github.com/sebastianbergmann/version/tree/5.0.2"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "time": "2024-10-09T05:16:32+00:00"
+ },
+ {
+ "name": "staabm/side-effects-detector",
+ "version": "1.0.5",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/staabm/side-effects-detector.git",
+ "reference": "d8334211a140ce329c13726d4a715adbddd0a163"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/staabm/side-effects-detector/zipball/d8334211a140ce329c13726d4a715adbddd0a163",
+ "reference": "d8334211a140ce329c13726d4a715adbddd0a163",
+ "shasum": ""
+ },
+ "require": {
+ "ext-tokenizer": "*",
+ "php": "^7.4 || ^8.0"
+ },
+ "require-dev": {
+ "phpstan/extension-installer": "^1.4.3",
+ "phpstan/phpstan": "^1.12.6",
+ "phpunit/phpunit": "^9.6.21",
+ "symfony/var-dumper": "^5.4.43",
+ "tomasvotruba/type-coverage": "1.0.0",
+ "tomasvotruba/unused-public": "1.0.0"
+ },
+ "type": "library",
+ "autoload": {
+ "classmap": [
+ "lib/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "A static analysis tool to detect side effects in PHP code",
+ "keywords": [
+ "static analysis"
+ ],
+ "support": {
+ "issues": "https://github.com/staabm/side-effects-detector/issues",
+ "source": "https://github.com/staabm/side-effects-detector/tree/1.0.5"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/staabm",
+ "type": "github"
+ }
+ ],
+ "time": "2024-10-20T05:08:20+00:00"
+ },
+ {
+ "name": "symfony/console",
+ "version": "v7.4.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/console.git",
+ "reference": "732a9ca6cd9dfd940c639062d5edbde2f6727fb6"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/console/zipball/732a9ca6cd9dfd940c639062d5edbde2f6727fb6",
+ "reference": "732a9ca6cd9dfd940c639062d5edbde2f6727fb6",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2",
+ "symfony/deprecation-contracts": "^2.5|^3",
+ "symfony/polyfill-mbstring": "~1.0",
+ "symfony/service-contracts": "^2.5|^3",
+ "symfony/string": "^7.2|^8.0"
+ },
+ "conflict": {
+ "symfony/dependency-injection": "<6.4",
+ "symfony/dotenv": "<6.4",
+ "symfony/event-dispatcher": "<6.4",
+ "symfony/lock": "<6.4",
+ "symfony/process": "<6.4"
+ },
+ "provide": {
+ "psr/log-implementation": "1.0|2.0|3.0"
+ },
+ "require-dev": {
+ "psr/log": "^1|^2|^3",
+ "symfony/config": "^6.4|^7.0|^8.0",
+ "symfony/dependency-injection": "^6.4|^7.0|^8.0",
+ "symfony/event-dispatcher": "^6.4|^7.0|^8.0",
+ "symfony/http-foundation": "^6.4|^7.0|^8.0",
+ "symfony/http-kernel": "^6.4|^7.0|^8.0",
+ "symfony/lock": "^6.4|^7.0|^8.0",
+ "symfony/messenger": "^6.4|^7.0|^8.0",
+ "symfony/process": "^6.4|^7.0|^8.0",
+ "symfony/stopwatch": "^6.4|^7.0|^8.0",
+ "symfony/var-dumper": "^6.4|^7.0|^8.0"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Console\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Eases the creation of beautiful and testable command line interfaces",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "cli",
+ "command-line",
+ "console",
+ "terminal"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/console/tree/v7.4.3"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-12-23T14:50:43+00:00"
+ },
+ {
+ "name": "symfony/deprecation-contracts",
+ "version": "v3.6.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/deprecation-contracts.git",
+ "reference": "63afe740e99a13ba87ec199bb07bbdee937a5b62"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/63afe740e99a13ba87ec199bb07bbdee937a5b62",
+ "reference": "63afe740e99a13ba87ec199bb07bbdee937a5b62",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.1"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/contracts",
+ "name": "symfony/contracts"
+ },
+ "branch-alias": {
+ "dev-main": "3.6-dev"
+ }
+ },
+ "autoload": {
+ "files": [
+ "function.php"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "A generic function and convention to trigger deprecation notices",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/deprecation-contracts/tree/v3.6.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2024-09-25T14:21:43+00:00"
+ },
+ {
+ "name": "symfony/event-dispatcher",
+ "version": "v7.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/event-dispatcher.git",
+ "reference": "9dddcddff1ef974ad87b3708e4b442dc38b2261d"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/9dddcddff1ef974ad87b3708e4b442dc38b2261d",
+ "reference": "9dddcddff1ef974ad87b3708e4b442dc38b2261d",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2",
+ "symfony/event-dispatcher-contracts": "^2.5|^3"
+ },
+ "conflict": {
+ "symfony/dependency-injection": "<6.4",
+ "symfony/service-contracts": "<2.5"
+ },
+ "provide": {
+ "psr/event-dispatcher-implementation": "1.0",
+ "symfony/event-dispatcher-implementation": "2.0|3.0"
+ },
+ "require-dev": {
+ "psr/log": "^1|^2|^3",
+ "symfony/config": "^6.4|^7.0|^8.0",
+ "symfony/dependency-injection": "^6.4|^7.0|^8.0",
+ "symfony/error-handler": "^6.4|^7.0|^8.0",
+ "symfony/expression-language": "^6.4|^7.0|^8.0",
+ "symfony/framework-bundle": "^6.4|^7.0|^8.0",
+ "symfony/http-foundation": "^6.4|^7.0|^8.0",
+ "symfony/service-contracts": "^2.5|^3",
+ "symfony/stopwatch": "^6.4|^7.0|^8.0"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\EventDispatcher\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Provides tools that allow your application components to communicate with each other by dispatching events and listening to them",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/event-dispatcher/tree/v7.4.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-10-28T09:38:46+00:00"
+ },
+ {
+ "name": "symfony/event-dispatcher-contracts",
+ "version": "v3.6.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/event-dispatcher-contracts.git",
+ "reference": "59eb412e93815df44f05f342958efa9f46b1e586"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/event-dispatcher-contracts/zipball/59eb412e93815df44f05f342958efa9f46b1e586",
+ "reference": "59eb412e93815df44f05f342958efa9f46b1e586",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.1",
+ "psr/event-dispatcher": "^1"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/contracts",
+ "name": "symfony/contracts"
+ },
+ "branch-alias": {
+ "dev-main": "3.6-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Contracts\\EventDispatcher\\": ""
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Generic abstractions related to dispatching event",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "abstractions",
+ "contracts",
+ "decoupling",
+ "interfaces",
+ "interoperability",
+ "standards"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v3.6.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2024-09-25T14:21:43+00:00"
+ },
+ {
+ "name": "symfony/filesystem",
+ "version": "v7.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/filesystem.git",
+ "reference": "d551b38811096d0be9c4691d406991b47c0c630a"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/filesystem/zipball/d551b38811096d0be9c4691d406991b47c0c630a",
+ "reference": "d551b38811096d0be9c4691d406991b47c0c630a",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2",
+ "symfony/polyfill-ctype": "~1.8",
+ "symfony/polyfill-mbstring": "~1.8"
+ },
+ "require-dev": {
+ "symfony/process": "^6.4|^7.0|^8.0"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Filesystem\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Provides basic utilities for the filesystem",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/filesystem/tree/v7.4.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-11-27T13:27:24+00:00"
+ },
+ {
+ "name": "symfony/finder",
+ "version": "v7.4.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/finder.git",
+ "reference": "fffe05569336549b20a1be64250b40516d6e8d06"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/finder/zipball/fffe05569336549b20a1be64250b40516d6e8d06",
+ "reference": "fffe05569336549b20a1be64250b40516d6e8d06",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "require-dev": {
+ "symfony/filesystem": "^6.4|^7.0|^8.0"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Finder\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Finds files and directories via an intuitive fluent interface",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/finder/tree/v7.4.3"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-12-23T14:50:43+00:00"
+ },
+ {
+ "name": "symfony/http-client",
+ "version": "v7.4.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/http-client.git",
+ "reference": "d01dfac1e0dc99f18da48b18101c23ce57929616"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/http-client/zipball/d01dfac1e0dc99f18da48b18101c23ce57929616",
+ "reference": "d01dfac1e0dc99f18da48b18101c23ce57929616",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2",
+ "psr/log": "^1|^2|^3",
+ "symfony/deprecation-contracts": "^2.5|^3",
+ "symfony/http-client-contracts": "~3.4.4|^3.5.2",
+ "symfony/polyfill-php83": "^1.29",
+ "symfony/service-contracts": "^2.5|^3"
+ },
+ "conflict": {
+ "amphp/amp": "<2.5",
+ "amphp/socket": "<1.1",
+ "php-http/discovery": "<1.15",
+ "symfony/http-foundation": "<6.4"
+ },
+ "provide": {
+ "php-http/async-client-implementation": "*",
+ "php-http/client-implementation": "*",
+ "psr/http-client-implementation": "1.0",
+ "symfony/http-client-implementation": "3.0"
+ },
+ "require-dev": {
+ "amphp/http-client": "^4.2.1|^5.0",
+ "amphp/http-tunnel": "^1.0|^2.0",
+ "guzzlehttp/promises": "^1.4|^2.0",
+ "nyholm/psr7": "^1.0",
+ "php-http/httplug": "^1.0|^2.0",
+ "psr/http-client": "^1.0",
+ "symfony/amphp-http-client-meta": "^1.0|^2.0",
+ "symfony/cache": "^6.4|^7.0|^8.0",
+ "symfony/dependency-injection": "^6.4|^7.0|^8.0",
+ "symfony/http-kernel": "^6.4|^7.0|^8.0",
+ "symfony/messenger": "^6.4|^7.0|^8.0",
+ "symfony/process": "^6.4|^7.0|^8.0",
+ "symfony/rate-limiter": "^6.4|^7.0|^8.0",
+ "symfony/stopwatch": "^6.4|^7.0|^8.0"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\HttpClient\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Provides powerful methods to fetch HTTP resources synchronously or asynchronously",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "http"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/http-client/tree/v7.4.3"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-12-23T14:50:43+00:00"
+ },
+ {
+ "name": "symfony/http-client-contracts",
+ "version": "v3.6.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/http-client-contracts.git",
+ "reference": "75d7043853a42837e68111812f4d964b01e5101c"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/http-client-contracts/zipball/75d7043853a42837e68111812f4d964b01e5101c",
+ "reference": "75d7043853a42837e68111812f4d964b01e5101c",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.1"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/contracts",
+ "name": "symfony/contracts"
+ },
+ "branch-alias": {
+ "dev-main": "3.6-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Contracts\\HttpClient\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Test/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Generic abstractions related to HTTP clients",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "abstractions",
+ "contracts",
+ "decoupling",
+ "interfaces",
+ "interoperability",
+ "standards"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/http-client-contracts/tree/v3.6.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-04-29T11:18:49+00:00"
+ },
+ {
+ "name": "symfony/options-resolver",
+ "version": "v7.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/options-resolver.git",
+ "reference": "b38026df55197f9e39a44f3215788edf83187b80"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/options-resolver/zipball/b38026df55197f9e39a44f3215788edf83187b80",
+ "reference": "b38026df55197f9e39a44f3215788edf83187b80",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2",
+ "symfony/deprecation-contracts": "^2.5|^3"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\OptionsResolver\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Provides an improved replacement for the array_replace PHP function",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "config",
+ "configuration",
+ "options"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/options-resolver/tree/v7.4.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-11-12T15:39:26+00:00"
+ },
+ {
+ "name": "symfony/polyfill-ctype",
+ "version": "v1.33.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-ctype.git",
+ "reference": "a3cc8b044a6ea513310cbd48ef7333b384945638"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/a3cc8b044a6ea513310cbd48ef7333b384945638",
+ "reference": "a3cc8b044a6ea513310cbd48ef7333b384945638",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.2"
+ },
+ "provide": {
+ "ext-ctype": "*"
+ },
+ "suggest": {
+ "ext-ctype": "For best performance"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/polyfill",
+ "name": "symfony/polyfill"
+ }
+ },
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Ctype\\": ""
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Gert de Pagter",
+ "email": "BackEndTea@gmail.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill for ctype functions",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "ctype",
+ "polyfill",
+ "portable"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-ctype/tree/v1.33.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2024-09-09T11:45:10+00:00"
+ },
+ {
+ "name": "symfony/polyfill-intl-grapheme",
+ "version": "v1.33.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-intl-grapheme.git",
+ "reference": "380872130d3a5dd3ace2f4010d95125fde5d5c70"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-intl-grapheme/zipball/380872130d3a5dd3ace2f4010d95125fde5d5c70",
+ "reference": "380872130d3a5dd3ace2f4010d95125fde5d5c70",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.2"
+ },
+ "suggest": {
+ "ext-intl": "For best performance"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/polyfill",
+ "name": "symfony/polyfill"
+ }
+ },
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Intl\\Grapheme\\": ""
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill for intl's grapheme_* functions",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "grapheme",
+ "intl",
+ "polyfill",
+ "portable",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-intl-grapheme/tree/v1.33.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-06-27T09:58:17+00:00"
+ },
+ {
+ "name": "symfony/polyfill-intl-normalizer",
+ "version": "v1.33.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-intl-normalizer.git",
+ "reference": "3833d7255cc303546435cb650316bff708a1c75c"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-intl-normalizer/zipball/3833d7255cc303546435cb650316bff708a1c75c",
+ "reference": "3833d7255cc303546435cb650316bff708a1c75c",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.2"
+ },
+ "suggest": {
+ "ext-intl": "For best performance"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/polyfill",
+ "name": "symfony/polyfill"
+ }
+ },
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Intl\\Normalizer\\": ""
+ },
+ "classmap": [
+ "Resources/stubs"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill for intl's Normalizer class and related functions",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "intl",
+ "normalizer",
+ "polyfill",
+ "portable",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-intl-normalizer/tree/v1.33.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2024-09-09T11:45:10+00:00"
+ },
+ {
+ "name": "symfony/polyfill-mbstring",
+ "version": "v1.33.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-mbstring.git",
+ "reference": "6d857f4d76bd4b343eac26d6b539585d2bc56493"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/6d857f4d76bd4b343eac26d6b539585d2bc56493",
+ "reference": "6d857f4d76bd4b343eac26d6b539585d2bc56493",
+ "shasum": ""
+ },
+ "require": {
+ "ext-iconv": "*",
+ "php": ">=7.2"
+ },
+ "provide": {
+ "ext-mbstring": "*"
+ },
+ "suggest": {
+ "ext-mbstring": "For best performance"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/polyfill",
+ "name": "symfony/polyfill"
+ }
+ },
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Mbstring\\": ""
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill for the Mbstring extension",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "mbstring",
+ "polyfill",
+ "portable",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-mbstring/tree/v1.33.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2024-12-23T08:48:59+00:00"
+ },
+ {
+ "name": "symfony/polyfill-php80",
+ "version": "v1.33.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-php80.git",
+ "reference": "0cc9dd0f17f61d8131e7df6b84bd344899fe2608"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/0cc9dd0f17f61d8131e7df6b84bd344899fe2608",
+ "reference": "0cc9dd0f17f61d8131e7df6b84bd344899fe2608",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.2"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/polyfill",
+ "name": "symfony/polyfill"
+ }
+ },
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Php80\\": ""
+ },
+ "classmap": [
+ "Resources/stubs"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Ion Bazan",
+ "email": "ion.bazan@gmail.com"
+ },
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill backporting some PHP 8.0+ features to lower PHP versions",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "polyfill",
+ "portable",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-php80/tree/v1.33.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-01-02T08:10:11+00:00"
+ },
+ {
+ "name": "symfony/polyfill-php81",
+ "version": "v1.33.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-php81.git",
+ "reference": "4a4cfc2d253c21a5ad0e53071df248ed48c6ce5c"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-php81/zipball/4a4cfc2d253c21a5ad0e53071df248ed48c6ce5c",
+ "reference": "4a4cfc2d253c21a5ad0e53071df248ed48c6ce5c",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.2"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/polyfill",
+ "name": "symfony/polyfill"
+ }
+ },
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Php81\\": ""
+ },
+ "classmap": [
+ "Resources/stubs"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill backporting some PHP 8.1+ features to lower PHP versions",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "polyfill",
+ "portable",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-php81/tree/v1.33.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2024-09-09T11:45:10+00:00"
+ },
+ {
+ "name": "symfony/polyfill-php83",
+ "version": "v1.33.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-php83.git",
+ "reference": "17f6f9a6b1735c0f163024d959f700cfbc5155e5"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-php83/zipball/17f6f9a6b1735c0f163024d959f700cfbc5155e5",
+ "reference": "17f6f9a6b1735c0f163024d959f700cfbc5155e5",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.2"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/polyfill",
+ "name": "symfony/polyfill"
+ }
+ },
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Php83\\": ""
+ },
+ "classmap": [
+ "Resources/stubs"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill backporting some PHP 8.3+ features to lower PHP versions",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "polyfill",
+ "portable",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-php83/tree/v1.33.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-07-08T02:45:35+00:00"
+ },
+ {
+ "name": "symfony/polyfill-php84",
+ "version": "v1.33.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-php84.git",
+ "reference": "d8ced4d875142b6a7426000426b8abc631d6b191"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-php84/zipball/d8ced4d875142b6a7426000426b8abc631d6b191",
+ "reference": "d8ced4d875142b6a7426000426b8abc631d6b191",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=7.2"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/polyfill",
+ "name": "symfony/polyfill"
+ }
+ },
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Php84\\": ""
+ },
+ "classmap": [
+ "Resources/stubs"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill backporting some PHP 8.4+ features to lower PHP versions",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "polyfill",
+ "portable",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-php84/tree/v1.33.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-06-24T13:30:11+00:00"
+ },
+ {
+ "name": "symfony/process",
+ "version": "v7.4.3",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/process.git",
+ "reference": "2f8e1a6cdf590ca63715da4d3a7a3327404a523f"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/process/zipball/2f8e1a6cdf590ca63715da4d3a7a3327404a523f",
+ "reference": "2f8e1a6cdf590ca63715da4d3a7a3327404a523f",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Process\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Executes commands in sub-processes",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/process/tree/v7.4.3"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-12-19T10:00:43+00:00"
+ },
+ {
+ "name": "symfony/service-contracts",
+ "version": "v3.6.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/service-contracts.git",
+ "reference": "45112560a3ba2d715666a509a0bc9521d10b6c43"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/service-contracts/zipball/45112560a3ba2d715666a509a0bc9521d10b6c43",
+ "reference": "45112560a3ba2d715666a509a0bc9521d10b6c43",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.1",
+ "psr/container": "^1.1|^2.0",
+ "symfony/deprecation-contracts": "^2.5|^3"
+ },
+ "conflict": {
+ "ext-psr": "<1.1|>=2"
+ },
+ "type": "library",
+ "extra": {
+ "thanks": {
+ "url": "https://github.com/symfony/contracts",
+ "name": "symfony/contracts"
+ },
+ "branch-alias": {
+ "dev-main": "3.6-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Contracts\\Service\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Test/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Generic abstractions related to writing services",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "abstractions",
+ "contracts",
+ "decoupling",
+ "interfaces",
+ "interoperability",
+ "standards"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/service-contracts/tree/v3.6.1"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-07-15T11:30:57+00:00"
+ },
+ {
+ "name": "symfony/stopwatch",
+ "version": "v7.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/stopwatch.git",
+ "reference": "8a24af0a2e8a872fb745047180649b8418303084"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/stopwatch/zipball/8a24af0a2e8a872fb745047180649b8418303084",
+ "reference": "8a24af0a2e8a872fb745047180649b8418303084",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2",
+ "symfony/service-contracts": "^2.5|^3"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Stopwatch\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Provides a way to profile code",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/stopwatch/tree/v7.4.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-08-04T07:05:15+00:00"
+ },
+ {
+ "name": "symfony/string",
+ "version": "v7.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/string.git",
+ "reference": "d50e862cb0a0e0886f73ca1f31b865efbb795003"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/string/zipball/d50e862cb0a0e0886f73ca1f31b865efbb795003",
+ "reference": "d50e862cb0a0e0886f73ca1f31b865efbb795003",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=8.2",
+ "symfony/deprecation-contracts": "^2.5|^3.0",
+ "symfony/polyfill-ctype": "~1.8",
+ "symfony/polyfill-intl-grapheme": "~1.33",
+ "symfony/polyfill-intl-normalizer": "~1.0",
+ "symfony/polyfill-mbstring": "~1.0"
+ },
+ "conflict": {
+ "symfony/translation-contracts": "<2.5"
+ },
+ "require-dev": {
+ "symfony/emoji": "^7.1|^8.0",
+ "symfony/http-client": "^6.4|^7.0|^8.0",
+ "symfony/intl": "^6.4|^7.0|^8.0",
+ "symfony/translation-contracts": "^2.5|^3.0",
+ "symfony/var-exporter": "^6.4|^7.0|^8.0"
+ },
+ "type": "library",
+ "autoload": {
+ "files": [
+ "Resources/functions.php"
+ ],
+ "psr-4": {
+ "Symfony\\Component\\String\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Provides an object-oriented API to strings and deals with bytes, UTF-8 code points and grapheme clusters in a unified way",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "grapheme",
+ "i18n",
+ "string",
+ "unicode",
+ "utf-8",
+ "utf8"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/string/tree/v7.4.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://github.com/nicolas-grekas",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "time": "2025-11-27T13:27:24+00:00"
+ },
+ {
+ "name": "ta-tikoma/phpunit-architecture-test",
+ "version": "0.8.5",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/ta-tikoma/phpunit-architecture-test.git",
+ "reference": "cf6fb197b676ba716837c886baca842e4db29005"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/ta-tikoma/phpunit-architecture-test/zipball/cf6fb197b676ba716837c886baca842e4db29005",
+ "reference": "cf6fb197b676ba716837c886baca842e4db29005",
+ "shasum": ""
+ },
+ "require": {
+ "nikic/php-parser": "^4.18.0 || ^5.0.0",
+ "php": "^8.1.0",
+ "phpdocumentor/reflection-docblock": "^5.3.0",
+ "phpunit/phpunit": "^10.5.5 || ^11.0.0 || ^12.0.0",
+ "symfony/finder": "^6.4.0 || ^7.0.0"
+ },
+ "require-dev": {
+ "laravel/pint": "^1.13.7",
+ "phpstan/phpstan": "^1.10.52"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "PHPUnit\\Architecture\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Ni Shi",
+ "email": "futik0ma011@gmail.com"
+ },
+ {
+ "name": "Nuno Maduro",
+ "email": "enunomaduro@gmail.com"
+ }
+ ],
+ "description": "Methods for testing application architecture",
+ "keywords": [
+ "architecture",
+ "phpunit",
+ "stucture",
+ "test",
+ "testing"
+ ],
+ "support": {
+ "issues": "https://github.com/ta-tikoma/phpunit-architecture-test/issues",
+ "source": "https://github.com/ta-tikoma/phpunit-architecture-test/tree/0.8.5"
+ },
+ "time": "2025-04-20T20:23:40+00:00"
+ },
+ {
+ "name": "theseer/tokenizer",
+ "version": "1.3.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/theseer/tokenizer.git",
+ "reference": "b7489ce515e168639d17feec34b8847c326b0b3c"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/theseer/tokenizer/zipball/b7489ce515e168639d17feec34b8847c326b0b3c",
+ "reference": "b7489ce515e168639d17feec34b8847c326b0b3c",
+ "shasum": ""
+ },
+ "require": {
+ "ext-dom": "*",
+ "ext-tokenizer": "*",
+ "ext-xmlwriter": "*",
+ "php": "^7.2 || ^8.0"
+ },
+ "type": "library",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Arne Blankerts",
+ "email": "arne@blankerts.de",
+ "role": "Developer"
+ }
+ ],
+ "description": "A small library for converting tokenized PHP source code into XML and potentially other formats",
+ "support": {
+ "issues": "https://github.com/theseer/tokenizer/issues",
+ "source": "https://github.com/theseer/tokenizer/tree/1.3.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/theseer",
+ "type": "github"
+ }
+ ],
+ "time": "2025-11-17T20:03:58+00:00"
+ },
+ {
+ "name": "webmozart/assert",
+ "version": "2.1.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/webmozarts/assert.git",
+ "reference": "bdbabc199a7ba9965484e4725d66170e5711323b"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/webmozarts/assert/zipball/bdbabc199a7ba9965484e4725d66170e5711323b",
+ "reference": "bdbabc199a7ba9965484e4725d66170e5711323b",
+ "shasum": ""
+ },
+ "require": {
+ "ext-ctype": "*",
+ "ext-date": "*",
+ "ext-filter": "*",
+ "php": "^8.2"
+ },
+ "suggest": {
+ "ext-intl": "",
+ "ext-simplexml": "",
+ "ext-spl": ""
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-feature/2-0": "2.0-dev"
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Webmozart\\Assert\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Bernhard Schussek",
+ "email": "bschussek@gmail.com"
+ },
+ {
+ "name": "Woody Gilk",
+ "email": "woody.gilk@gmail.com"
+ }
+ ],
+ "description": "Assertions to validate method input/output with nice error messages.",
+ "keywords": [
+ "assert",
+ "check",
+ "validate"
+ ],
+ "support": {
+ "issues": "https://github.com/webmozarts/assert/issues",
+ "source": "https://github.com/webmozarts/assert/tree/2.1.1"
+ },
+ "time": "2026-01-08T11:28:40+00:00"
+ }
+ ],
+ "aliases": [],
+ "minimum-stability": "stable",
+ "stability-flags": {},
+ "prefer-stable": false,
+ "prefer-lowest": false,
+ "platform": {
+ "php": "^8.1"
+ },
+ "platform-dev": {},
+ "platform-overrides": {
+ "php": "8.3"
+ },
+ "plugin-api-version": "2.6.0"
}
diff --git a/phpstan.dist.neon b/phpstan.dist.neon
new file mode 100644
index 00000000..1cdf47d8
--- /dev/null
+++ b/phpstan.dist.neon
@@ -0,0 +1,14 @@
+parameters:
+ level: max
+ phpVersion:
+ min: 80100
+ max: 80499
+ paths:
+ - src
+ - tests
+ ignoreErrors:
+ - identifier: parameter.defaultValue
+ - identifier: trait.unused
+ - identifier: property.onlyWritten
+
+ reportUnmatchedIgnoredErrors: false
diff --git a/phpunit.xml.dist b/phpunit.xml.dist
index 00dd3c89..41860103 100644
--- a/phpunit.xml.dist
+++ b/phpunit.xml.dist
@@ -1,17 +1,18 @@
-
+
-
-
- src
-
-
-
-
- tests
-
-
+ cacheDirectory=".phpunit.cache"
+ colors="true"
+ xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+ xsi:noNamespaceSchemaLocation="vendor/phpunit/phpunit/phpunit.xsd"
+>
+
+
+ ./src
+
+
+
+
+ ./tests
+
+
diff --git a/release-please-config.json b/release-please-config.json
new file mode 100644
index 00000000..5bcdb2b2
--- /dev/null
+++ b/release-please-config.json
@@ -0,0 +1,67 @@
+{
+ "packages": {
+ ".": {}
+ },
+ "$schema": "https://raw.githubusercontent.com/googleapis/release-please/main/schemas/config.json",
+ "include-v-in-tag": true,
+ "include-component-in-tag": false,
+ "versioning": "prerelease",
+ "prerelease": false,
+ "bump-minor-pre-major": true,
+ "bump-patch-for-minor-pre-major": false,
+ "pull-request-header": "Automated Release PR",
+ "pull-request-title-pattern": "release: ${version}",
+ "changelog-sections": [
+ {
+ "type": "feat",
+ "section": "Features"
+ },
+ {
+ "type": "fix",
+ "section": "Bug Fixes"
+ },
+ {
+ "type": "perf",
+ "section": "Performance Improvements"
+ },
+ {
+ "type": "revert",
+ "section": "Reverts"
+ },
+ {
+ "type": "chore",
+ "section": "Chores"
+ },
+ {
+ "type": "docs",
+ "section": "Documentation"
+ },
+ {
+ "type": "style",
+ "section": "Styles"
+ },
+ {
+ "type": "refactor",
+ "section": "Refactors"
+ },
+ {
+ "type": "test",
+ "section": "Tests",
+ "hidden": true
+ },
+ {
+ "type": "build",
+ "section": "Build System"
+ },
+ {
+ "type": "ci",
+ "section": "Continuous Integration",
+ "hidden": true
+ }
+ ],
+ "release-type": "php",
+ "extra-files": [
+ "README.md",
+ "src/Version.php"
+ ]
+}
\ No newline at end of file
diff --git a/sample/README.md b/sample/README.md
deleted file mode 100644
index 2b83ab87..00000000
--- a/sample/README.md
+++ /dev/null
@@ -1,15 +0,0 @@
-# Running the sample application
-
-### Step 1
-Open `sample.php` and fill the account details:
-```php
-$public_key = 'your_public_key';
-$your_private_key = 'your_private_key';
-$url_end_point = 'https://ik.imagekit.io/demo';
-```
-
-### Step 2:
-Run the `sample.php` file.
-```bash
-php sample.php
-```
\ No newline at end of file
diff --git a/sample/file_management/index.php b/sample/file_management/index.php
deleted file mode 100644
index 2d8e3ada..00000000
--- a/sample/file_management/index.php
+++ /dev/null
@@ -1,319 +0,0 @@
-listFiles();
-
-echo "\n\n";
-echo "1. List All Files: \n";
-echo "\033[01;32m".print_r($listFiles,true)."\033[0m";
-echo "\n";
-
-$file_id = $listFiles->result[0]->fileId;
-$version_id = $listFiles->result[0]->versionInfo->id;
-$filePath = $listFiles->result[0]->filePath;
-$sourceFilePath = $listFiles->result[0]->filePath;
-
-// List Filtered Files
-
-$listFilteredFiles = $imageKit->listFiles([
- "type" => "file",
- "sort" => "ASC_CREATED",
- "path" => "/sample-folder",
- "fileType" => "all",
- "limit" => 10,
- "skip" => 0,
- "tags" => ["tag3","tag4"],
-]);
-
-echo "\n\n";
-echo "2. List Filtered Files: \n";
-echo "\033[01;32m".print_r($listFilteredFiles,true)."\033[0m";
-echo "\n";
-
-// Advance Search Filtered Files
-
-$advanceSearchFilteredFiles = $imageKit->listFiles([
- "searchQuery" => '(size < "50kb" AND width > 500) OR (tags IN ["summer-sale","banner"])',
-]);
-
-echo "\n\n";
-echo "3. Advance Search Filtered Files: \n";
-echo "\033[01;32m".print_r($advanceSearchFilteredFiles,true)."\033[0m";
-echo "\n";
-
-// Get File Details
-$getFileDetails = $imageKit->getFileDetails($file_id);
-
-echo "\n\n";
-echo "4. Get File Details: \n";
-echo "\033[01;32m".print_r($getFileDetails,true)."\033[0m";
-echo "\n";
-
-// Get File Version Details
-$getFileVersionDetails = $imageKit->getFileVersionDetails($file_id,$version_id);
-
-echo "\n\n";
-echo "5. Get File Version Details: \n";
-echo "\033[01;32m".print_r($getFileVersionDetails,true)."\033[0m";
-echo "\n";
-
-// Get File Versions
-$getFileVersions = $imageKit->getFileVersions($file_id);
-
-
-echo "\n\n";
-echo "6. Get File Versions: \n";
-echo "\033[01;32m".print_r($getFileVersions,true)."\033[0m";
-echo "\n";
-
-// Update File Details
-$updateData = [
- "removeAITags" => "all", // "all" or ["tag1","tag2"]
- "webhookUrl" => "https://example.com/webhook",
- "tags" => ["tag3", "tag4"],
-];
-
-$updateFileDetails = $imageKit->updateFileDetails(
- $file_id,
- $updateData
-);
-
-echo "\n\n";
-echo "7. Update File Details: \n";
-echo "\033[01;32m".print_r($updateFileDetails,true)."\033[0m";
-echo "\n";
-
-// Add Tags (Bulk)
-$fileIds = [$file_id];
-$tags = ['image_tag_1', 'image_tag_2'];
-
-$bulkAddTags = $imageKit->bulkAddTags($fileIds, $tags);
-
-echo "\n\n";
-echo "8. Add Tags (Bulk): \n";
-echo "\033[01;32m".print_r($bulkAddTags,true)."\033[0m";
-echo "\n";
-
-// Remove Tags (Bulk)
-$fileIds = [$file_id];
-$tags = ['image_tag_1', 'image_tag_2'];
-
-$bulkRemoveTags = $imageKit->bulkRemoveTags($fileIds, $tags);
-
-echo "\n\n";
-echo "9. Remove Tags (Bulk): \n";
-echo "\033[01;32m".print_r($bulkRemoveTags,true)."\033[0m";
-echo "\n";
-
-// Remove AI Tags (Bulk)
-$fileIds = [$file_id];
-$AITags = ['image_AITag_1', 'image_AITag_2'];
-
-$bulkRemoveAITags = $imageKit->bulkRemoveAITags($fileIds, $AITags);
-
-echo "\n\n";
-echo "10. Remove AI Tags (Bulk): \n";
-echo "\033[01;32m".print_r($bulkRemoveAITags,true)."\033[0m";
-echo "\n";
-
-// Copy File
-
-$destinationPath = '/sample-folder2/';
-$copyFile = $imageKit->copy([
- 'sourceFilePath' => $sourceFilePath,
- 'destinationPath' => $destinationPath,
- 'includeFileVersions' => false
-]);
-
-echo "\n\n";
-echo "11. Copy File: \n";
-echo "\033[01;32m".print_r($copyFile,true)."\033[0m";
-echo "\n";
-
-// Move File
-
-$destinationPath = '/';
-$moveFile = $imageKit->move([
- 'sourceFilePath' => '/sample-folder2/default-image.jpg',
- 'destinationPath' => $destinationPath
-]);
-
-echo "\n\n";
-echo "12. Move File: \n";
-echo "\033[01;32m".print_r($moveFile,true)."\033[0m";
-echo "\n";
-
-// Rename File with purge cache false
-
-$newFileName = 'sample-file2.jpg';
-$renameFile = $imageKit->rename([
- 'filePath' => $filePath,
- 'newFileName' => $newFileName,
- 'purgeCache' => false
-]);
-
-echo "\n\n";
-echo "13. Rename File with Pruge Cache False: \n";
-echo "\033[01;32m".print_r($renameFile,true)."\033[0m";
-echo "\n";
-
-// Rename File with Purge Cache true
-
-$newFileName = 'sample-file3.jpg';
-$renameFile = $imageKit->renameFile([
- 'filePath' => $filePath,
- 'newFileName' => $newFileName,
-], true);
-
-echo "\n\n";
-echo "14. Rename File with Pruge Cache True: \n";
-echo "\033[01;32m".print_r($renameFile,true)."\033[0m";
-echo "\n";
-
-// Restore File Version
-
-$restoreFileVersion = $imageKit->restoreFileVersion([
- 'fileId' => $file_id,
- 'versionId' => $version_id,
-]);
-
-echo "\n\n";
-echo "15. Restore File Version: \n";
-echo "\033[01;32m".print_r($restoreFileVersion,true)."\033[0m";
-echo "\n";
-
-// Create Folder
-
-$folderName = 'new-folder';
-$parentFolderPath = '/';
-$createFolder = $imageKit->createFolder([
- 'folderName' => $folderName,
- 'parentFolderPath' => $parentFolderPath,
-]);
-
-echo "\n\n";
-echo "16. Create Folder: \n";
-echo "\033[01;32m".print_r($createFolder,true)."\033[0m";
-echo "\n";
-
-// Copy Folder
-
-$sourceFolderPath = $folderName;
-$destinationPath = '/sample-folder';
-$includeFileVersions = false;
-$copyFolder = $imageKit->copyFolder([
- 'sourceFolderPath' => $sourceFolderPath,
- 'destinationPath' => $destinationPath,
- 'includeFileVersions' => $includeFileVersions
-]);
-
-echo "\n\n";
-echo "17. Copy Folder: \n";
-echo "\033[01;32m".print_r($copyFolder,true)."\033[0m";
-echo "\n";
-
-// Move Folder
-
-$sourceFolderPath = $folderName;
-$destinationPath = '/sample-folder';
-$moveFolder = $imageKit->moveFolder([
- 'sourceFolderPath' => $sourceFolderPath,
- 'destinationPath' => $destinationPath
-]);
-
-$job_id = $moveFolder->result->jobId;
-
-echo "\n\n";
-echo "18. Move Folder: \n";
-echo "\033[01;32m".print_r($moveFolder,true)."\033[0m";
-echo "\n";
-
-
-// Delete Folder
-$folderPath = '/sample-folder/new-folder';
-$deleteFolder = $imageKit->deleteFolder($folderPath);
-
-echo "\n\n";
-echo "19. Delete Folder: \n";
-echo "\033[01;32m".print_r($deleteFolder,true)."\033[0m";
-echo "\n";
-
-// Bulk Job Status
-
-$bulkJobStatus = $imageKit->getBulkJobStatus($job_id);
-
-echo "\n\n";
-echo "20. Bulk Job Status: \n";
-echo "\033[01;32m".print_r($bulkJobStatus,true)."\033[0m";
-echo "\n";
-
-// Purge Cache
-
-$image_url = $url_end_point.'/sample-folder/default-image.jpg';
-$purgeCache = $imageKit->purgeCache($image_url);
-$cacheRequestId = $purgeCache->result->requestId;
-echo "\n\n";
-echo "21. Purge Cache: \n";
-echo "\033[01;32m".print_r($purgeCache,true)."\033[0m";
-echo "\n";
-
-// Purge Cache Status
-
-$getPurgeCacheStatus = $imageKit->getPurgeCacheStatus($cacheRequestId);
-
-echo "\n\n";
-echo "22. Purge Cache Status: \n";
-echo "\033[01;32m".print_r($getPurgeCacheStatus,true)."\033[0m";
-echo "\n";
-
-// Get File Metadata (From File ID)
-
-$getFileMetadata = $imageKit->getFileMetaData($file_id);
-
-echo "\n\n";
-echo "23. Get File Metadata (From File ID): \n";
-echo "\033[01;32m".print_r($getFileMetadata,true)."\033[0m";
-echo "\n";
-
-// Get File Metadata (From Remote URL)
-
-$getFileMetadata = $imageKit->getFileMetadataFromRemoteURL($image_url);
-
-echo "\n\n";
-echo "24. Get File Metadata (From Remote URL): \n";
-echo "\033[01;32m".print_r($getFileMetadata,true)."\033[0m";
-echo "\n";
-
-// Delete File Version
-
-$deleteFileVersion = $imageKit->deleteFileVersion($file_id, $version_id);
-
-echo "\n\n";
-echo "25. Delete File Version: \n";
-echo "\033[01;32m".print_r($deleteFileVersion,true)."\033[0m";
-echo "\n";
-
-// Delete File
-
-$deleteFile = $imageKit->deleteFile($file_id);
-
-echo "\n\n";
-echo "26. Delete File: \n";
-echo "\033[01;32m".print_r($deleteFile,true)."\033[0m";
-echo "\n";
-
-// Delete Files (Bulk)
-
-$fileIds = [$file_id];
-$deleteFiles = $imageKit->bulkDeleteFiles($fileIds);
-
-echo "\n\n";
-echo "27. Delete Files (Bulk): \n";
-echo "\033[01;32m".print_r($deleteFiles,true)."\033[0m";
-echo "\n";
diff --git a/sample/metadata/index.php b/sample/metadata/index.php
deleted file mode 100644
index 4c2fbed3..00000000
--- a/sample/metadata/index.php
+++ /dev/null
@@ -1,62 +0,0 @@
- "net_price", // required
- "label" => "Net Price", // required
- "schema" => [ // required
- "type" => 'Number', // required
- "minValue" => 1000,
- "maxValue" => 5000,
- ],
-];
-
-$createCustomMetadataField = $imageKit->createCustomMetadataField($body);
-
-echo "\n\n";
-echo "1. Create Fields: \n";
-echo "\033[01;32m".print_r($createCustomMetadataField,true)."\033[0m";
-echo "\n";
-
-// Get Fields
-
-$includeDeleted = false;
-$getCustomMetadataFields = $imageKit->getCustomMetadataFields($includeDeleted);
-$customMetadataFieldId = $getCustomMetadataFields->result[0]->id;
-
-echo "\n\n";
-echo "2. Get Fields: \n";
-echo "\033[01;32m".print_r($getCustomMetadataFields,true)."\033[0m";
-echo "\n";
-
-// Update Field
-
-$body = [
- "label" => "Net Price2",
- "schema" => [
- "type"=>'Number'
- ],
-];
-
-$updateCustomMetadataField = $imageKit->updateCustomMetadataField($customMetadataFieldId, $body);
-
-echo "\n\n";
-echo "3. Update Field: \n";
-echo "\033[01;32m".print_r($updateCustomMetadataField,true)."\033[0m";
-echo "\n";
-
-// Delete Field
-
-$deleteCustomMetadataField = $imageKit->deleteCustomMetadataField($customMetadataFieldId);
-
-echo "\n\n";
-echo "4. Delete Field: \n";
-echo "\033[01;32m".print_r($deleteCustomMetadataField,true)."\033[0m";
-echo "\n";
-
diff --git a/sample/sample.php b/sample/sample.php
deleted file mode 100644
index ac3cc383..00000000
--- a/sample/sample.php
+++ /dev/null
@@ -1,31 +0,0 @@
-uploadFile([
- 'file' => $encodedImageData,
- 'fileName' => 'sample-base64-upload',
- 'folder' => 'sample-folder',
- 'tags' => implode(['abd', 'def']),
- 'useUniqueFileName' => false,
- 'customCoordinates' => implode(',', ['10', '10', '100', '100']),
- 'transformation' => [
- 'pre' => 'l-text,i-Imagekit,fs-50,l-end',
- 'post' => [
- [
- 'type' => 'transformation',
- 'value' => 'h-100'
- ]
- ]
- ],
-]);
-
-echo "\n\n";
-echo "1. Upload Image (Base64) - Response: \n";
-echo "\033[01;32m".print_r($uploadFile, true)."\033[0m";
-echo "\n";
-
-// Upload Image - Binary
-
-$uploadFile = $imageKit->uploadFile([
- 'file' => fopen(__DIR__ . '/sample_image.jpeg', 'r'),
- 'fileName' => 'sample-binary-upload',
- 'folder' => 'sample-folder',
- 'tags' => implode(['abd', 'def']),
- 'useUniqueFileName' => true,
- 'customCoordinates' => implode(',', ['10', '10', '100', '100']),
- 'transformation' => [
- 'pre' => 'l-text,i-Imagekit,fs-50,l-end',
- 'post' => [
- [
- 'type' => 'transformation',
- 'value' => 'h-100'
- ]
- ]
- ],
-]);
-
-echo "\n\n";
-echo "2. Upload Image (Binary) - Response: \n";
-echo "\033[01;32m".print_r($uploadFile, true)."\033[0m";
-echo "\n";
-
-
-// Upload Image - URL
-
-$uploadFile = $imageKit->uploadFile([
- 'file' => $sample_file_url,
- 'fileName' => 'sample-url-upload',
- 'folder' => 'sample-folder',
- 'tags' => implode(['abd', 'def']),
- 'useUniqueFileName' => true,
- 'customCoordinates' => implode(',', ['10', '10', '100', '100']),
- 'transformation' => [
- 'pre' => 'l-text,i-Imagekit,fs-50,l-end',
- 'post' => [
- [
- 'type' => 'transformation',
- 'value' => 'h-100'
- ]
- ]
- ],
-]);
-
-echo "\n\n";
-echo "3. Upload Image (URL) - Response: \n";
-echo "\033[01;32m".print_r($uploadFile, true)."\033[0m";
-echo "\n";
diff --git a/sample/upload_api/sample_image.jpeg b/sample/upload_api/sample_image.jpeg
deleted file mode 100644
index 44283cdf..00000000
Binary files a/sample/upload_api/sample_image.jpeg and /dev/null differ
diff --git a/sample/url_generation/chained_transformations.php b/sample/url_generation/chained_transformations.php
deleted file mode 100644
index 6b3bd330..00000000
--- a/sample/url_generation/chained_transformations.php
+++ /dev/null
@@ -1,54 +0,0 @@
-url(
- [
- 'path' => '/default-image.jpg',
-
- // It means first resize the image to 400x300 and then rotate 90 degrees
- 'transformation' => [
- [
- 'width' => '400',
- 'height' => '300',
- ],
- [
- 'rotation' => '90'
- ]
- ],
- ]
-);
-
-echo "\n\n";
-echo "1. Resized then rotated Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Rotate then Resize
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
-
- // It means first rotate the image to 90 degress and then resize it to 400x300
- 'transformation' => [
- [
- 'rotation' => '90'
- ],
- [
- 'width' => '400',
- 'height' => '300',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "2. Retotated then resized Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
diff --git a/sample/url_generation/image_enhancement_and_color_manipulation.php b/sample/url_generation/image_enhancement_and_color_manipulation.php
deleted file mode 100644
index dc83b116..00000000
--- a/sample/url_generation/image_enhancement_and_color_manipulation.php
+++ /dev/null
@@ -1,105 +0,0 @@
-url(
- [
- 'src' => 'https://ik.imagekit.io/demo/sample_image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'effectContrast' => '',
- ]
- ],
- ]
-);
-
-echo "\n\n";
-echo "1. Contrast stretch Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Sharpen (e-sharpen)
-// https://docs.imagekit.io/features/image-transformations/image-enhancement-and-color-manipulation#sharpen-e-sharpen
-
-$imageURL = $imageKit->url(
- [
- 'src' => 'https://ik.imagekit.io/demo/sample_image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'effectSharpen' => '10',
- ]
- ],
- ]
-);
-
-echo "\n\n";
-echo "2. Sharpen Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Unsharp mask (e-usm)
-// https://docs.imagekit.io/features/image-transformations/image-enhancement-and-color-manipulation#unsharp-mask-e-usm
-
-$imageURL = $imageKit->url(
- [
- 'src' => 'https://ik.imagekit.io/demo/sample_image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'effectUSM' => '2-2-0.8-0.024', // radius=2, sigma=2, amount=0.8, threshold=0.024
- ]
- ],
- ]
-);
-
-echo "\n\n";
-echo "3. Unsharp mask Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Shadow (e-shadow)
-// https://docs.imagekit.io/features/image-transformations/image-enhancement-and-color-manipulation#shadow-e-shadow
-
-$imageURL = $imageKit->url(
- [
- 'src' => 'https://ik.imagekit.io/demo/sample_image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'effectShadow' => 'bl-15_st-40_x-10_y-N5'
- ]
- ],
- ]
-);
-
-echo "\n\n";
-echo "4. Shadow image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Gradient (e-gradient)
-// https://docs.imagekit.io/features/image-transformations/image-enhancement-and-color-manipulation#gradient-e-gradient
-
-$imageURL = $imageKit->url(
- [
- 'src' => 'https://ik.imagekit.io/demo/sample_image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'effectGradient' => 'from-red_to-white',
- ]
- ],
- ]
-);
-
-echo "\n\n";
-echo "5. Gradient image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
\ No newline at end of file
diff --git a/sample/url_generation/index.php b/sample/url_generation/index.php
deleted file mode 100644
index bf586543..00000000
--- a/sample/url_generation/index.php
+++ /dev/null
@@ -1,11 +0,0 @@
-url(
- [
- 'path' => '/default-image.jpg',
- ]
-);
-
-echo "\n\n";
-echo "1. URL for Image with relative path: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// URL for Image with relative path and custom URL Endpoint
-
-$imageURL = $imageKit->url(
- [
- 'urlEndpoint' => $url_end_point . '/sample-folder',
- 'path' => '/default-image.jpg',
- ]
-);
-
-
-echo "\n\n";
-echo "2. URL for Image with relative path and Custom URL Endpoint: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// URL for Image with absolute url
-
-$imageURL = $imageKit->url(
- [
- 'src' => 'https://ik.imagekit.io/test/default-image.jpg'
- ]
-);
-
-echo "\n\n";
-echo "3. URL for Image with Absolute URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Resizing Images
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "4. Resized Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Pad resize crop strategy (cm-pad_resize)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#pad-resize-crop-strategy-cm-pad_resize
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- 'cropMode' => 'pad_resize',
- 'background' => 'F3F3F3'
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "5. Pad Resize Crop Strategy Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Pad resize crop strategy with Focus (fo)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#pad-resize-crop-strategy-cm-pad_resize
-// More on 'fo' - https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#focus-fo
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- 'cropMode' => 'pad_resize',
- 'background' => 'D3D3D3',
- 'focus' => 'left',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "6. Pad Resize Crop Strategy with Focus-Left Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Forced crop strategy (c-force)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#forced-crop-strategy-c-force
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- 'crop' => 'force',
- 'background' => 'F3F3F3',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "7. Forced Crop Strategy Strategy Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Max-size cropping strategy (c-at_max)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#max-size-cropping-strategy-c-at_max
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- 'crop' => 'at_max',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "8. Max-size cropping strategy Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Min-size cropping strategy (c-at_least)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#min-size-cropping-strategy-c-at_least
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- 'crop' => 'at_least',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "9. Min-size cropping strategy Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Maintain ratio crop strategy c-maintain_ratio (center-top)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#maintain-ratio-crop-strategy-c-maintain_ratio
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- 'crop' => 'maintain_ratio',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "10. Maintain ratio cropping strategy (center-top) Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Maintain ratio crop strategy with fo-custom
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#maintain-ratio-crop-strategy-c-maintain_ratio
-
-$imageURL = $imageKit->url(
- [
- 'src' => 'https://ik.imagekit.io/demo/img/bike-image.jpeg',
- 'transformation' => [
- [
- 'height' => '300',
- 'width' => '400',
- 'focus' => 'custom',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "11. Maintain ratio cropping strategy with fo-custom Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Extract crop strategy cm-extract (default center extract)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#extract-crop-strategy-cm-extract
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'width' => '200',
- 'height' => '200',
- 'cropMode' => 'extract',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "12. Extract crop strategy (default center extract) Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Extract crop strategy cm-extract (relative focus)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#extract-crop-strategy-cm-extract
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'width' => '200',
- 'height' => '200',
- 'cropMode' => 'extract',
- 'focus' => 'bottom_right',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "13. Extract crop strategy (relative focus) Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Extract crop strategy cm-extract (focus with x,y coordinates)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#examples-focus-using-cropped-image-coordinates
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'width' => '200',
- 'height' => '200',
- 'cropMode' => 'extract',
- 'x' => '100',
- 'y' => '300',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "14. Extract crop strategy (Focus with X,Y Coordinates) Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Extract crop strategy cm-extract (focus using xc,yc center coordinates)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#examples-focus-using-cropped-image-coordinates
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'width' => '200',
- 'height' => '200',
- 'cropMode' => 'extract',
- 'xc' => '100',
- 'yc' => '300',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "15. Extract crop strategy (Focus using center Coordinates XC, YC) Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Extract crop strategy cm-extract (focus with custom coordinates)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#example-focus-using-custom-coordinates
-
-$imageURL = $imageKit->url(
- [
- 'src' => 'https://ik.imagekit.io/demo/img/bike-image.jpeg',
- 'transformation' => [
- [
- 'width' => '200',
- 'height' => '200',
- 'cropMode' => 'extract',
- 'focus' => 'custom'
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "16. Extract crop strategy (Focus using custom coordinates) Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Pad extract crop strategy (cm-pad_extract)
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#pad-extract-crop-strategy-cm-pad_extract
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'width' => '200',
- 'height' => '200',
- 'cropMode' => 'pad_extract',
- 'background' => 'F3F3F3',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "17. Pad extract crop strategy Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Quality manipulation
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'quality' => '40',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "18. Quality Manipulated Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Blur Image
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'blur' => '40', // 1-100
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "19. Blur Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Grayscale Image (e-grayscale)
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'effectGray' => '',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "20. Grayscale Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Trim edges
-
-$imageURL = $imageKit->url(
- [
- 'src' => 'https://ik.imagekit.io/demo/img/trim_example_BkgQVu7oX.png',
- 'transformation' => [
- [
- 'trim' => 'true', // true|Number
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "21. Trim edges Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-
-// Bordered Image
-// https://docs.imagekit.io/features/image-transformations/resize-crop-and-other-transformations#border-b
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'border' => '10_FF0000', // width_hexcolor
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "22. Bordered Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Rotate Image
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'rotate' => '180', // degrees
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "23. Rotated Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Radius
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- // 'radius' => '100',
- 'radius' => 'max',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "24. Radius Applied Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Background color
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'width' => '1200',
- 'height' => '1200',
- 'cropMode' => 'pad_extract',
- 'background' => '272B38',
- ],
- ],
- ]
-);
-
-echo "\n\n";
-echo "25. Background color Applied Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
-
-// Download Image
-
-$imageURL = $imageKit->url(
- [
- 'path' => '/default-image.jpg',
- 'transformation' => [
- [
- 'width' => '1200',
- 'height' => '1200',
- 'cropMode' => 'pad_extract',
- 'background' => '272B38',
- ],
- ],
- 'queryParameters' => [
- 'ik-attachment' => 'true'
- ]
- ]
-);
-
-echo "\n\n";
-echo "26. Download Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
diff --git a/sample/url_generation/signed_url.php b/sample/url_generation/signed_url.php
deleted file mode 100644
index 896ebf45..00000000
--- a/sample/url_generation/signed_url.php
+++ /dev/null
@@ -1,27 +0,0 @@
-url([
- "path" => "/default-image.jpg",
- "queryParameters" =>
- [
- "v" => "123"
- ],
- "transformation" => [
- [
- "height" => "300",
- "width" => "400"
- ]
- ],
- "signed" => true,
- "expireSeconds" => 300, // 300 seconds
-]);
-
-echo "\n\n";
-echo "Singed Image URL: \n";
-echo "\033[01;32m$imageURL\033[0m";
-echo "\n";
diff --git a/sample/utility/index.php b/sample/utility/index.php
deleted file mode 100644
index bbd8cea6..00000000
--- a/sample/utility/index.php
+++ /dev/null
@@ -1,26 +0,0 @@
-getAuthenticationParameters($token = "", $expire = 0);
-
-echo "\n\n";
-echo "1. Authentication parameter generation: \n";
-echo "\033[01;32m".print_r($authenticationParameters,true)."\033[0m";
-echo "\n";
-
-// Distance calculation between two pHash values
-$firstHash='f06830ca9f1e3e90';
-$secondHash='f06830ca9f1e3e90';
-$pHashDistance = $imageKit->pHashDistance($firstHash ,$secondHash);
-
-echo "\n\n";
-echo "2. Distance calculation between two pHash values: \n";
-echo "\033[01;32m".print_r($pHashDistance,true)."\033[0m";
-echo "\n";
-
diff --git a/scripts/bootstrap b/scripts/bootstrap
new file mode 100755
index 00000000..0010226e
--- /dev/null
+++ b/scripts/bootstrap
@@ -0,0 +1,8 @@
+#!/usr/bin/env bash
+
+set -e
+
+cd -- "$(dirname -- "$0")/.."
+
+echo "==> Running composer install"
+exec -- composer install --no-interaction
diff --git a/scripts/clean b/scripts/clean
new file mode 100755
index 00000000..5d9a765b
--- /dev/null
+++ b/scripts/clean
@@ -0,0 +1,8 @@
+#!/usr/bin/env bash
+
+set -e
+
+cd -- "$(dirname -- "$0")/.."
+
+echo "==> Cleaning up..."
+exec -- rm -fr -- ./vendor/ ./.php-cs-fixer.cache
diff --git a/scripts/format b/scripts/format
new file mode 100755
index 00000000..8e633516
--- /dev/null
+++ b/scripts/format
@@ -0,0 +1,8 @@
+#!/usr/bin/env bash
+
+set -e
+
+cd -- "$(dirname -- "$0")/.."
+
+echo "==> Running php-cs-fixer"
+exec -- ./vendor/bin/php-cs-fixer fix
diff --git a/scripts/lint b/scripts/lint
new file mode 100755
index 00000000..211ce906
--- /dev/null
+++ b/scripts/lint
@@ -0,0 +1,8 @@
+#!/usr/bin/env bash
+
+set -e
+
+cd -- "$(dirname -- "$0")/.."
+
+echo "==> Running PHPStan"
+exec -- ./vendor/bin/phpstan analyse --memory-limit=12G
diff --git a/scripts/test b/scripts/test
new file mode 100755
index 00000000..63df1370
--- /dev/null
+++ b/scripts/test
@@ -0,0 +1,9 @@
+#!/usr/bin/env bash
+
+set -e
+
+cd "$(dirname "$0")/.."
+
+
+
+exec -- ./vendor/bin/pest --colors=always
diff --git a/src/Accounts/Origins/OriginCreateParams.php b/src/Accounts/Origins/OriginCreateParams.php
new file mode 100644
index 00000000..d36feb97
--- /dev/null
+++ b/src/Accounts/Origins/OriginCreateParams.php
@@ -0,0 +1,468 @@
+ */
+ use SdkModel;
+ use SdkParams;
+
+ /** @var 'AKENEO_PIM' $type */
+ #[Required]
+ public string $type = 'AKENEO_PIM';
+
+ /**
+ * Access key for the bucket.
+ */
+ #[Required]
+ public string $accessKey;
+
+ #[Required]
+ public string $bucket;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * Secret key for the bucket.
+ */
+ #[Required]
+ public string $secretKey;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Optional]
+ public ?bool $includeCanonicalHeader;
+
+ #[Optional]
+ public ?string $prefix;
+
+ /**
+ * Custom S3-compatible endpoint.
+ */
+ #[Required]
+ public string $endpoint;
+
+ /**
+ * Use path-style S3 URLs?
+ */
+ #[Optional]
+ public ?bool $s3ForcePathStyle;
+
+ /**
+ * Akeneo instance base URL.
+ */
+ #[Required('baseUrl')]
+ public string $baseURL;
+
+ /**
+ * Forward the Host header to origin?
+ */
+ #[Optional]
+ public ?bool $forwardHostHeaderToOrigin;
+
+ #[Required]
+ public string $clientEmail;
+
+ #[Required]
+ public string $privateKey;
+
+ #[Required]
+ public string $accountName;
+
+ #[Required]
+ public string $container;
+
+ #[Required]
+ public string $sasToken;
+
+ /**
+ * Akeneo API client ID.
+ */
+ #[Required('clientId')]
+ public string $clientID;
+
+ /**
+ * Akeneo API client secret.
+ */
+ #[Required]
+ public string $clientSecret;
+
+ /**
+ * Akeneo API password.
+ */
+ #[Required]
+ public string $password;
+
+ /**
+ * Akeneo API username.
+ */
+ #[Required]
+ public string $username;
+
+ /**
+ * `new OriginCreateParams()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * OriginCreateParams::with(
+ * accessKey: ...,
+ * bucket: ...,
+ * name: ...,
+ * secretKey: ...,
+ * endpoint: ...,
+ * baseURL: ...,
+ * clientEmail: ...,
+ * privateKey: ...,
+ * accountName: ...,
+ * container: ...,
+ * sasToken: ...,
+ * clientID: ...,
+ * clientSecret: ...,
+ * password: ...,
+ * username: ...,
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new OriginCreateParams)
+ * ->withAccessKey(...)
+ * ->withBucket(...)
+ * ->withName(...)
+ * ->withSecretKey(...)
+ * ->withEndpoint(...)
+ * ->withBaseURL(...)
+ * ->withClientEmail(...)
+ * ->withPrivateKey(...)
+ * ->withAccountName(...)
+ * ->withContainer(...)
+ * ->withSasToken(...)
+ * ->withClientID(...)
+ * ->withClientSecret(...)
+ * ->withPassword(...)
+ * ->withUsername(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $accessKey,
+ string $bucket,
+ string $name,
+ string $secretKey,
+ string $endpoint,
+ string $baseURL,
+ string $clientEmail,
+ string $privateKey,
+ string $accountName,
+ string $container,
+ string $sasToken,
+ string $clientID,
+ string $clientSecret,
+ string $password,
+ string $username,
+ ?string $baseURLForCanonicalHeader = null,
+ ?bool $includeCanonicalHeader = null,
+ ?string $prefix = null,
+ ?bool $s3ForcePathStyle = null,
+ ?bool $forwardHostHeaderToOrigin = null,
+ ): self {
+ $self = new self;
+
+ $self['accessKey'] = $accessKey;
+ $self['bucket'] = $bucket;
+ $self['name'] = $name;
+ $self['secretKey'] = $secretKey;
+ $self['endpoint'] = $endpoint;
+ $self['baseURL'] = $baseURL;
+ $self['clientEmail'] = $clientEmail;
+ $self['privateKey'] = $privateKey;
+ $self['accountName'] = $accountName;
+ $self['container'] = $container;
+ $self['sasToken'] = $sasToken;
+ $self['clientID'] = $clientID;
+ $self['clientSecret'] = $clientSecret;
+ $self['password'] = $password;
+ $self['username'] = $username;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+ null !== $includeCanonicalHeader && $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ null !== $prefix && $self['prefix'] = $prefix;
+ null !== $s3ForcePathStyle && $self['s3ForcePathStyle'] = $s3ForcePathStyle;
+ null !== $forwardHostHeaderToOrigin && $self['forwardHostHeaderToOrigin'] = $forwardHostHeaderToOrigin;
+
+ return $self;
+ }
+
+ /**
+ * @param 'AKENEO_PIM' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * Access key for the bucket.
+ */
+ public function withAccessKey(string $accessKey): self
+ {
+ $self = clone $this;
+ $self['accessKey'] = $accessKey;
+
+ return $self;
+ }
+
+ public function withBucket(string $bucket): self
+ {
+ $self = clone $this;
+ $self['bucket'] = $bucket;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Secret key for the bucket.
+ */
+ public function withSecretKey(string $secretKey): self
+ {
+ $self = clone $this;
+ $self['secretKey'] = $secretKey;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ /**
+ * Custom S3-compatible endpoint.
+ */
+ public function withEndpoint(string $endpoint): self
+ {
+ $self = clone $this;
+ $self['endpoint'] = $endpoint;
+
+ return $self;
+ }
+
+ /**
+ * Use path-style S3 URLs?
+ */
+ public function withS3ForcePathStyle(bool $s3ForcePathStyle): self
+ {
+ $self = clone $this;
+ $self['s3ForcePathStyle'] = $s3ForcePathStyle;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo instance base URL.
+ */
+ public function withBaseURL(string $baseURL): self
+ {
+ $self = clone $this;
+ $self['baseURL'] = $baseURL;
+
+ return $self;
+ }
+
+ /**
+ * Forward the Host header to origin?
+ */
+ public function withForwardHostHeaderToOrigin(
+ bool $forwardHostHeaderToOrigin
+ ): self {
+ $self = clone $this;
+ $self['forwardHostHeaderToOrigin'] = $forwardHostHeaderToOrigin;
+
+ return $self;
+ }
+
+ public function withClientEmail(string $clientEmail): self
+ {
+ $self = clone $this;
+ $self['clientEmail'] = $clientEmail;
+
+ return $self;
+ }
+
+ public function withPrivateKey(string $privateKey): self
+ {
+ $self = clone $this;
+ $self['privateKey'] = $privateKey;
+
+ return $self;
+ }
+
+ public function withAccountName(string $accountName): self
+ {
+ $self = clone $this;
+ $self['accountName'] = $accountName;
+
+ return $self;
+ }
+
+ public function withContainer(string $container): self
+ {
+ $self = clone $this;
+ $self['container'] = $container;
+
+ return $self;
+ }
+
+ public function withSasToken(string $sasToken): self
+ {
+ $self = clone $this;
+ $self['sasToken'] = $sasToken;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API client ID.
+ */
+ public function withClientID(string $clientID): self
+ {
+ $self = clone $this;
+ $self['clientID'] = $clientID;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API client secret.
+ */
+ public function withClientSecret(string $clientSecret): self
+ {
+ $self = clone $this;
+ $self['clientSecret'] = $clientSecret;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API password.
+ */
+ public function withPassword(string $password): self
+ {
+ $self = clone $this;
+ $self['password'] = $password;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API username.
+ */
+ public function withUsername(string $username): self
+ {
+ $self = clone $this;
+ $self['username'] = $username;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginRequest.php b/src/Accounts/Origins/OriginRequest.php
new file mode 100644
index 00000000..08918583
--- /dev/null
+++ b/src/Accounts/Origins/OriginRequest.php
@@ -0,0 +1,59 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return [
+ 'S3' => S3::class,
+ 'S3_COMPATIBLE' => S3Compatible::class,
+ 'CLOUDINARY_BACKUP' => CloudinaryBackup::class,
+ 'WEB_FOLDER' => WebFolder::class,
+ 'WEB_PROXY' => WebProxy::class,
+ 'GCS' => GoogleCloudStorageGcs::class,
+ 'AZURE_BLOB' => AzureBlobStorage::class,
+ 'AKENEO_PIM' => AkeneoPim::class,
+ ];
+ }
+}
diff --git a/src/Accounts/Origins/OriginRequest/AkeneoPim.php b/src/Accounts/Origins/OriginRequest/AkeneoPim.php
new file mode 100644
index 00000000..11da7ced
--- /dev/null
+++ b/src/Accounts/Origins/OriginRequest/AkeneoPim.php
@@ -0,0 +1,244 @@
+ */
+ use SdkModel;
+
+ /** @var 'AKENEO_PIM' $type */
+ #[Required]
+ public string $type = 'AKENEO_PIM';
+
+ /**
+ * Akeneo instance base URL.
+ */
+ #[Required('baseUrl')]
+ public string $baseURL;
+
+ /**
+ * Akeneo API client ID.
+ */
+ #[Required('clientId')]
+ public string $clientID;
+
+ /**
+ * Akeneo API client secret.
+ */
+ #[Required]
+ public string $clientSecret;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * Akeneo API password.
+ */
+ #[Required]
+ public string $password;
+
+ /**
+ * Akeneo API username.
+ */
+ #[Required]
+ public string $username;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Optional]
+ public ?bool $includeCanonicalHeader;
+
+ /**
+ * `new AkeneoPim()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * AkeneoPim::with(
+ * baseURL: ...,
+ * clientID: ...,
+ * clientSecret: ...,
+ * name: ...,
+ * password: ...,
+ * username: ...,
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new AkeneoPim)
+ * ->withBaseURL(...)
+ * ->withClientID(...)
+ * ->withClientSecret(...)
+ * ->withName(...)
+ * ->withPassword(...)
+ * ->withUsername(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $baseURL,
+ string $clientID,
+ string $clientSecret,
+ string $name,
+ string $password,
+ string $username,
+ ?string $baseURLForCanonicalHeader = null,
+ ?bool $includeCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['baseURL'] = $baseURL;
+ $self['clientID'] = $clientID;
+ $self['clientSecret'] = $clientSecret;
+ $self['name'] = $name;
+ $self['password'] = $password;
+ $self['username'] = $username;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+ null !== $includeCanonicalHeader && $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo instance base URL.
+ */
+ public function withBaseURL(string $baseURL): self
+ {
+ $self = clone $this;
+ $self['baseURL'] = $baseURL;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API client ID.
+ */
+ public function withClientID(string $clientID): self
+ {
+ $self = clone $this;
+ $self['clientID'] = $clientID;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API client secret.
+ */
+ public function withClientSecret(string $clientSecret): self
+ {
+ $self = clone $this;
+ $self['clientSecret'] = $clientSecret;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API password.
+ */
+ public function withPassword(string $password): self
+ {
+ $self = clone $this;
+ $self['password'] = $password;
+
+ return $self;
+ }
+
+ /**
+ * @param 'AKENEO_PIM' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API username.
+ */
+ public function withUsername(string $username): self
+ {
+ $self = clone $this;
+ $self['username'] = $username;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginRequest/AzureBlobStorage.php b/src/Accounts/Origins/OriginRequest/AzureBlobStorage.php
new file mode 100644
index 00000000..3b42220b
--- /dev/null
+++ b/src/Accounts/Origins/OriginRequest/AzureBlobStorage.php
@@ -0,0 +1,193 @@
+ */
+ use SdkModel;
+
+ /** @var 'AZURE_BLOB' $type */
+ #[Required]
+ public string $type = 'AZURE_BLOB';
+
+ #[Required]
+ public string $accountName;
+
+ #[Required]
+ public string $container;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ #[Required]
+ public string $sasToken;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Optional]
+ public ?bool $includeCanonicalHeader;
+
+ #[Optional]
+ public ?string $prefix;
+
+ /**
+ * `new AzureBlobStorage()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * AzureBlobStorage::with(
+ * accountName: ..., container: ..., name: ..., sasToken: ...
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new AzureBlobStorage)
+ * ->withAccountName(...)
+ * ->withContainer(...)
+ * ->withName(...)
+ * ->withSasToken(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $accountName,
+ string $container,
+ string $name,
+ string $sasToken,
+ ?string $baseURLForCanonicalHeader = null,
+ ?bool $includeCanonicalHeader = null,
+ ?string $prefix = null,
+ ): self {
+ $self = new self;
+
+ $self['accountName'] = $accountName;
+ $self['container'] = $container;
+ $self['name'] = $name;
+ $self['sasToken'] = $sasToken;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+ null !== $includeCanonicalHeader && $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ null !== $prefix && $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ public function withAccountName(string $accountName): self
+ {
+ $self = clone $this;
+ $self['accountName'] = $accountName;
+
+ return $self;
+ }
+
+ public function withContainer(string $container): self
+ {
+ $self = clone $this;
+ $self['container'] = $container;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ public function withSasToken(string $sasToken): self
+ {
+ $self = clone $this;
+ $self['sasToken'] = $sasToken;
+
+ return $self;
+ }
+
+ /**
+ * @param 'AZURE_BLOB' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginRequest/CloudinaryBackup.php b/src/Accounts/Origins/OriginRequest/CloudinaryBackup.php
new file mode 100644
index 00000000..da0561fc
--- /dev/null
+++ b/src/Accounts/Origins/OriginRequest/CloudinaryBackup.php
@@ -0,0 +1,215 @@
+ */
+ use SdkModel;
+
+ /** @var 'CLOUDINARY_BACKUP' $type */
+ #[Required]
+ public string $type = 'CLOUDINARY_BACKUP';
+
+ /**
+ * Access key for the bucket.
+ */
+ #[Required]
+ public string $accessKey;
+
+ /**
+ * S3 bucket name.
+ */
+ #[Required]
+ public string $bucket;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * Secret key for the bucket.
+ */
+ #[Required]
+ public string $secretKey;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Optional]
+ public ?bool $includeCanonicalHeader;
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ #[Optional]
+ public ?string $prefix;
+
+ /**
+ * `new CloudinaryBackup()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * CloudinaryBackup::with(accessKey: ..., bucket: ..., name: ..., secretKey: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new CloudinaryBackup)
+ * ->withAccessKey(...)
+ * ->withBucket(...)
+ * ->withName(...)
+ * ->withSecretKey(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $accessKey,
+ string $bucket,
+ string $name,
+ string $secretKey,
+ ?string $baseURLForCanonicalHeader = null,
+ ?bool $includeCanonicalHeader = null,
+ ?string $prefix = null,
+ ): self {
+ $self = new self;
+
+ $self['accessKey'] = $accessKey;
+ $self['bucket'] = $bucket;
+ $self['name'] = $name;
+ $self['secretKey'] = $secretKey;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+ null !== $includeCanonicalHeader && $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ null !== $prefix && $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ /**
+ * Access key for the bucket.
+ */
+ public function withAccessKey(string $accessKey): self
+ {
+ $self = clone $this;
+ $self['accessKey'] = $accessKey;
+
+ return $self;
+ }
+
+ /**
+ * S3 bucket name.
+ */
+ public function withBucket(string $bucket): self
+ {
+ $self = clone $this;
+ $self['bucket'] = $bucket;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Secret key for the bucket.
+ */
+ public function withSecretKey(string $secretKey): self
+ {
+ $self = clone $this;
+ $self['secretKey'] = $secretKey;
+
+ return $self;
+ }
+
+ /**
+ * @param 'CLOUDINARY_BACKUP' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginRequest/GoogleCloudStorageGcs.php b/src/Accounts/Origins/OriginRequest/GoogleCloudStorageGcs.php
new file mode 100644
index 00000000..e867b814
--- /dev/null
+++ b/src/Accounts/Origins/OriginRequest/GoogleCloudStorageGcs.php
@@ -0,0 +1,193 @@
+ */
+ use SdkModel;
+
+ /** @var 'GCS' $type */
+ #[Required]
+ public string $type = 'GCS';
+
+ #[Required]
+ public string $bucket;
+
+ #[Required]
+ public string $clientEmail;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ #[Required]
+ public string $privateKey;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Optional]
+ public ?bool $includeCanonicalHeader;
+
+ #[Optional]
+ public ?string $prefix;
+
+ /**
+ * `new GoogleCloudStorageGcs()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * GoogleCloudStorageGcs::with(
+ * bucket: ..., clientEmail: ..., name: ..., privateKey: ...
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new GoogleCloudStorageGcs)
+ * ->withBucket(...)
+ * ->withClientEmail(...)
+ * ->withName(...)
+ * ->withPrivateKey(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $bucket,
+ string $clientEmail,
+ string $name,
+ string $privateKey,
+ ?string $baseURLForCanonicalHeader = null,
+ ?bool $includeCanonicalHeader = null,
+ ?string $prefix = null,
+ ): self {
+ $self = new self;
+
+ $self['bucket'] = $bucket;
+ $self['clientEmail'] = $clientEmail;
+ $self['name'] = $name;
+ $self['privateKey'] = $privateKey;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+ null !== $includeCanonicalHeader && $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ null !== $prefix && $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ public function withBucket(string $bucket): self
+ {
+ $self = clone $this;
+ $self['bucket'] = $bucket;
+
+ return $self;
+ }
+
+ public function withClientEmail(string $clientEmail): self
+ {
+ $self = clone $this;
+ $self['clientEmail'] = $clientEmail;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ public function withPrivateKey(string $privateKey): self
+ {
+ $self = clone $this;
+ $self['privateKey'] = $privateKey;
+
+ return $self;
+ }
+
+ /**
+ * @param 'GCS' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginRequest/S3.php b/src/Accounts/Origins/OriginRequest/S3.php
new file mode 100644
index 00000000..cd4c3c79
--- /dev/null
+++ b/src/Accounts/Origins/OriginRequest/S3.php
@@ -0,0 +1,211 @@
+ */
+ use SdkModel;
+
+ /** @var 'S3' $type */
+ #[Required]
+ public string $type = 'S3';
+
+ /**
+ * Access key for the bucket.
+ */
+ #[Required]
+ public string $accessKey;
+
+ /**
+ * S3 bucket name.
+ */
+ #[Required]
+ public string $bucket;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * Secret key for the bucket.
+ */
+ #[Required]
+ public string $secretKey;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Optional]
+ public ?bool $includeCanonicalHeader;
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ #[Optional]
+ public ?string $prefix;
+
+ /**
+ * `new S3()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * S3::with(accessKey: ..., bucket: ..., name: ..., secretKey: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new S3)->withAccessKey(...)->withBucket(...)->withName(...)->withSecretKey(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $accessKey,
+ string $bucket,
+ string $name,
+ string $secretKey,
+ ?string $baseURLForCanonicalHeader = null,
+ ?bool $includeCanonicalHeader = null,
+ ?string $prefix = null,
+ ): self {
+ $self = new self;
+
+ $self['accessKey'] = $accessKey;
+ $self['bucket'] = $bucket;
+ $self['name'] = $name;
+ $self['secretKey'] = $secretKey;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+ null !== $includeCanonicalHeader && $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ null !== $prefix && $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ /**
+ * Access key for the bucket.
+ */
+ public function withAccessKey(string $accessKey): self
+ {
+ $self = clone $this;
+ $self['accessKey'] = $accessKey;
+
+ return $self;
+ }
+
+ /**
+ * S3 bucket name.
+ */
+ public function withBucket(string $bucket): self
+ {
+ $self = clone $this;
+ $self['bucket'] = $bucket;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Secret key for the bucket.
+ */
+ public function withSecretKey(string $secretKey): self
+ {
+ $self = clone $this;
+ $self['secretKey'] = $secretKey;
+
+ return $self;
+ }
+
+ /**
+ * @param 'S3' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginRequest/S3Compatible.php b/src/Accounts/Origins/OriginRequest/S3Compatible.php
new file mode 100644
index 00000000..fac8cf60
--- /dev/null
+++ b/src/Accounts/Origins/OriginRequest/S3Compatible.php
@@ -0,0 +1,258 @@
+ */
+ use SdkModel;
+
+ /** @var 'S3_COMPATIBLE' $type */
+ #[Required]
+ public string $type = 'S3_COMPATIBLE';
+
+ /**
+ * Access key for the bucket.
+ */
+ #[Required]
+ public string $accessKey;
+
+ /**
+ * S3 bucket name.
+ */
+ #[Required]
+ public string $bucket;
+
+ /**
+ * Custom S3-compatible endpoint.
+ */
+ #[Required]
+ public string $endpoint;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * Secret key for the bucket.
+ */
+ #[Required]
+ public string $secretKey;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Optional]
+ public ?bool $includeCanonicalHeader;
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ #[Optional]
+ public ?string $prefix;
+
+ /**
+ * Use path-style S3 URLs?
+ */
+ #[Optional]
+ public ?bool $s3ForcePathStyle;
+
+ /**
+ * `new S3Compatible()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * S3Compatible::with(
+ * accessKey: ..., bucket: ..., endpoint: ..., name: ..., secretKey: ...
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new S3Compatible)
+ * ->withAccessKey(...)
+ * ->withBucket(...)
+ * ->withEndpoint(...)
+ * ->withName(...)
+ * ->withSecretKey(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $accessKey,
+ string $bucket,
+ string $endpoint,
+ string $name,
+ string $secretKey,
+ ?string $baseURLForCanonicalHeader = null,
+ ?bool $includeCanonicalHeader = null,
+ ?string $prefix = null,
+ ?bool $s3ForcePathStyle = null,
+ ): self {
+ $self = new self;
+
+ $self['accessKey'] = $accessKey;
+ $self['bucket'] = $bucket;
+ $self['endpoint'] = $endpoint;
+ $self['name'] = $name;
+ $self['secretKey'] = $secretKey;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+ null !== $includeCanonicalHeader && $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ null !== $prefix && $self['prefix'] = $prefix;
+ null !== $s3ForcePathStyle && $self['s3ForcePathStyle'] = $s3ForcePathStyle;
+
+ return $self;
+ }
+
+ /**
+ * Access key for the bucket.
+ */
+ public function withAccessKey(string $accessKey): self
+ {
+ $self = clone $this;
+ $self['accessKey'] = $accessKey;
+
+ return $self;
+ }
+
+ /**
+ * S3 bucket name.
+ */
+ public function withBucket(string $bucket): self
+ {
+ $self = clone $this;
+ $self['bucket'] = $bucket;
+
+ return $self;
+ }
+
+ /**
+ * Custom S3-compatible endpoint.
+ */
+ public function withEndpoint(string $endpoint): self
+ {
+ $self = clone $this;
+ $self['endpoint'] = $endpoint;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Secret key for the bucket.
+ */
+ public function withSecretKey(string $secretKey): self
+ {
+ $self = clone $this;
+ $self['secretKey'] = $secretKey;
+
+ return $self;
+ }
+
+ /**
+ * @param 'S3_COMPATIBLE' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ /**
+ * Use path-style S3 URLs?
+ */
+ public function withS3ForcePathStyle(bool $s3ForcePathStyle): self
+ {
+ $self = clone $this;
+ $self['s3ForcePathStyle'] = $s3ForcePathStyle;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginRequest/WebFolder.php b/src/Accounts/Origins/OriginRequest/WebFolder.php
new file mode 100644
index 00000000..885195b6
--- /dev/null
+++ b/src/Accounts/Origins/OriginRequest/WebFolder.php
@@ -0,0 +1,172 @@
+ */
+ use SdkModel;
+
+ /** @var 'WEB_FOLDER' $type */
+ #[Required]
+ public string $type = 'WEB_FOLDER';
+
+ /**
+ * Root URL for the web folder origin.
+ */
+ #[Required('baseUrl')]
+ public string $baseURL;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * Forward the Host header to origin?
+ */
+ #[Optional]
+ public ?bool $forwardHostHeaderToOrigin;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Optional]
+ public ?bool $includeCanonicalHeader;
+
+ /**
+ * `new WebFolder()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * WebFolder::with(baseURL: ..., name: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new WebFolder)->withBaseURL(...)->withName(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $baseURL,
+ string $name,
+ ?string $baseURLForCanonicalHeader = null,
+ ?bool $forwardHostHeaderToOrigin = null,
+ ?bool $includeCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['baseURL'] = $baseURL;
+ $self['name'] = $name;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+ null !== $forwardHostHeaderToOrigin && $self['forwardHostHeaderToOrigin'] = $forwardHostHeaderToOrigin;
+ null !== $includeCanonicalHeader && $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Root URL for the web folder origin.
+ */
+ public function withBaseURL(string $baseURL): self
+ {
+ $self = clone $this;
+ $self['baseURL'] = $baseURL;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * @param 'WEB_FOLDER' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Forward the Host header to origin?
+ */
+ public function withForwardHostHeaderToOrigin(
+ bool $forwardHostHeaderToOrigin
+ ): self {
+ $self = clone $this;
+ $self['forwardHostHeaderToOrigin'] = $forwardHostHeaderToOrigin;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginRequest/WebProxy.php b/src/Accounts/Origins/OriginRequest/WebProxy.php
new file mode 100644
index 00000000..b4ab0fc1
--- /dev/null
+++ b/src/Accounts/Origins/OriginRequest/WebProxy.php
@@ -0,0 +1,131 @@
+ */
+ use SdkModel;
+
+ /** @var 'WEB_PROXY' $type */
+ #[Required]
+ public string $type = 'WEB_PROXY';
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Optional]
+ public ?bool $includeCanonicalHeader;
+
+ /**
+ * `new WebProxy()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * WebProxy::with(name: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new WebProxy)->withName(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $name,
+ ?string $baseURLForCanonicalHeader = null,
+ ?bool $includeCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['name'] = $name;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+ null !== $includeCanonicalHeader && $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * @param 'WEB_PROXY' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginResponse.php b/src/Accounts/Origins/OriginResponse.php
new file mode 100644
index 00000000..2a4d4c8e
--- /dev/null
+++ b/src/Accounts/Origins/OriginResponse.php
@@ -0,0 +1,59 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return [
+ 'S3' => S3::class,
+ 'S3_COMPATIBLE' => S3Compatible::class,
+ 'CLOUDINARY_BACKUP' => CloudinaryBackup::class,
+ 'WEB_FOLDER' => WebFolder::class,
+ 'WEB_PROXY' => WebProxy::class,
+ 'GCS' => GoogleCloudStorageGcs::class,
+ 'AZURE_BLOB' => AzureBlobStorage::class,
+ 'AKENEO_PIM' => AkeneoPim::class,
+ ];
+ }
+}
diff --git a/src/Accounts/Origins/OriginResponse/AkeneoPim.php b/src/Accounts/Origins/OriginResponse/AkeneoPim.php
new file mode 100644
index 00000000..84b2accf
--- /dev/null
+++ b/src/Accounts/Origins/OriginResponse/AkeneoPim.php
@@ -0,0 +1,175 @@
+ */
+ use SdkModel;
+
+ /** @var 'AKENEO_PIM' $type */
+ #[Required]
+ public string $type = 'AKENEO_PIM';
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ #[Required]
+ public string $id;
+
+ /**
+ * Akeneo instance base URL.
+ */
+ #[Required('baseUrl')]
+ public string $baseURL;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Required]
+ public bool $includeCanonicalHeader;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * `new AkeneoPim()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * AkeneoPim::with(id: ..., baseURL: ..., includeCanonicalHeader: ..., name: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new AkeneoPim)
+ * ->withID(...)
+ * ->withBaseURL(...)
+ * ->withIncludeCanonicalHeader(...)
+ * ->withName(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $id,
+ string $baseURL,
+ string $name,
+ bool $includeCanonicalHeader = false,
+ ?string $baseURLForCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['id'] = $id;
+ $self['baseURL'] = $baseURL;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ $self['name'] = $name;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo instance base URL.
+ */
+ public function withBaseURL(string $baseURL): self
+ {
+ $self = clone $this;
+ $self['baseURL'] = $baseURL;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * @param 'AKENEO_PIM' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginResponse/AzureBlobStorage.php b/src/Accounts/Origins/OriginResponse/AzureBlobStorage.php
new file mode 100644
index 00000000..45df2f63
--- /dev/null
+++ b/src/Accounts/Origins/OriginResponse/AzureBlobStorage.php
@@ -0,0 +1,206 @@
+ */
+ use SdkModel;
+
+ /** @var 'AZURE_BLOB' $type */
+ #[Required]
+ public string $type = 'AZURE_BLOB';
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ #[Required]
+ public string $id;
+
+ #[Required]
+ public string $accountName;
+
+ #[Required]
+ public string $container;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Required]
+ public bool $includeCanonicalHeader;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ #[Required]
+ public string $prefix;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * `new AzureBlobStorage()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * AzureBlobStorage::with(
+ * id: ...,
+ * accountName: ...,
+ * container: ...,
+ * includeCanonicalHeader: ...,
+ * name: ...,
+ * prefix: ...,
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new AzureBlobStorage)
+ * ->withID(...)
+ * ->withAccountName(...)
+ * ->withContainer(...)
+ * ->withIncludeCanonicalHeader(...)
+ * ->withName(...)
+ * ->withPrefix(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $id,
+ string $accountName,
+ string $container,
+ string $name,
+ string $prefix,
+ bool $includeCanonicalHeader = false,
+ ?string $baseURLForCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['id'] = $id;
+ $self['accountName'] = $accountName;
+ $self['container'] = $container;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ $self['name'] = $name;
+ $self['prefix'] = $prefix;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ public function withAccountName(string $accountName): self
+ {
+ $self = clone $this;
+ $self['accountName'] = $accountName;
+
+ return $self;
+ }
+
+ public function withContainer(string $container): self
+ {
+ $self = clone $this;
+ $self['container'] = $container;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ /**
+ * @param 'AZURE_BLOB' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginResponse/CloudinaryBackup.php b/src/Accounts/Origins/OriginResponse/CloudinaryBackup.php
new file mode 100644
index 00000000..fba1c65d
--- /dev/null
+++ b/src/Accounts/Origins/OriginResponse/CloudinaryBackup.php
@@ -0,0 +1,198 @@
+ */
+ use SdkModel;
+
+ /** @var 'CLOUDINARY_BACKUP' $type */
+ #[Required]
+ public string $type = 'CLOUDINARY_BACKUP';
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ #[Required]
+ public string $id;
+
+ /**
+ * S3 bucket name.
+ */
+ #[Required]
+ public string $bucket;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Required]
+ public bool $includeCanonicalHeader;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ #[Required]
+ public string $prefix;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * `new CloudinaryBackup()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * CloudinaryBackup::with(
+ * id: ..., bucket: ..., includeCanonicalHeader: ..., name: ..., prefix: ...
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new CloudinaryBackup)
+ * ->withID(...)
+ * ->withBucket(...)
+ * ->withIncludeCanonicalHeader(...)
+ * ->withName(...)
+ * ->withPrefix(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $id,
+ string $bucket,
+ string $name,
+ string $prefix,
+ bool $includeCanonicalHeader = false,
+ ?string $baseURLForCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['id'] = $id;
+ $self['bucket'] = $bucket;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ $self['name'] = $name;
+ $self['prefix'] = $prefix;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ /**
+ * S3 bucket name.
+ */
+ public function withBucket(string $bucket): self
+ {
+ $self = clone $this;
+ $self['bucket'] = $bucket;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ /**
+ * @param 'CLOUDINARY_BACKUP' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginResponse/GoogleCloudStorageGcs.php b/src/Accounts/Origins/OriginResponse/GoogleCloudStorageGcs.php
new file mode 100644
index 00000000..cb998b0b
--- /dev/null
+++ b/src/Accounts/Origins/OriginResponse/GoogleCloudStorageGcs.php
@@ -0,0 +1,206 @@
+ */
+ use SdkModel;
+
+ /** @var 'GCS' $type */
+ #[Required]
+ public string $type = 'GCS';
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ #[Required]
+ public string $id;
+
+ #[Required]
+ public string $bucket;
+
+ #[Required]
+ public string $clientEmail;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Required]
+ public bool $includeCanonicalHeader;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ #[Required]
+ public string $prefix;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * `new GoogleCloudStorageGcs()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * GoogleCloudStorageGcs::with(
+ * id: ...,
+ * bucket: ...,
+ * clientEmail: ...,
+ * includeCanonicalHeader: ...,
+ * name: ...,
+ * prefix: ...,
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new GoogleCloudStorageGcs)
+ * ->withID(...)
+ * ->withBucket(...)
+ * ->withClientEmail(...)
+ * ->withIncludeCanonicalHeader(...)
+ * ->withName(...)
+ * ->withPrefix(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $id,
+ string $bucket,
+ string $clientEmail,
+ string $name,
+ string $prefix,
+ bool $includeCanonicalHeader = false,
+ ?string $baseURLForCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['id'] = $id;
+ $self['bucket'] = $bucket;
+ $self['clientEmail'] = $clientEmail;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ $self['name'] = $name;
+ $self['prefix'] = $prefix;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ public function withBucket(string $bucket): self
+ {
+ $self = clone $this;
+ $self['bucket'] = $bucket;
+
+ return $self;
+ }
+
+ public function withClientEmail(string $clientEmail): self
+ {
+ $self = clone $this;
+ $self['clientEmail'] = $clientEmail;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ /**
+ * @param 'GCS' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginResponse/S3.php b/src/Accounts/Origins/OriginResponse/S3.php
new file mode 100644
index 00000000..b62e9ef4
--- /dev/null
+++ b/src/Accounts/Origins/OriginResponse/S3.php
@@ -0,0 +1,198 @@
+ */
+ use SdkModel;
+
+ /** @var 'S3' $type */
+ #[Required]
+ public string $type = 'S3';
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ #[Required]
+ public string $id;
+
+ /**
+ * S3 bucket name.
+ */
+ #[Required]
+ public string $bucket;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Required]
+ public bool $includeCanonicalHeader;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ #[Required]
+ public string $prefix;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * `new S3()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * S3::with(
+ * id: ..., bucket: ..., includeCanonicalHeader: ..., name: ..., prefix: ...
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new S3)
+ * ->withID(...)
+ * ->withBucket(...)
+ * ->withIncludeCanonicalHeader(...)
+ * ->withName(...)
+ * ->withPrefix(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $id,
+ string $bucket,
+ string $name,
+ string $prefix,
+ bool $includeCanonicalHeader = false,
+ ?string $baseURLForCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['id'] = $id;
+ $self['bucket'] = $bucket;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ $self['name'] = $name;
+ $self['prefix'] = $prefix;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ /**
+ * S3 bucket name.
+ */
+ public function withBucket(string $bucket): self
+ {
+ $self = clone $this;
+ $self['bucket'] = $bucket;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ /**
+ * @param 'S3' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginResponse/S3Compatible.php b/src/Accounts/Origins/OriginResponse/S3Compatible.php
new file mode 100644
index 00000000..78078b4a
--- /dev/null
+++ b/src/Accounts/Origins/OriginResponse/S3Compatible.php
@@ -0,0 +1,246 @@
+ */
+ use SdkModel;
+
+ /** @var 'S3_COMPATIBLE' $type */
+ #[Required]
+ public string $type = 'S3_COMPATIBLE';
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ #[Required]
+ public string $id;
+
+ /**
+ * S3 bucket name.
+ */
+ #[Required]
+ public string $bucket;
+
+ /**
+ * Custom S3-compatible endpoint.
+ */
+ #[Required]
+ public string $endpoint;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Required]
+ public bool $includeCanonicalHeader;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ #[Required]
+ public string $prefix;
+
+ /**
+ * Use path-style S3 URLs?
+ */
+ #[Required]
+ public bool $s3ForcePathStyle;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * `new S3Compatible()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * S3Compatible::with(
+ * id: ...,
+ * bucket: ...,
+ * endpoint: ...,
+ * includeCanonicalHeader: ...,
+ * name: ...,
+ * prefix: ...,
+ * s3ForcePathStyle: ...,
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new S3Compatible)
+ * ->withID(...)
+ * ->withBucket(...)
+ * ->withEndpoint(...)
+ * ->withIncludeCanonicalHeader(...)
+ * ->withName(...)
+ * ->withPrefix(...)
+ * ->withS3ForcePathStyle(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $id,
+ string $bucket,
+ string $endpoint,
+ string $name,
+ string $prefix,
+ bool $includeCanonicalHeader = false,
+ bool $s3ForcePathStyle = false,
+ ?string $baseURLForCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['id'] = $id;
+ $self['bucket'] = $bucket;
+ $self['endpoint'] = $endpoint;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ $self['name'] = $name;
+ $self['prefix'] = $prefix;
+ $self['s3ForcePathStyle'] = $s3ForcePathStyle;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ /**
+ * S3 bucket name.
+ */
+ public function withBucket(string $bucket): self
+ {
+ $self = clone $this;
+ $self['bucket'] = $bucket;
+
+ return $self;
+ }
+
+ /**
+ * Custom S3-compatible endpoint.
+ */
+ public function withEndpoint(string $endpoint): self
+ {
+ $self = clone $this;
+ $self['endpoint'] = $endpoint;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Path prefix inside the bucket.
+ */
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ /**
+ * Use path-style S3 URLs?
+ */
+ public function withS3ForcePathStyle(bool $s3ForcePathStyle): self
+ {
+ $self = clone $this;
+ $self['s3ForcePathStyle'] = $s3ForcePathStyle;
+
+ return $self;
+ }
+
+ /**
+ * @param 'S3_COMPATIBLE' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginResponse/WebFolder.php b/src/Accounts/Origins/OriginResponse/WebFolder.php
new file mode 100644
index 00000000..85234356
--- /dev/null
+++ b/src/Accounts/Origins/OriginResponse/WebFolder.php
@@ -0,0 +1,203 @@
+ */
+ use SdkModel;
+
+ /** @var 'WEB_FOLDER' $type */
+ #[Required]
+ public string $type = 'WEB_FOLDER';
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ #[Required]
+ public string $id;
+
+ /**
+ * Root URL for the web folder origin.
+ */
+ #[Required('baseUrl')]
+ public string $baseURL;
+
+ /**
+ * Forward the Host header to origin?
+ */
+ #[Required]
+ public bool $forwardHostHeaderToOrigin;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Required]
+ public bool $includeCanonicalHeader;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * `new WebFolder()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * WebFolder::with(
+ * id: ...,
+ * baseURL: ...,
+ * forwardHostHeaderToOrigin: ...,
+ * includeCanonicalHeader: ...,
+ * name: ...,
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new WebFolder)
+ * ->withID(...)
+ * ->withBaseURL(...)
+ * ->withForwardHostHeaderToOrigin(...)
+ * ->withIncludeCanonicalHeader(...)
+ * ->withName(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $id,
+ string $baseURL,
+ string $name,
+ bool $forwardHostHeaderToOrigin = false,
+ bool $includeCanonicalHeader = false,
+ ?string $baseURLForCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['id'] = $id;
+ $self['baseURL'] = $baseURL;
+ $self['forwardHostHeaderToOrigin'] = $forwardHostHeaderToOrigin;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ $self['name'] = $name;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ /**
+ * Root URL for the web folder origin.
+ */
+ public function withBaseURL(string $baseURL): self
+ {
+ $self = clone $this;
+ $self['baseURL'] = $baseURL;
+
+ return $self;
+ }
+
+ /**
+ * Forward the Host header to origin?
+ */
+ public function withForwardHostHeaderToOrigin(
+ bool $forwardHostHeaderToOrigin
+ ): self {
+ $self = clone $this;
+ $self['forwardHostHeaderToOrigin'] = $forwardHostHeaderToOrigin;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * @param 'WEB_FOLDER' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginResponse/WebProxy.php b/src/Accounts/Origins/OriginResponse/WebProxy.php
new file mode 100644
index 00000000..a460f0fc
--- /dev/null
+++ b/src/Accounts/Origins/OriginResponse/WebProxy.php
@@ -0,0 +1,151 @@
+ */
+ use SdkModel;
+
+ /** @var 'WEB_PROXY' $type */
+ #[Required]
+ public string $type = 'WEB_PROXY';
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ #[Required]
+ public string $id;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Required]
+ public bool $includeCanonicalHeader;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * `new WebProxy()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * WebProxy::with(id: ..., includeCanonicalHeader: ..., name: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new WebProxy)->withID(...)->withIncludeCanonicalHeader(...)->withName(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $id,
+ string $name,
+ bool $includeCanonicalHeader = false,
+ ?string $baseURLForCanonicalHeader = null,
+ ): self {
+ $self = new self;
+
+ $self['id'] = $id;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ $self['name'] = $name;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier for the origin. This is generated by ImageKit when you create a new origin.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * @param 'WEB_PROXY' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Origins/OriginUpdateParams.php b/src/Accounts/Origins/OriginUpdateParams.php
new file mode 100644
index 00000000..1abf1736
--- /dev/null
+++ b/src/Accounts/Origins/OriginUpdateParams.php
@@ -0,0 +1,468 @@
+ */
+ use SdkModel;
+ use SdkParams;
+
+ /** @var 'AKENEO_PIM' $type */
+ #[Required]
+ public string $type = 'AKENEO_PIM';
+
+ /**
+ * Access key for the bucket.
+ */
+ #[Required]
+ public string $accessKey;
+
+ #[Required]
+ public string $bucket;
+
+ /**
+ * Display name of the origin.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * Secret key for the bucket.
+ */
+ #[Required]
+ public string $secretKey;
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ #[Optional('baseUrlForCanonicalHeader')]
+ public ?string $baseURLForCanonicalHeader;
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ #[Optional]
+ public ?bool $includeCanonicalHeader;
+
+ #[Optional]
+ public ?string $prefix;
+
+ /**
+ * Custom S3-compatible endpoint.
+ */
+ #[Required]
+ public string $endpoint;
+
+ /**
+ * Use path-style S3 URLs?
+ */
+ #[Optional]
+ public ?bool $s3ForcePathStyle;
+
+ /**
+ * Akeneo instance base URL.
+ */
+ #[Required('baseUrl')]
+ public string $baseURL;
+
+ /**
+ * Forward the Host header to origin?
+ */
+ #[Optional]
+ public ?bool $forwardHostHeaderToOrigin;
+
+ #[Required]
+ public string $clientEmail;
+
+ #[Required]
+ public string $privateKey;
+
+ #[Required]
+ public string $accountName;
+
+ #[Required]
+ public string $container;
+
+ #[Required]
+ public string $sasToken;
+
+ /**
+ * Akeneo API client ID.
+ */
+ #[Required('clientId')]
+ public string $clientID;
+
+ /**
+ * Akeneo API client secret.
+ */
+ #[Required]
+ public string $clientSecret;
+
+ /**
+ * Akeneo API password.
+ */
+ #[Required]
+ public string $password;
+
+ /**
+ * Akeneo API username.
+ */
+ #[Required]
+ public string $username;
+
+ /**
+ * `new OriginUpdateParams()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * OriginUpdateParams::with(
+ * accessKey: ...,
+ * bucket: ...,
+ * name: ...,
+ * secretKey: ...,
+ * endpoint: ...,
+ * baseURL: ...,
+ * clientEmail: ...,
+ * privateKey: ...,
+ * accountName: ...,
+ * container: ...,
+ * sasToken: ...,
+ * clientID: ...,
+ * clientSecret: ...,
+ * password: ...,
+ * username: ...,
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new OriginUpdateParams)
+ * ->withAccessKey(...)
+ * ->withBucket(...)
+ * ->withName(...)
+ * ->withSecretKey(...)
+ * ->withEndpoint(...)
+ * ->withBaseURL(...)
+ * ->withClientEmail(...)
+ * ->withPrivateKey(...)
+ * ->withAccountName(...)
+ * ->withContainer(...)
+ * ->withSasToken(...)
+ * ->withClientID(...)
+ * ->withClientSecret(...)
+ * ->withPassword(...)
+ * ->withUsername(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ string $accessKey,
+ string $bucket,
+ string $name,
+ string $secretKey,
+ string $endpoint,
+ string $baseURL,
+ string $clientEmail,
+ string $privateKey,
+ string $accountName,
+ string $container,
+ string $sasToken,
+ string $clientID,
+ string $clientSecret,
+ string $password,
+ string $username,
+ ?string $baseURLForCanonicalHeader = null,
+ ?bool $includeCanonicalHeader = null,
+ ?string $prefix = null,
+ ?bool $s3ForcePathStyle = null,
+ ?bool $forwardHostHeaderToOrigin = null,
+ ): self {
+ $self = new self;
+
+ $self['accessKey'] = $accessKey;
+ $self['bucket'] = $bucket;
+ $self['name'] = $name;
+ $self['secretKey'] = $secretKey;
+ $self['endpoint'] = $endpoint;
+ $self['baseURL'] = $baseURL;
+ $self['clientEmail'] = $clientEmail;
+ $self['privateKey'] = $privateKey;
+ $self['accountName'] = $accountName;
+ $self['container'] = $container;
+ $self['sasToken'] = $sasToken;
+ $self['clientID'] = $clientID;
+ $self['clientSecret'] = $clientSecret;
+ $self['password'] = $password;
+ $self['username'] = $username;
+
+ null !== $baseURLForCanonicalHeader && $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+ null !== $includeCanonicalHeader && $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+ null !== $prefix && $self['prefix'] = $prefix;
+ null !== $s3ForcePathStyle && $self['s3ForcePathStyle'] = $s3ForcePathStyle;
+ null !== $forwardHostHeaderToOrigin && $self['forwardHostHeaderToOrigin'] = $forwardHostHeaderToOrigin;
+
+ return $self;
+ }
+
+ /**
+ * @param 'AKENEO_PIM' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * Access key for the bucket.
+ */
+ public function withAccessKey(string $accessKey): self
+ {
+ $self = clone $this;
+ $self['accessKey'] = $accessKey;
+
+ return $self;
+ }
+
+ public function withBucket(string $bucket): self
+ {
+ $self = clone $this;
+ $self['bucket'] = $bucket;
+
+ return $self;
+ }
+
+ /**
+ * Display name of the origin.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Secret key for the bucket.
+ */
+ public function withSecretKey(string $secretKey): self
+ {
+ $self = clone $this;
+ $self['secretKey'] = $secretKey;
+
+ return $self;
+ }
+
+ /**
+ * URL used in the Canonical header (if enabled).
+ */
+ public function withBaseURLForCanonicalHeader(
+ string $baseURLForCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['baseURLForCanonicalHeader'] = $baseURLForCanonicalHeader;
+
+ return $self;
+ }
+
+ /**
+ * Whether to send a Canonical header.
+ */
+ public function withIncludeCanonicalHeader(
+ bool $includeCanonicalHeader
+ ): self {
+ $self = clone $this;
+ $self['includeCanonicalHeader'] = $includeCanonicalHeader;
+
+ return $self;
+ }
+
+ public function withPrefix(string $prefix): self
+ {
+ $self = clone $this;
+ $self['prefix'] = $prefix;
+
+ return $self;
+ }
+
+ /**
+ * Custom S3-compatible endpoint.
+ */
+ public function withEndpoint(string $endpoint): self
+ {
+ $self = clone $this;
+ $self['endpoint'] = $endpoint;
+
+ return $self;
+ }
+
+ /**
+ * Use path-style S3 URLs?
+ */
+ public function withS3ForcePathStyle(bool $s3ForcePathStyle): self
+ {
+ $self = clone $this;
+ $self['s3ForcePathStyle'] = $s3ForcePathStyle;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo instance base URL.
+ */
+ public function withBaseURL(string $baseURL): self
+ {
+ $self = clone $this;
+ $self['baseURL'] = $baseURL;
+
+ return $self;
+ }
+
+ /**
+ * Forward the Host header to origin?
+ */
+ public function withForwardHostHeaderToOrigin(
+ bool $forwardHostHeaderToOrigin
+ ): self {
+ $self = clone $this;
+ $self['forwardHostHeaderToOrigin'] = $forwardHostHeaderToOrigin;
+
+ return $self;
+ }
+
+ public function withClientEmail(string $clientEmail): self
+ {
+ $self = clone $this;
+ $self['clientEmail'] = $clientEmail;
+
+ return $self;
+ }
+
+ public function withPrivateKey(string $privateKey): self
+ {
+ $self = clone $this;
+ $self['privateKey'] = $privateKey;
+
+ return $self;
+ }
+
+ public function withAccountName(string $accountName): self
+ {
+ $self = clone $this;
+ $self['accountName'] = $accountName;
+
+ return $self;
+ }
+
+ public function withContainer(string $container): self
+ {
+ $self = clone $this;
+ $self['container'] = $container;
+
+ return $self;
+ }
+
+ public function withSasToken(string $sasToken): self
+ {
+ $self = clone $this;
+ $self['sasToken'] = $sasToken;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API client ID.
+ */
+ public function withClientID(string $clientID): self
+ {
+ $self = clone $this;
+ $self['clientID'] = $clientID;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API client secret.
+ */
+ public function withClientSecret(string $clientSecret): self
+ {
+ $self = clone $this;
+ $self['clientSecret'] = $clientSecret;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API password.
+ */
+ public function withPassword(string $password): self
+ {
+ $self = clone $this;
+ $self['password'] = $password;
+
+ return $self;
+ }
+
+ /**
+ * Akeneo API username.
+ */
+ public function withUsername(string $username): self
+ {
+ $self = clone $this;
+ $self['username'] = $username;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointCreateParams.php b/src/Accounts/URLEndpoints/URLEndpointCreateParams.php
new file mode 100644
index 00000000..5d5fbb74
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointCreateParams.php
@@ -0,0 +1,159 @@
+|null,
+ * urlPrefix?: string|null,
+ * urlRewriter?: URLRewriterShape|null,
+ * }
+ */
+final class URLEndpointCreateParams implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+ use SdkParams;
+
+ /**
+ * Description of the URL endpoint.
+ */
+ #[Required]
+ public string $description;
+
+ /**
+ * Ordered list of origin IDs to try when the file isn’t in the Media Library; ImageKit checks them in the sequence provided. Origin must be created before it can be used in a URL endpoint.
+ *
+ * @var list|null $origins
+ */
+ #[Optional(list: 'string')]
+ public ?array $origins;
+
+ /**
+ * Path segment appended to your base URL to form the endpoint (letters, digits, and hyphens only — or empty for the default endpoint).
+ */
+ #[Optional]
+ public ?string $urlPrefix;
+
+ /**
+ * Configuration for third-party URL rewriting.
+ *
+ * @var URLRewriterVariants|null $urlRewriter
+ */
+ #[Optional(union: URLRewriter::class)]
+ public CloudinaryURLRewriter|ImgixURLRewriter|AkamaiURLRewriter|null $urlRewriter;
+
+ /**
+ * `new URLEndpointCreateParams()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * URLEndpointCreateParams::with(description: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new URLEndpointCreateParams)->withDescription(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param list|null $origins
+ * @param URLRewriterShape|null $urlRewriter
+ */
+ public static function with(
+ string $description,
+ ?array $origins = null,
+ ?string $urlPrefix = null,
+ CloudinaryURLRewriter|array|ImgixURLRewriter|AkamaiURLRewriter|null $urlRewriter = null,
+ ): self {
+ $self = new self;
+
+ $self['description'] = $description;
+
+ null !== $origins && $self['origins'] = $origins;
+ null !== $urlPrefix && $self['urlPrefix'] = $urlPrefix;
+ null !== $urlRewriter && $self['urlRewriter'] = $urlRewriter;
+
+ return $self;
+ }
+
+ /**
+ * Description of the URL endpoint.
+ */
+ public function withDescription(string $description): self
+ {
+ $self = clone $this;
+ $self['description'] = $description;
+
+ return $self;
+ }
+
+ /**
+ * Ordered list of origin IDs to try when the file isn’t in the Media Library; ImageKit checks them in the sequence provided. Origin must be created before it can be used in a URL endpoint.
+ *
+ * @param list $origins
+ */
+ public function withOrigins(array $origins): self
+ {
+ $self = clone $this;
+ $self['origins'] = $origins;
+
+ return $self;
+ }
+
+ /**
+ * Path segment appended to your base URL to form the endpoint (letters, digits, and hyphens only — or empty for the default endpoint).
+ */
+ public function withURLPrefix(string $urlPrefix): self
+ {
+ $self = clone $this;
+ $self['urlPrefix'] = $urlPrefix;
+
+ return $self;
+ }
+
+ /**
+ * Configuration for third-party URL rewriting.
+ *
+ * @param URLRewriterShape $urlRewriter
+ */
+ public function withURLRewriter(
+ CloudinaryURLRewriter|array|ImgixURLRewriter|AkamaiURLRewriter $urlRewriter
+ ): self {
+ $self = clone $this;
+ $self['urlRewriter'] = $urlRewriter;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter.php
new file mode 100644
index 00000000..013a7d11
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter.php
@@ -0,0 +1,44 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return [
+ 'CLOUDINARY' => CloudinaryURLRewriter::class,
+ 'IMGIX' => ImgixURLRewriter::class,
+ 'AKAMAI' => AkamaiURLRewriter::class,
+ ];
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter/AkamaiURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter/AkamaiURLRewriter.php
new file mode 100644
index 00000000..3426c523
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter/AkamaiURLRewriter.php
@@ -0,0 +1,48 @@
+ */
+ use SdkModel;
+
+ /** @var 'AKAMAI' $type */
+ #[Required]
+ public string $type = 'AKAMAI';
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(): self
+ {
+ return new self;
+ }
+
+ /**
+ * @param 'AKAMAI' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter/CloudinaryURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter/CloudinaryURLRewriter.php
new file mode 100644
index 00000000..56426c4f
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter/CloudinaryURLRewriter.php
@@ -0,0 +1,73 @@
+ */
+ use SdkModel;
+
+ /** @var 'CLOUDINARY' $type */
+ #[Required]
+ public string $type = 'CLOUDINARY';
+
+ /**
+ * Whether to preserve `/` in the rewritten URL.
+ */
+ #[Optional]
+ public ?bool $preserveAssetDeliveryTypes;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(?bool $preserveAssetDeliveryTypes = null): self
+ {
+ $self = new self;
+
+ null !== $preserveAssetDeliveryTypes && $self['preserveAssetDeliveryTypes'] = $preserveAssetDeliveryTypes;
+
+ return $self;
+ }
+
+ /**
+ * @param 'CLOUDINARY' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * Whether to preserve `/` in the rewritten URL.
+ */
+ public function withPreserveAssetDeliveryTypes(
+ bool $preserveAssetDeliveryTypes
+ ): self {
+ $self = clone $this;
+ $self['preserveAssetDeliveryTypes'] = $preserveAssetDeliveryTypes;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter/ImgixURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter/ImgixURLRewriter.php
new file mode 100644
index 00000000..4eadafe0
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointCreateParams/URLRewriter/ImgixURLRewriter.php
@@ -0,0 +1,48 @@
+ */
+ use SdkModel;
+
+ /** @var 'IMGIX' $type */
+ #[Required]
+ public string $type = 'IMGIX';
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(): self
+ {
+ return new self;
+ }
+
+ /**
+ * @param 'IMGIX' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointRequest.php b/src/Accounts/URLEndpoints/URLEndpointRequest.php
new file mode 100644
index 00000000..a3a90292
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointRequest.php
@@ -0,0 +1,154 @@
+|null,
+ * urlPrefix?: string|null,
+ * urlRewriter?: URLRewriterShape|null,
+ * }
+ */
+final class URLEndpointRequest implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * Description of the URL endpoint.
+ */
+ #[Required]
+ public string $description;
+
+ /**
+ * Ordered list of origin IDs to try when the file isn’t in the Media Library; ImageKit checks them in the sequence provided. Origin must be created before it can be used in a URL endpoint.
+ *
+ * @var list|null $origins
+ */
+ #[Optional(list: 'string')]
+ public ?array $origins;
+
+ /**
+ * Path segment appended to your base URL to form the endpoint (letters, digits, and hyphens only — or empty for the default endpoint).
+ */
+ #[Optional]
+ public ?string $urlPrefix;
+
+ /**
+ * Configuration for third-party URL rewriting.
+ *
+ * @var URLRewriterVariants|null $urlRewriter
+ */
+ #[Optional(union: URLRewriter::class)]
+ public CloudinaryURLRewriter|ImgixURLRewriter|AkamaiURLRewriter|null $urlRewriter;
+
+ /**
+ * `new URLEndpointRequest()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * URLEndpointRequest::with(description: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new URLEndpointRequest)->withDescription(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param list|null $origins
+ * @param URLRewriterShape|null $urlRewriter
+ */
+ public static function with(
+ string $description,
+ ?array $origins = null,
+ ?string $urlPrefix = null,
+ CloudinaryURLRewriter|array|ImgixURLRewriter|AkamaiURLRewriter|null $urlRewriter = null,
+ ): self {
+ $self = new self;
+
+ $self['description'] = $description;
+
+ null !== $origins && $self['origins'] = $origins;
+ null !== $urlPrefix && $self['urlPrefix'] = $urlPrefix;
+ null !== $urlRewriter && $self['urlRewriter'] = $urlRewriter;
+
+ return $self;
+ }
+
+ /**
+ * Description of the URL endpoint.
+ */
+ public function withDescription(string $description): self
+ {
+ $self = clone $this;
+ $self['description'] = $description;
+
+ return $self;
+ }
+
+ /**
+ * Ordered list of origin IDs to try when the file isn’t in the Media Library; ImageKit checks them in the sequence provided. Origin must be created before it can be used in a URL endpoint.
+ *
+ * @param list $origins
+ */
+ public function withOrigins(array $origins): self
+ {
+ $self = clone $this;
+ $self['origins'] = $origins;
+
+ return $self;
+ }
+
+ /**
+ * Path segment appended to your base URL to form the endpoint (letters, digits, and hyphens only — or empty for the default endpoint).
+ */
+ public function withURLPrefix(string $urlPrefix): self
+ {
+ $self = clone $this;
+ $self['urlPrefix'] = $urlPrefix;
+
+ return $self;
+ }
+
+ /**
+ * Configuration for third-party URL rewriting.
+ *
+ * @param URLRewriterShape $urlRewriter
+ */
+ public function withURLRewriter(
+ CloudinaryURLRewriter|array|ImgixURLRewriter|AkamaiURLRewriter $urlRewriter
+ ): self {
+ $self = clone $this;
+ $self['urlRewriter'] = $urlRewriter;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter.php
new file mode 100644
index 00000000..73515b91
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter.php
@@ -0,0 +1,44 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return [
+ 'CLOUDINARY' => CloudinaryURLRewriter::class,
+ 'IMGIX' => ImgixURLRewriter::class,
+ 'AKAMAI' => AkamaiURLRewriter::class,
+ ];
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter/AkamaiURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter/AkamaiURLRewriter.php
new file mode 100644
index 00000000..534e2eaf
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter/AkamaiURLRewriter.php
@@ -0,0 +1,48 @@
+ */
+ use SdkModel;
+
+ /** @var 'AKAMAI' $type */
+ #[Required]
+ public string $type = 'AKAMAI';
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(): self
+ {
+ return new self;
+ }
+
+ /**
+ * @param 'AKAMAI' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter/CloudinaryURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter/CloudinaryURLRewriter.php
new file mode 100644
index 00000000..b2438007
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter/CloudinaryURLRewriter.php
@@ -0,0 +1,73 @@
+ */
+ use SdkModel;
+
+ /** @var 'CLOUDINARY' $type */
+ #[Required]
+ public string $type = 'CLOUDINARY';
+
+ /**
+ * Whether to preserve `/` in the rewritten URL.
+ */
+ #[Optional]
+ public ?bool $preserveAssetDeliveryTypes;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(?bool $preserveAssetDeliveryTypes = null): self
+ {
+ $self = new self;
+
+ null !== $preserveAssetDeliveryTypes && $self['preserveAssetDeliveryTypes'] = $preserveAssetDeliveryTypes;
+
+ return $self;
+ }
+
+ /**
+ * @param 'CLOUDINARY' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * Whether to preserve `/` in the rewritten URL.
+ */
+ public function withPreserveAssetDeliveryTypes(
+ bool $preserveAssetDeliveryTypes
+ ): self {
+ $self = clone $this;
+ $self['preserveAssetDeliveryTypes'] = $preserveAssetDeliveryTypes;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter/ImgixURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter/ImgixURLRewriter.php
new file mode 100644
index 00000000..2f96917c
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointRequest/URLRewriter/ImgixURLRewriter.php
@@ -0,0 +1,48 @@
+ */
+ use SdkModel;
+
+ /** @var 'IMGIX' $type */
+ #[Required]
+ public string $type = 'IMGIX';
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(): self
+ {
+ return new self;
+ }
+
+ /**
+ * @param 'IMGIX' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointResponse.php b/src/Accounts/URLEndpoints/URLEndpointResponse.php
new file mode 100644
index 00000000..af3e773d
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointResponse.php
@@ -0,0 +1,180 @@
+,
+ * urlPrefix: string,
+ * urlRewriter?: URLRewriterShape|null,
+ * }
+ */
+final class URLEndpointResponse implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * Unique identifier for the URL-endpoint. This is generated by ImageKit when you create a new URL-endpoint. For the default URL-endpoint, this is always `default`.
+ */
+ #[Required]
+ public string $id;
+
+ /**
+ * Description of the URL endpoint.
+ */
+ #[Required]
+ public string $description;
+
+ /**
+ * Ordered list of origin IDs to try when the file isn’t in the Media Library; ImageKit checks them in the sequence provided. Origin must be created before it can be used in a URL endpoint.
+ *
+ * @var list $origins
+ */
+ #[Required(list: 'string')]
+ public array $origins;
+
+ /**
+ * Path segment appended to your base URL to form the endpoint (letters, digits, and hyphens only — or empty for the default endpoint).
+ */
+ #[Required]
+ public string $urlPrefix;
+
+ /**
+ * Configuration for third-party URL rewriting.
+ *
+ * @var URLRewriterVariants|null $urlRewriter
+ */
+ #[Optional(union: URLRewriter::class)]
+ public CloudinaryURLRewriter|ImgixURLRewriter|AkamaiURLRewriter|null $urlRewriter;
+
+ /**
+ * `new URLEndpointResponse()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * URLEndpointResponse::with(
+ * id: ..., description: ..., origins: ..., urlPrefix: ...
+ * )
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new URLEndpointResponse)
+ * ->withID(...)
+ * ->withDescription(...)
+ * ->withOrigins(...)
+ * ->withURLPrefix(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param list $origins
+ * @param URLRewriterShape|null $urlRewriter
+ */
+ public static function with(
+ string $id,
+ string $description,
+ array $origins = [],
+ string $urlPrefix = '',
+ CloudinaryURLRewriter|array|ImgixURLRewriter|AkamaiURLRewriter|null $urlRewriter = null,
+ ): self {
+ $self = new self;
+
+ $self['id'] = $id;
+ $self['description'] = $description;
+ $self['origins'] = $origins;
+ $self['urlPrefix'] = $urlPrefix;
+
+ null !== $urlRewriter && $self['urlRewriter'] = $urlRewriter;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier for the URL-endpoint. This is generated by ImageKit when you create a new URL-endpoint. For the default URL-endpoint, this is always `default`.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ /**
+ * Description of the URL endpoint.
+ */
+ public function withDescription(string $description): self
+ {
+ $self = clone $this;
+ $self['description'] = $description;
+
+ return $self;
+ }
+
+ /**
+ * Ordered list of origin IDs to try when the file isn’t in the Media Library; ImageKit checks them in the sequence provided. Origin must be created before it can be used in a URL endpoint.
+ *
+ * @param list $origins
+ */
+ public function withOrigins(array $origins): self
+ {
+ $self = clone $this;
+ $self['origins'] = $origins;
+
+ return $self;
+ }
+
+ /**
+ * Path segment appended to your base URL to form the endpoint (letters, digits, and hyphens only — or empty for the default endpoint).
+ */
+ public function withURLPrefix(string $urlPrefix): self
+ {
+ $self = clone $this;
+ $self['urlPrefix'] = $urlPrefix;
+
+ return $self;
+ }
+
+ /**
+ * Configuration for third-party URL rewriting.
+ *
+ * @param URLRewriterShape $urlRewriter
+ */
+ public function withURLRewriter(
+ CloudinaryURLRewriter|array|ImgixURLRewriter|AkamaiURLRewriter $urlRewriter
+ ): self {
+ $self = clone $this;
+ $self['urlRewriter'] = $urlRewriter;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter.php
new file mode 100644
index 00000000..4670b2e9
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter.php
@@ -0,0 +1,44 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return [
+ 'CLOUDINARY' => CloudinaryURLRewriter::class,
+ 'IMGIX' => ImgixURLRewriter::class,
+ 'AKAMAI' => AkamaiURLRewriter::class,
+ ];
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter/AkamaiURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter/AkamaiURLRewriter.php
new file mode 100644
index 00000000..505b599f
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter/AkamaiURLRewriter.php
@@ -0,0 +1,48 @@
+ */
+ use SdkModel;
+
+ /** @var 'AKAMAI' $type */
+ #[Required]
+ public string $type = 'AKAMAI';
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(): self
+ {
+ return new self;
+ }
+
+ /**
+ * @param 'AKAMAI' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter/CloudinaryURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter/CloudinaryURLRewriter.php
new file mode 100644
index 00000000..c4efdb70
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter/CloudinaryURLRewriter.php
@@ -0,0 +1,86 @@
+ */
+ use SdkModel;
+
+ /** @var 'CLOUDINARY' $type */
+ #[Required]
+ public string $type = 'CLOUDINARY';
+
+ /**
+ * Whether to preserve `/` in the rewritten URL.
+ */
+ #[Required]
+ public bool $preserveAssetDeliveryTypes;
+
+ /**
+ * `new CloudinaryURLRewriter()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * CloudinaryURLRewriter::with(preserveAssetDeliveryTypes: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new CloudinaryURLRewriter)->withPreserveAssetDeliveryTypes(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(bool $preserveAssetDeliveryTypes = false): self
+ {
+ $self = new self;
+
+ $self['preserveAssetDeliveryTypes'] = $preserveAssetDeliveryTypes;
+
+ return $self;
+ }
+
+ /**
+ * Whether to preserve `/` in the rewritten URL.
+ */
+ public function withPreserveAssetDeliveryTypes(
+ bool $preserveAssetDeliveryTypes
+ ): self {
+ $self = clone $this;
+ $self['preserveAssetDeliveryTypes'] = $preserveAssetDeliveryTypes;
+
+ return $self;
+ }
+
+ /**
+ * @param 'CLOUDINARY' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter/ImgixURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter/ImgixURLRewriter.php
new file mode 100644
index 00000000..e22b4dba
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointResponse/URLRewriter/ImgixURLRewriter.php
@@ -0,0 +1,48 @@
+ */
+ use SdkModel;
+
+ /** @var 'IMGIX' $type */
+ #[Required]
+ public string $type = 'IMGIX';
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(): self
+ {
+ return new self;
+ }
+
+ /**
+ * @param 'IMGIX' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointUpdateParams.php b/src/Accounts/URLEndpoints/URLEndpointUpdateParams.php
new file mode 100644
index 00000000..cfda6c3d
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointUpdateParams.php
@@ -0,0 +1,159 @@
+|null,
+ * urlPrefix?: string|null,
+ * urlRewriter?: URLRewriterShape|null,
+ * }
+ */
+final class URLEndpointUpdateParams implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+ use SdkParams;
+
+ /**
+ * Description of the URL endpoint.
+ */
+ #[Required]
+ public string $description;
+
+ /**
+ * Ordered list of origin IDs to try when the file isn’t in the Media Library; ImageKit checks them in the sequence provided. Origin must be created before it can be used in a URL endpoint.
+ *
+ * @var list|null $origins
+ */
+ #[Optional(list: 'string')]
+ public ?array $origins;
+
+ /**
+ * Path segment appended to your base URL to form the endpoint (letters, digits, and hyphens only — or empty for the default endpoint).
+ */
+ #[Optional]
+ public ?string $urlPrefix;
+
+ /**
+ * Configuration for third-party URL rewriting.
+ *
+ * @var URLRewriterVariants|null $urlRewriter
+ */
+ #[Optional(union: URLRewriter::class)]
+ public CloudinaryURLRewriter|ImgixURLRewriter|AkamaiURLRewriter|null $urlRewriter;
+
+ /**
+ * `new URLEndpointUpdateParams()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * URLEndpointUpdateParams::with(description: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new URLEndpointUpdateParams)->withDescription(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param list|null $origins
+ * @param URLRewriterShape|null $urlRewriter
+ */
+ public static function with(
+ string $description,
+ ?array $origins = null,
+ ?string $urlPrefix = null,
+ CloudinaryURLRewriter|array|ImgixURLRewriter|AkamaiURLRewriter|null $urlRewriter = null,
+ ): self {
+ $self = new self;
+
+ $self['description'] = $description;
+
+ null !== $origins && $self['origins'] = $origins;
+ null !== $urlPrefix && $self['urlPrefix'] = $urlPrefix;
+ null !== $urlRewriter && $self['urlRewriter'] = $urlRewriter;
+
+ return $self;
+ }
+
+ /**
+ * Description of the URL endpoint.
+ */
+ public function withDescription(string $description): self
+ {
+ $self = clone $this;
+ $self['description'] = $description;
+
+ return $self;
+ }
+
+ /**
+ * Ordered list of origin IDs to try when the file isn’t in the Media Library; ImageKit checks them in the sequence provided. Origin must be created before it can be used in a URL endpoint.
+ *
+ * @param list $origins
+ */
+ public function withOrigins(array $origins): self
+ {
+ $self = clone $this;
+ $self['origins'] = $origins;
+
+ return $self;
+ }
+
+ /**
+ * Path segment appended to your base URL to form the endpoint (letters, digits, and hyphens only — or empty for the default endpoint).
+ */
+ public function withURLPrefix(string $urlPrefix): self
+ {
+ $self = clone $this;
+ $self['urlPrefix'] = $urlPrefix;
+
+ return $self;
+ }
+
+ /**
+ * Configuration for third-party URL rewriting.
+ *
+ * @param URLRewriterShape $urlRewriter
+ */
+ public function withURLRewriter(
+ CloudinaryURLRewriter|array|ImgixURLRewriter|AkamaiURLRewriter $urlRewriter
+ ): self {
+ $self = clone $this;
+ $self['urlRewriter'] = $urlRewriter;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter.php
new file mode 100644
index 00000000..8b2661a1
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter.php
@@ -0,0 +1,44 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return [
+ 'CLOUDINARY' => CloudinaryURLRewriter::class,
+ 'IMGIX' => ImgixURLRewriter::class,
+ 'AKAMAI' => AkamaiURLRewriter::class,
+ ];
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter/AkamaiURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter/AkamaiURLRewriter.php
new file mode 100644
index 00000000..ad726587
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter/AkamaiURLRewriter.php
@@ -0,0 +1,48 @@
+ */
+ use SdkModel;
+
+ /** @var 'AKAMAI' $type */
+ #[Required]
+ public string $type = 'AKAMAI';
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(): self
+ {
+ return new self;
+ }
+
+ /**
+ * @param 'AKAMAI' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter/CloudinaryURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter/CloudinaryURLRewriter.php
new file mode 100644
index 00000000..7d42dda6
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter/CloudinaryURLRewriter.php
@@ -0,0 +1,73 @@
+ */
+ use SdkModel;
+
+ /** @var 'CLOUDINARY' $type */
+ #[Required]
+ public string $type = 'CLOUDINARY';
+
+ /**
+ * Whether to preserve `/` in the rewritten URL.
+ */
+ #[Optional]
+ public ?bool $preserveAssetDeliveryTypes;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(?bool $preserveAssetDeliveryTypes = null): self
+ {
+ $self = new self;
+
+ null !== $preserveAssetDeliveryTypes && $self['preserveAssetDeliveryTypes'] = $preserveAssetDeliveryTypes;
+
+ return $self;
+ }
+
+ /**
+ * @param 'CLOUDINARY' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * Whether to preserve `/` in the rewritten URL.
+ */
+ public function withPreserveAssetDeliveryTypes(
+ bool $preserveAssetDeliveryTypes
+ ): self {
+ $self = clone $this;
+ $self['preserveAssetDeliveryTypes'] = $preserveAssetDeliveryTypes;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter/ImgixURLRewriter.php b/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter/ImgixURLRewriter.php
new file mode 100644
index 00000000..21125d80
--- /dev/null
+++ b/src/Accounts/URLEndpoints/URLEndpointUpdateParams/URLRewriter/ImgixURLRewriter.php
@@ -0,0 +1,48 @@
+ */
+ use SdkModel;
+
+ /** @var 'IMGIX' $type */
+ #[Required]
+ public string $type = 'IMGIX';
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(): self
+ {
+ return new self;
+ }
+
+ /**
+ * @param 'IMGIX' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Usage/UsageGetParams.php b/src/Accounts/Usage/UsageGetParams.php
new file mode 100644
index 00000000..3c4f6064
--- /dev/null
+++ b/src/Accounts/Usage/UsageGetParams.php
@@ -0,0 +1,92 @@
+ */
+ use SdkModel;
+ use SdkParams;
+
+ /**
+ * Specify a `endDate` in `YYYY-MM-DD` format. It should be after the `startDate`. The difference between `startDate` and `endDate` should be less than 90 days.
+ */
+ #[Required]
+ public string $endDate;
+
+ /**
+ * Specify a `startDate` in `YYYY-MM-DD` format. It should be before the `endDate`. The difference between `startDate` and `endDate` should be less than 90 days.
+ */
+ #[Required]
+ public string $startDate;
+
+ /**
+ * `new UsageGetParams()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * UsageGetParams::with(endDate: ..., startDate: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new UsageGetParams)->withEndDate(...)->withStartDate(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(string $endDate, string $startDate): self
+ {
+ $self = new self;
+
+ $self['endDate'] = $endDate;
+ $self['startDate'] = $startDate;
+
+ return $self;
+ }
+
+ /**
+ * Specify a `endDate` in `YYYY-MM-DD` format. It should be after the `startDate`. The difference between `startDate` and `endDate` should be less than 90 days.
+ */
+ public function withEndDate(string $endDate): self
+ {
+ $self = clone $this;
+ $self['endDate'] = $endDate;
+
+ return $self;
+ }
+
+ /**
+ * Specify a `startDate` in `YYYY-MM-DD` format. It should be before the `endDate`. The difference between `startDate` and `endDate` should be less than 90 days.
+ */
+ public function withStartDate(string $startDate): self
+ {
+ $self = clone $this;
+ $self['startDate'] = $startDate;
+
+ return $self;
+ }
+}
diff --git a/src/Accounts/Usage/UsageGetResponse.php b/src/Accounts/Usage/UsageGetResponse.php
new file mode 100644
index 00000000..d6759c18
--- /dev/null
+++ b/src/Accounts/Usage/UsageGetResponse.php
@@ -0,0 +1,140 @@
+ */
+ use SdkModel;
+
+ /**
+ * Amount of bandwidth used in bytes.
+ */
+ #[Optional]
+ public ?int $bandwidthBytes;
+
+ /**
+ * Number of extension units used.
+ */
+ #[Optional]
+ public ?int $extensionUnitsCount;
+
+ /**
+ * Storage used by media library in bytes.
+ */
+ #[Optional]
+ public ?int $mediaLibraryStorageBytes;
+
+ /**
+ * Storage used by the original cache in bytes.
+ */
+ #[Optional]
+ public ?int $originalCacheStorageBytes;
+
+ /**
+ * Number of video processing units used.
+ */
+ #[Optional]
+ public ?int $videoProcessingUnitsCount;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ ?int $bandwidthBytes = null,
+ ?int $extensionUnitsCount = null,
+ ?int $mediaLibraryStorageBytes = null,
+ ?int $originalCacheStorageBytes = null,
+ ?int $videoProcessingUnitsCount = null,
+ ): self {
+ $self = new self;
+
+ null !== $bandwidthBytes && $self['bandwidthBytes'] = $bandwidthBytes;
+ null !== $extensionUnitsCount && $self['extensionUnitsCount'] = $extensionUnitsCount;
+ null !== $mediaLibraryStorageBytes && $self['mediaLibraryStorageBytes'] = $mediaLibraryStorageBytes;
+ null !== $originalCacheStorageBytes && $self['originalCacheStorageBytes'] = $originalCacheStorageBytes;
+ null !== $videoProcessingUnitsCount && $self['videoProcessingUnitsCount'] = $videoProcessingUnitsCount;
+
+ return $self;
+ }
+
+ /**
+ * Amount of bandwidth used in bytes.
+ */
+ public function withBandwidthBytes(int $bandwidthBytes): self
+ {
+ $self = clone $this;
+ $self['bandwidthBytes'] = $bandwidthBytes;
+
+ return $self;
+ }
+
+ /**
+ * Number of extension units used.
+ */
+ public function withExtensionUnitsCount(int $extensionUnitsCount): self
+ {
+ $self = clone $this;
+ $self['extensionUnitsCount'] = $extensionUnitsCount;
+
+ return $self;
+ }
+
+ /**
+ * Storage used by media library in bytes.
+ */
+ public function withMediaLibraryStorageBytes(
+ int $mediaLibraryStorageBytes
+ ): self {
+ $self = clone $this;
+ $self['mediaLibraryStorageBytes'] = $mediaLibraryStorageBytes;
+
+ return $self;
+ }
+
+ /**
+ * Storage used by the original cache in bytes.
+ */
+ public function withOriginalCacheStorageBytes(
+ int $originalCacheStorageBytes
+ ): self {
+ $self = clone $this;
+ $self['originalCacheStorageBytes'] = $originalCacheStorageBytes;
+
+ return $self;
+ }
+
+ /**
+ * Number of video processing units used.
+ */
+ public function withVideoProcessingUnitsCount(
+ int $videoProcessingUnitsCount
+ ): self {
+ $self = clone $this;
+ $self['videoProcessingUnitsCount'] = $videoProcessingUnitsCount;
+
+ return $self;
+ }
+}
diff --git a/src/Assets/AssetListParams.php b/src/Assets/AssetListParams.php
new file mode 100644
index 00000000..1d90f4b3
--- /dev/null
+++ b/src/Assets/AssetListParams.php
@@ -0,0 +1,242 @@
+,
+ * limit?: int|null,
+ * path?: string|null,
+ * searchQuery?: string|null,
+ * skip?: int|null,
+ * sort?: null|Sort|value-of,
+ * type?: null|Type|value-of,
+ * }
+ */
+final class AssetListParams implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+ use SdkParams;
+
+ /**
+ * Filter results by file type.
+ *
+ * - `all` — include all file types
+ * - `image` — include only image files
+ * - `non-image` — include only non-image files (e.g., JS, CSS, video)
+ *
+ * @var value-of|null $fileType
+ */
+ #[Optional(enum: FileType::class)]
+ public ?string $fileType;
+
+ /**
+ * The maximum number of results to return in response.
+ */
+ #[Optional]
+ public ?int $limit;
+
+ /**
+ * Folder path if you want to limit the search within a specific folder. For example, `/sales-banner/` will only search in folder sales-banner.
+ *
+ * Note : If your use case involves searching within a folder as well as its subfolders, you can use `path` parameter in `searchQuery` with appropriate operator.
+ * Checkout [Supported parameters](/docs/api-reference/digital-asset-management-dam/list-and-search-assets#supported-parameters) for more information.
+ */
+ #[Optional]
+ public ?string $path;
+
+ /**
+ * Query string in a Lucene-like query language e.g. `createdAt > "7d"`.
+ *
+ * Note : When the searchQuery parameter is present, the following query parameters will have no effect on the result:
+ *
+ * 1. `tags`
+ * 2. `type`
+ * 3. `name`
+ *
+ * [Learn more](/docs/api-reference/digital-asset-management-dam/list-and-search-assets#advanced-search-queries) from examples.
+ */
+ #[Optional]
+ public ?string $searchQuery;
+
+ /**
+ * The number of results to skip before returning results.
+ */
+ #[Optional]
+ public ?int $skip;
+
+ /**
+ * Sort the results by one of the supported fields in ascending or descending order.
+ *
+ * @var value-of|null $sort
+ */
+ #[Optional(enum: Sort::class)]
+ public ?string $sort;
+
+ /**
+ * Filter results by asset type.
+ *
+ * - `file` — returns only files
+ * - `file-version` — returns specific file versions
+ * - `folder` — returns only folders
+ * - `all` — returns both files and folders (excludes `file-version`)
+ *
+ * @var value-of|null $type
+ */
+ #[Optional(enum: Type::class)]
+ public ?string $type;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param FileType|value-of|null $fileType
+ * @param Sort|value-of|null $sort
+ * @param Type|value-of|null $type
+ */
+ public static function with(
+ FileType|string|null $fileType = null,
+ ?int $limit = null,
+ ?string $path = null,
+ ?string $searchQuery = null,
+ ?int $skip = null,
+ Sort|string|null $sort = null,
+ Type|string|null $type = null,
+ ): self {
+ $self = new self;
+
+ null !== $fileType && $self['fileType'] = $fileType;
+ null !== $limit && $self['limit'] = $limit;
+ null !== $path && $self['path'] = $path;
+ null !== $searchQuery && $self['searchQuery'] = $searchQuery;
+ null !== $skip && $self['skip'] = $skip;
+ null !== $sort && $self['sort'] = $sort;
+ null !== $type && $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * Filter results by file type.
+ *
+ * - `all` — include all file types
+ * - `image` — include only image files
+ * - `non-image` — include only non-image files (e.g., JS, CSS, video)
+ *
+ * @param FileType|value-of $fileType
+ */
+ public function withFileType(FileType|string $fileType): self
+ {
+ $self = clone $this;
+ $self['fileType'] = $fileType;
+
+ return $self;
+ }
+
+ /**
+ * The maximum number of results to return in response.
+ */
+ public function withLimit(int $limit): self
+ {
+ $self = clone $this;
+ $self['limit'] = $limit;
+
+ return $self;
+ }
+
+ /**
+ * Folder path if you want to limit the search within a specific folder. For example, `/sales-banner/` will only search in folder sales-banner.
+ *
+ * Note : If your use case involves searching within a folder as well as its subfolders, you can use `path` parameter in `searchQuery` with appropriate operator.
+ * Checkout [Supported parameters](/docs/api-reference/digital-asset-management-dam/list-and-search-assets#supported-parameters) for more information.
+ */
+ public function withPath(string $path): self
+ {
+ $self = clone $this;
+ $self['path'] = $path;
+
+ return $self;
+ }
+
+ /**
+ * Query string in a Lucene-like query language e.g. `createdAt > "7d"`.
+ *
+ * Note : When the searchQuery parameter is present, the following query parameters will have no effect on the result:
+ *
+ * 1. `tags`
+ * 2. `type`
+ * 3. `name`
+ *
+ * [Learn more](/docs/api-reference/digital-asset-management-dam/list-and-search-assets#advanced-search-queries) from examples.
+ */
+ public function withSearchQuery(string $searchQuery): self
+ {
+ $self = clone $this;
+ $self['searchQuery'] = $searchQuery;
+
+ return $self;
+ }
+
+ /**
+ * The number of results to skip before returning results.
+ */
+ public function withSkip(int $skip): self
+ {
+ $self = clone $this;
+ $self['skip'] = $skip;
+
+ return $self;
+ }
+
+ /**
+ * Sort the results by one of the supported fields in ascending or descending order.
+ *
+ * @param Sort|value-of $sort
+ */
+ public function withSort(Sort|string $sort): self
+ {
+ $self = clone $this;
+ $self['sort'] = $sort;
+
+ return $self;
+ }
+
+ /**
+ * Filter results by asset type.
+ *
+ * - `file` — returns only files
+ * - `file-version` — returns specific file versions
+ * - `folder` — returns only folders
+ * - `all` — returns both files and folders (excludes `file-version`)
+ *
+ * @param Type|value-of $type
+ */
+ public function withType(Type|string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+}
diff --git a/src/Assets/AssetListParams/FileType.php b/src/Assets/AssetListParams/FileType.php
new file mode 100644
index 00000000..8c812108
--- /dev/null
+++ b/src/Assets/AssetListParams/FileType.php
@@ -0,0 +1,21 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return [File::class, 'folder' => Folder::class];
+ }
+}
diff --git a/src/BaseOverlay.php b/src/BaseOverlay.php
new file mode 100644
index 00000000..2d1a6986
--- /dev/null
+++ b/src/BaseOverlay.php
@@ -0,0 +1,129 @@
+,
+ * position?: null|OverlayPosition|OverlayPositionShape,
+ * timing?: null|OverlayTiming|OverlayTimingShape,
+ * }
+ */
+final class BaseOverlay implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * Controls how the layer blends with the base image or underlying content. Maps to `lm` in the URL.
+ * By default, layers completely cover the base image beneath them. Layer modes change this behavior:
+ * - `multiply`: Multiplies the pixel values of the layer with the base image. The result is always darker than the original images. This is ideal for applying shadows or color tints.
+ * - `displace`: Uses the layer as a displacement map to distort pixels in the base image. The red channel controls horizontal displacement, and the green channel controls vertical displacement. Requires `x` or `y` parameter to control displacement magnitude.
+ * - `cutout`: Acts as an inverse mask where opaque areas of the layer turn the base image transparent, while transparent areas leave the base image unchanged. This mode functions like a hole-punch, effectively cutting the shape of the layer out of the underlying image.
+ * - `cutter`: Acts as a shape mask where only the parts of the base image that fall inside the opaque area of the layer are preserved. This mode functions like a cookie-cutter, trimming the base image to match the specific dimensions and shape of the layer.
+ * See [Layer modes](https://imagekit.io/docs/add-overlays-on-images#layer-modes).
+ *
+ * @var value-of|null $layerMode
+ */
+ #[Optional(enum: LayerMode::class)]
+ public ?string $layerMode;
+
+ /**
+ * Specifies the overlay's position relative to the parent asset.
+ * See [Position of Layer](https://imagekit.io/docs/transformations#position-of-layer).
+ */
+ #[Optional]
+ public ?OverlayPosition $position;
+
+ /**
+ * Specifies timing information for the overlay (only applicable if the base asset is a video).
+ * See [Position of Layer](https://imagekit.io/docs/transformations#position-of-layer).
+ */
+ #[Optional]
+ public ?OverlayTiming $timing;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param LayerMode|value-of|null $layerMode
+ * @param OverlayPosition|OverlayPositionShape|null $position
+ * @param OverlayTiming|OverlayTimingShape|null $timing
+ */
+ public static function with(
+ LayerMode|string|null $layerMode = null,
+ OverlayPosition|array|null $position = null,
+ OverlayTiming|array|null $timing = null,
+ ): self {
+ $self = new self;
+
+ null !== $layerMode && $self['layerMode'] = $layerMode;
+ null !== $position && $self['position'] = $position;
+ null !== $timing && $self['timing'] = $timing;
+
+ return $self;
+ }
+
+ /**
+ * Controls how the layer blends with the base image or underlying content. Maps to `lm` in the URL.
+ * By default, layers completely cover the base image beneath them. Layer modes change this behavior:
+ * - `multiply`: Multiplies the pixel values of the layer with the base image. The result is always darker than the original images. This is ideal for applying shadows or color tints.
+ * - `displace`: Uses the layer as a displacement map to distort pixels in the base image. The red channel controls horizontal displacement, and the green channel controls vertical displacement. Requires `x` or `y` parameter to control displacement magnitude.
+ * - `cutout`: Acts as an inverse mask where opaque areas of the layer turn the base image transparent, while transparent areas leave the base image unchanged. This mode functions like a hole-punch, effectively cutting the shape of the layer out of the underlying image.
+ * - `cutter`: Acts as a shape mask where only the parts of the base image that fall inside the opaque area of the layer are preserved. This mode functions like a cookie-cutter, trimming the base image to match the specific dimensions and shape of the layer.
+ * See [Layer modes](https://imagekit.io/docs/add-overlays-on-images#layer-modes).
+ *
+ * @param LayerMode|value-of $layerMode
+ */
+ public function withLayerMode(LayerMode|string $layerMode): self
+ {
+ $self = clone $this;
+ $self['layerMode'] = $layerMode;
+
+ return $self;
+ }
+
+ /**
+ * Specifies the overlay's position relative to the parent asset.
+ * See [Position of Layer](https://imagekit.io/docs/transformations#position-of-layer).
+ *
+ * @param OverlayPosition|OverlayPositionShape $position
+ */
+ public function withPosition(OverlayPosition|array $position): self
+ {
+ $self = clone $this;
+ $self['position'] = $position;
+
+ return $self;
+ }
+
+ /**
+ * Specifies timing information for the overlay (only applicable if the base asset is a video).
+ * See [Position of Layer](https://imagekit.io/docs/transformations#position-of-layer).
+ *
+ * @param OverlayTiming|OverlayTimingShape $timing
+ */
+ public function withTiming(OverlayTiming|array $timing): self
+ {
+ $self = clone $this;
+ $self['timing'] = $timing;
+
+ return $self;
+ }
+}
diff --git a/src/BaseOverlay/LayerMode.php b/src/BaseOverlay/LayerMode.php
new file mode 100644
index 00000000..8f40d2f6
--- /dev/null
+++ b/src/BaseOverlay/LayerMode.php
@@ -0,0 +1,25 @@
+|null,
+ * description?: string|null,
+ * extensions?: list|null,
+ * folder?: string|null,
+ * isPrivateFile?: bool|null,
+ * isPublished?: bool|null,
+ * overwriteAITags?: bool|null,
+ * overwriteCustomMetadata?: bool|null,
+ * overwriteFile?: bool|null,
+ * overwriteTags?: bool|null,
+ * responseFields?: list>|null,
+ * tags?: list|null,
+ * transformation?: null|Transformation|TransformationShape,
+ * useUniqueFileName?: bool|null,
+ * webhookURL?: string|null,
+ * }
+ */
+final class FileUploadParams implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+ use SdkParams;
+
+ /**
+ * The API accepts any of the following:
+ *
+ * - **Binary data** – send the raw bytes as `multipart/form-data`.
+ * - **HTTP / HTTPS URL** – a publicly reachable URL that ImageKit’s servers can fetch.
+ * - **Base64 string** – the file encoded as a Base64 data URI or plain Base64.
+ *
+ * When supplying a URL, the server must receive the response headers within 8 seconds; otherwise the request fails with 400 Bad Request.
+ */
+ #[Required]
+ public string $file;
+
+ /**
+ * The name with which the file has to be uploaded.
+ */
+ #[Required]
+ public string $fileName;
+
+ /**
+ * This is the client-generated JSON Web Token (JWT). The ImageKit.io server uses it to authenticate and check that the upload request parameters have not been tampered with after the token has been generated. Learn how to create the token on the page below. This field is only required for authentication when uploading a file from the client side.
+ *
+ * **Note**: Sending a JWT that has been used in the past will result in a validation error. Even if your previous request resulted in an error, you should always send a new token.
+ *
+ *
+ * **⚠️Warning**: JWT must be generated on the server-side because it is generated using your account's private API key. This field is required for authentication when uploading a file from the client-side.
+ */
+ #[Optional]
+ public ?string $token;
+
+ /**
+ * Server-side checks to run on the asset.
+ * Read more about [Upload API checks](/docs/api-reference/upload-file/upload-file-v2#upload-api-checks).
+ */
+ #[Optional]
+ public ?string $checks;
+
+ /**
+ * Define an important area in the image. This is only relevant for image type files.
+ *
+ * - To be passed as a string with the x and y coordinates of the top-left corner, and width and height of the area of interest in the format `x,y,width,height`. For example - `10,10,100,100`
+ * - Can be used with fo-customtransformation.
+ * - If this field is not specified and the file is overwritten, then customCoordinates will be removed.
+ */
+ #[Optional]
+ public ?string $customCoordinates;
+
+ /**
+ * JSON key-value pairs to associate with the asset. Create the custom metadata fields before setting these values.
+ *
+ * @var array|null $customMetadata
+ */
+ #[Optional(map: 'mixed')]
+ public ?array $customMetadata;
+
+ /**
+ * Optional text to describe the contents of the file.
+ */
+ #[Optional]
+ public ?string $description;
+
+ /**
+ * Array of extensions to be applied to the asset. Each extension can be configured with specific parameters based on the extension type.
+ *
+ * @var list|null $extensions
+ */
+ #[Optional(list: ExtensionItem::class)]
+ public ?array $extensions;
+
+ /**
+ * The folder path in which the image has to be uploaded. If the folder(s) didn't exist before, a new folder(s) is created. Using multiple `/` creates a nested folder.
+ */
+ #[Optional]
+ public ?string $folder;
+
+ /**
+ * Whether to mark the file as private or not.
+ *
+ * If `true`, the file is marked as private and is accessible only using named transformation or signed URL.
+ */
+ #[Optional]
+ public ?bool $isPrivateFile;
+
+ /**
+ * Whether to upload file as published or not.
+ *
+ * If `false`, the file is marked as unpublished, which restricts access to the file only via the media library. Files in draft or unpublished state can only be publicly accessed after being published.
+ *
+ * The option to upload in draft state is only available in custom enterprise pricing plans.
+ */
+ #[Optional]
+ public ?bool $isPublished;
+
+ /**
+ * If set to `true` and a file already exists at the exact location, its AITags will be removed. Set `overwriteAITags` to `false` to preserve AITags.
+ */
+ #[Optional]
+ public ?bool $overwriteAITags;
+
+ /**
+ * If the request does not have `customMetadata`, and a file already exists at the exact location, existing customMetadata will be removed.
+ */
+ #[Optional]
+ public ?bool $overwriteCustomMetadata;
+
+ /**
+ * If `false` and `useUniqueFileName` is also `false`, and a file already exists at the exact location, upload API will return an error immediately.
+ */
+ #[Optional]
+ public ?bool $overwriteFile;
+
+ /**
+ * If the request does not have `tags`, and a file already exists at the exact location, existing tags will be removed.
+ */
+ #[Optional]
+ public ?bool $overwriteTags;
+
+ /**
+ * Array of response field keys to include in the API response body.
+ *
+ * @var list>|null $responseFields
+ */
+ #[Optional(list: ResponseField::class)]
+ public ?array $responseFields;
+
+ /**
+ * Set the tags while uploading the file.
+ * Provide an array of tag strings (e.g. `["tag1", "tag2", "tag3"]`). The combined length of all tag characters must not exceed 500, and the `%` character is not allowed.
+ * If this field is not specified and the file is overwritten, the existing tags will be removed.
+ *
+ * @var list|null $tags
+ */
+ #[Optional(list: 'string')]
+ public ?array $tags;
+
+ /**
+ * Configure pre-processing (`pre`) and post-processing (`post`) transformations.
+ *
+ * - `pre` — applied before the file is uploaded to the Media Library.
+ * Useful for reducing file size or applying basic optimizations upfront (e.g., resize, compress).
+ *
+ * - `post` — applied immediately after upload.
+ * Ideal for generating transformed versions (like video encodes or thumbnails) in advance, so they're ready for delivery without delay.
+ *
+ * You can mix and match any combination of post-processing types.
+ */
+ #[Optional]
+ public ?Transformation $transformation;
+
+ /**
+ * Whether to use a unique filename for this file or not.
+ *
+ * If `true`, ImageKit.io will add a unique suffix to the filename parameter to get a unique filename.
+ *
+ * If `false`, then the image is uploaded with the provided filename parameter, and any existing file with the same name is replaced.
+ */
+ #[Optional]
+ public ?bool $useUniqueFileName;
+
+ /**
+ * The final status of extensions after they have completed execution will be delivered to this endpoint as a POST request. [Learn more](/docs/api-reference/digital-asset-management-dam/managing-assets/update-file-details#webhook-payload-structure) about the webhook payload structure.
+ */
+ #[Optional('webhookUrl')]
+ public ?string $webhookURL;
+
+ /**
+ * `new FileUploadParams()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * FileUploadParams::with(file: ..., fileName: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new FileUploadParams)->withFile(...)->withFileName(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param array|null $customMetadata
+ * @param list|null $extensions
+ * @param list>|null $responseFields
+ * @param list|null $tags
+ * @param Transformation|TransformationShape|null $transformation
+ */
+ public static function with(
+ string|FileParam $file,
+ string $fileName,
+ ?string $token = null,
+ ?string $checks = null,
+ ?string $customCoordinates = null,
+ ?array $customMetadata = null,
+ ?string $description = null,
+ ?array $extensions = null,
+ ?string $folder = null,
+ ?bool $isPrivateFile = null,
+ ?bool $isPublished = null,
+ ?bool $overwriteAITags = null,
+ ?bool $overwriteCustomMetadata = null,
+ ?bool $overwriteFile = null,
+ ?bool $overwriteTags = null,
+ ?array $responseFields = null,
+ ?array $tags = null,
+ Transformation|array|null $transformation = null,
+ ?bool $useUniqueFileName = null,
+ ?string $webhookURL = null,
+ ): self {
+ $self = new self;
+
+ $self['file'] = $file;
+ $self['fileName'] = $fileName;
+
+ null !== $token && $self['token'] = $token;
+ null !== $checks && $self['checks'] = $checks;
+ null !== $customCoordinates && $self['customCoordinates'] = $customCoordinates;
+ null !== $customMetadata && $self['customMetadata'] = $customMetadata;
+ null !== $description && $self['description'] = $description;
+ null !== $extensions && $self['extensions'] = $extensions;
+ null !== $folder && $self['folder'] = $folder;
+ null !== $isPrivateFile && $self['isPrivateFile'] = $isPrivateFile;
+ null !== $isPublished && $self['isPublished'] = $isPublished;
+ null !== $overwriteAITags && $self['overwriteAITags'] = $overwriteAITags;
+ null !== $overwriteCustomMetadata && $self['overwriteCustomMetadata'] = $overwriteCustomMetadata;
+ null !== $overwriteFile && $self['overwriteFile'] = $overwriteFile;
+ null !== $overwriteTags && $self['overwriteTags'] = $overwriteTags;
+ null !== $responseFields && $self['responseFields'] = $responseFields;
+ null !== $tags && $self['tags'] = $tags;
+ null !== $transformation && $self['transformation'] = $transformation;
+ null !== $useUniqueFileName && $self['useUniqueFileName'] = $useUniqueFileName;
+ null !== $webhookURL && $self['webhookURL'] = $webhookURL;
+
+ return $self;
+ }
+
+ /**
+ * The API accepts any of the following:
+ *
+ * - **Binary data** – send the raw bytes as `multipart/form-data`.
+ * - **HTTP / HTTPS URL** – a publicly reachable URL that ImageKit’s servers can fetch.
+ * - **Base64 string** – the file encoded as a Base64 data URI or plain Base64.
+ *
+ * When supplying a URL, the server must receive the response headers within 8 seconds; otherwise the request fails with 400 Bad Request.
+ */
+ public function withFile(string|FileParam $file): self
+ {
+ $self = clone $this;
+ $self['file'] = $file;
+
+ return $self;
+ }
+
+ /**
+ * The name with which the file has to be uploaded.
+ */
+ public function withFileName(string $fileName): self
+ {
+ $self = clone $this;
+ $self['fileName'] = $fileName;
+
+ return $self;
+ }
+
+ /**
+ * This is the client-generated JSON Web Token (JWT). The ImageKit.io server uses it to authenticate and check that the upload request parameters have not been tampered with after the token has been generated. Learn how to create the token on the page below. This field is only required for authentication when uploading a file from the client side.
+ *
+ * **Note**: Sending a JWT that has been used in the past will result in a validation error. Even if your previous request resulted in an error, you should always send a new token.
+ *
+ *
+ * **⚠️Warning**: JWT must be generated on the server-side because it is generated using your account's private API key. This field is required for authentication when uploading a file from the client-side.
+ */
+ public function withToken(string $token): self
+ {
+ $self = clone $this;
+ $self['token'] = $token;
+
+ return $self;
+ }
+
+ /**
+ * Server-side checks to run on the asset.
+ * Read more about [Upload API checks](/docs/api-reference/upload-file/upload-file-v2#upload-api-checks).
+ */
+ public function withChecks(string $checks): self
+ {
+ $self = clone $this;
+ $self['checks'] = $checks;
+
+ return $self;
+ }
+
+ /**
+ * Define an important area in the image. This is only relevant for image type files.
+ *
+ * - To be passed as a string with the x and y coordinates of the top-left corner, and width and height of the area of interest in the format `x,y,width,height`. For example - `10,10,100,100`
+ * - Can be used with fo-customtransformation.
+ * - If this field is not specified and the file is overwritten, then customCoordinates will be removed.
+ */
+ public function withCustomCoordinates(string $customCoordinates): self
+ {
+ $self = clone $this;
+ $self['customCoordinates'] = $customCoordinates;
+
+ return $self;
+ }
+
+ /**
+ * JSON key-value pairs to associate with the asset. Create the custom metadata fields before setting these values.
+ *
+ * @param array $customMetadata
+ */
+ public function withCustomMetadata(array $customMetadata): self
+ {
+ $self = clone $this;
+ $self['customMetadata'] = $customMetadata;
+
+ return $self;
+ }
+
+ /**
+ * Optional text to describe the contents of the file.
+ */
+ public function withDescription(string $description): self
+ {
+ $self = clone $this;
+ $self['description'] = $description;
+
+ return $self;
+ }
+
+ /**
+ * Array of extensions to be applied to the asset. Each extension can be configured with specific parameters based on the extension type.
+ *
+ * @param list $extensions
+ */
+ public function withExtensions(array $extensions): self
+ {
+ $self = clone $this;
+ $self['extensions'] = $extensions;
+
+ return $self;
+ }
+
+ /**
+ * The folder path in which the image has to be uploaded. If the folder(s) didn't exist before, a new folder(s) is created. Using multiple `/` creates a nested folder.
+ */
+ public function withFolder(string $folder): self
+ {
+ $self = clone $this;
+ $self['folder'] = $folder;
+
+ return $self;
+ }
+
+ /**
+ * Whether to mark the file as private or not.
+ *
+ * If `true`, the file is marked as private and is accessible only using named transformation or signed URL.
+ */
+ public function withIsPrivateFile(bool $isPrivateFile): self
+ {
+ $self = clone $this;
+ $self['isPrivateFile'] = $isPrivateFile;
+
+ return $self;
+ }
+
+ /**
+ * Whether to upload file as published or not.
+ *
+ * If `false`, the file is marked as unpublished, which restricts access to the file only via the media library. Files in draft or unpublished state can only be publicly accessed after being published.
+ *
+ * The option to upload in draft state is only available in custom enterprise pricing plans.
+ */
+ public function withIsPublished(bool $isPublished): self
+ {
+ $self = clone $this;
+ $self['isPublished'] = $isPublished;
+
+ return $self;
+ }
+
+ /**
+ * If set to `true` and a file already exists at the exact location, its AITags will be removed. Set `overwriteAITags` to `false` to preserve AITags.
+ */
+ public function withOverwriteAITags(bool $overwriteAITags): self
+ {
+ $self = clone $this;
+ $self['overwriteAITags'] = $overwriteAITags;
+
+ return $self;
+ }
+
+ /**
+ * If the request does not have `customMetadata`, and a file already exists at the exact location, existing customMetadata will be removed.
+ */
+ public function withOverwriteCustomMetadata(
+ bool $overwriteCustomMetadata
+ ): self {
+ $self = clone $this;
+ $self['overwriteCustomMetadata'] = $overwriteCustomMetadata;
+
+ return $self;
+ }
+
+ /**
+ * If `false` and `useUniqueFileName` is also `false`, and a file already exists at the exact location, upload API will return an error immediately.
+ */
+ public function withOverwriteFile(bool $overwriteFile): self
+ {
+ $self = clone $this;
+ $self['overwriteFile'] = $overwriteFile;
+
+ return $self;
+ }
+
+ /**
+ * If the request does not have `tags`, and a file already exists at the exact location, existing tags will be removed.
+ */
+ public function withOverwriteTags(bool $overwriteTags): self
+ {
+ $self = clone $this;
+ $self['overwriteTags'] = $overwriteTags;
+
+ return $self;
+ }
+
+ /**
+ * Array of response field keys to include in the API response body.
+ *
+ * @param list> $responseFields
+ */
+ public function withResponseFields(array $responseFields): self
+ {
+ $self = clone $this;
+ $self['responseFields'] = $responseFields;
+
+ return $self;
+ }
+
+ /**
+ * Set the tags while uploading the file.
+ * Provide an array of tag strings (e.g. `["tag1", "tag2", "tag3"]`). The combined length of all tag characters must not exceed 500, and the `%` character is not allowed.
+ * If this field is not specified and the file is overwritten, the existing tags will be removed.
+ *
+ * @param list $tags
+ */
+ public function withTags(array $tags): self
+ {
+ $self = clone $this;
+ $self['tags'] = $tags;
+
+ return $self;
+ }
+
+ /**
+ * Configure pre-processing (`pre`) and post-processing (`post`) transformations.
+ *
+ * - `pre` — applied before the file is uploaded to the Media Library.
+ * Useful for reducing file size or applying basic optimizations upfront (e.g., resize, compress).
+ *
+ * - `post` — applied immediately after upload.
+ * Ideal for generating transformed versions (like video encodes or thumbnails) in advance, so they're ready for delivery without delay.
+ *
+ * You can mix and match any combination of post-processing types.
+ *
+ * @param Transformation|TransformationShape $transformation
+ */
+ public function withTransformation(
+ Transformation|array $transformation
+ ): self {
+ $self = clone $this;
+ $self['transformation'] = $transformation;
+
+ return $self;
+ }
+
+ /**
+ * Whether to use a unique filename for this file or not.
+ *
+ * If `true`, ImageKit.io will add a unique suffix to the filename parameter to get a unique filename.
+ *
+ * If `false`, then the image is uploaded with the provided filename parameter, and any existing file with the same name is replaced.
+ */
+ public function withUseUniqueFileName(bool $useUniqueFileName): self
+ {
+ $self = clone $this;
+ $self['useUniqueFileName'] = $useUniqueFileName;
+
+ return $self;
+ }
+
+ /**
+ * The final status of extensions after they have completed execution will be delivered to this endpoint as a POST request. [Learn more](/docs/api-reference/digital-asset-management-dam/managing-assets/update-file-details#webhook-payload-structure) about the webhook payload structure.
+ */
+ public function withWebhookURL(string $webhookURL): self
+ {
+ $self = clone $this;
+ $self['webhookURL'] = $webhookURL;
+
+ return $self;
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadParams/ResponseField.php b/src/Beta/V2/Files/FileUploadParams/ResponseField.php
new file mode 100644
index 00000000..04a9aeb2
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadParams/ResponseField.php
@@ -0,0 +1,24 @@
+|null, pre?: string|null
+ * }
+ */
+final class Transformation implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * List of transformations to apply *after* the file is uploaded.
+ * Each item must match one of the following types:
+ * `transformation`, `gif-to-video`, `thumbnail`, `abs`.
+ *
+ * @var list|null $post
+ */
+ #[Optional(list: Post::class)]
+ public ?array $post;
+
+ /**
+ * Transformation string to apply before uploading the file to the Media Library. Useful for optimizing files at ingestion.
+ */
+ #[Optional]
+ public ?string $pre;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param list|null $post
+ */
+ public static function with(?array $post = null, ?string $pre = null): self
+ {
+ $self = new self;
+
+ null !== $post && $self['post'] = $post;
+ null !== $pre && $self['pre'] = $pre;
+
+ return $self;
+ }
+
+ /**
+ * List of transformations to apply *after* the file is uploaded.
+ * Each item must match one of the following types:
+ * `transformation`, `gif-to-video`, `thumbnail`, `abs`.
+ *
+ * @param list $post
+ */
+ public function withPost(array $post): self
+ {
+ $self = clone $this;
+ $self['post'] = $post;
+
+ return $self;
+ }
+
+ /**
+ * Transformation string to apply before uploading the file to the Media Library. Useful for optimizing files at ingestion.
+ */
+ public function withPre(string $pre): self
+ {
+ $self = clone $this;
+ $self['pre'] = $pre;
+
+ return $self;
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadParams/Transformation/Post.php b/src/Beta/V2/Files/FileUploadParams/Transformation/Post.php
new file mode 100644
index 00000000..6f82cf67
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadParams/Transformation/Post.php
@@ -0,0 +1,45 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return [
+ 'transformation' => SimplePostTransformation::class,
+ 'gif-to-video' => ConvertGifToVideo::class,
+ 'thumbnail' => GenerateAThumbnail::class,
+ 'abs' => AdaptiveBitrateStreaming::class,
+ ];
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadParams/Transformation/Post/AdaptiveBitrateStreaming.php b/src/Beta/V2/Files/FileUploadParams/Transformation/Post/AdaptiveBitrateStreaming.php
new file mode 100644
index 00000000..8223ea1b
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadParams/Transformation/Post/AdaptiveBitrateStreaming.php
@@ -0,0 +1,116 @@
+, type: 'abs', value: string
+ * }
+ */
+final class AdaptiveBitrateStreaming implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * Adaptive Bitrate Streaming (ABS) setup.
+ *
+ * @var 'abs' $type
+ */
+ #[Required]
+ public string $type = 'abs';
+
+ /**
+ * Streaming protocol to use (`hls` or `dash`).
+ *
+ * @var value-of $protocol
+ */
+ #[Required(enum: Protocol::class)]
+ public string $protocol;
+
+ /**
+ * List of different representations you want to create separated by an underscore.
+ */
+ #[Required]
+ public string $value;
+
+ /**
+ * `new AdaptiveBitrateStreaming()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * AdaptiveBitrateStreaming::with(protocol: ..., value: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new AdaptiveBitrateStreaming)->withProtocol(...)->withValue(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param Protocol|value-of $protocol
+ */
+ public static function with(Protocol|string $protocol, string $value): self
+ {
+ $self = new self;
+
+ $self['protocol'] = $protocol;
+ $self['value'] = $value;
+
+ return $self;
+ }
+
+ /**
+ * Streaming protocol to use (`hls` or `dash`).
+ *
+ * @param Protocol|value-of $protocol
+ */
+ public function withProtocol(Protocol|string $protocol): self
+ {
+ $self = clone $this;
+ $self['protocol'] = $protocol;
+
+ return $self;
+ }
+
+ /**
+ * Adaptive Bitrate Streaming (ABS) setup.
+ *
+ * @param 'abs' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * List of different representations you want to create separated by an underscore.
+ */
+ public function withValue(string $value): self
+ {
+ $self = clone $this;
+ $self['value'] = $value;
+
+ return $self;
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadParams/Transformation/Post/AdaptiveBitrateStreaming/Protocol.php b/src/Beta/V2/Files/FileUploadParams/Transformation/Post/AdaptiveBitrateStreaming/Protocol.php
new file mode 100644
index 00000000..9be027f5
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadParams/Transformation/Post/AdaptiveBitrateStreaming/Protocol.php
@@ -0,0 +1,15 @@
+ */
+ use SdkModel;
+
+ /**
+ * Converts an animated GIF into an MP4.
+ *
+ * @var 'gif-to-video' $type
+ */
+ #[Required]
+ public string $type = 'gif-to-video';
+
+ /**
+ * Optional transformation string to apply to the output video.
+ * **Example**: `q-80`.
+ */
+ #[Optional]
+ public ?string $value;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(?string $value = null): self
+ {
+ $self = new self;
+
+ null !== $value && $self['value'] = $value;
+
+ return $self;
+ }
+
+ /**
+ * Converts an animated GIF into an MP4.
+ *
+ * @param 'gif-to-video' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * Optional transformation string to apply to the output video.
+ * **Example**: `q-80`.
+ */
+ public function withValue(string $value): self
+ {
+ $self = clone $this;
+ $self['value'] = $value;
+
+ return $self;
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadParams/Transformation/Post/GenerateAThumbnail.php b/src/Beta/V2/Files/FileUploadParams/Transformation/Post/GenerateAThumbnail.php
new file mode 100644
index 00000000..23cf5ffb
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadParams/Transformation/Post/GenerateAThumbnail.php
@@ -0,0 +1,80 @@
+ */
+ use SdkModel;
+
+ /**
+ * Generates a thumbnail image.
+ *
+ * @var 'thumbnail' $type
+ */
+ #[Required]
+ public string $type = 'thumbnail';
+
+ /**
+ * Optional transformation string.
+ * **Example**: `w-150,h-150`.
+ */
+ #[Optional]
+ public ?string $value;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(?string $value = null): self
+ {
+ $self = new self;
+
+ null !== $value && $self['value'] = $value;
+
+ return $self;
+ }
+
+ /**
+ * Generates a thumbnail image.
+ *
+ * @param 'thumbnail' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * Optional transformation string.
+ * **Example**: `w-150,h-150`.
+ */
+ public function withValue(string $value): self
+ {
+ $self = clone $this;
+ $self['value'] = $value;
+
+ return $self;
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadParams/Transformation/Post/SimplePostTransformation.php b/src/Beta/V2/Files/FileUploadParams/Transformation/Post/SimplePostTransformation.php
new file mode 100644
index 00000000..bc515320
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadParams/Transformation/Post/SimplePostTransformation.php
@@ -0,0 +1,93 @@
+ */
+ use SdkModel;
+
+ /**
+ * Transformation type.
+ *
+ * @var 'transformation' $type
+ */
+ #[Required]
+ public string $type = 'transformation';
+
+ /**
+ * Transformation string (e.g. `w-200,h-200`).
+ * Same syntax as ImageKit URL-based transformations.
+ */
+ #[Required]
+ public string $value;
+
+ /**
+ * `new SimplePostTransformation()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * SimplePostTransformation::with(value: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new SimplePostTransformation)->withValue(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(string $value): self
+ {
+ $self = new self;
+
+ $self['value'] = $value;
+
+ return $self;
+ }
+
+ /**
+ * Transformation type.
+ *
+ * @param 'transformation' $type
+ */
+ public function withType(string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * Transformation string (e.g. `w-200,h-200`).
+ * Same syntax as ImageKit URL-based transformations.
+ */
+ public function withValue(string $value): self
+ {
+ $self = clone $this;
+ $self['value'] = $value;
+
+ return $self;
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadResponse.php b/src/Beta/V2/Files/FileUploadResponse.php
new file mode 100644
index 00000000..89f2316f
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadResponse.php
@@ -0,0 +1,606 @@
+|null,
+ * audioCodec?: string|null,
+ * bitRate?: int|null,
+ * customCoordinates?: string|null,
+ * customMetadata?: array|null,
+ * description?: string|null,
+ * duration?: int|null,
+ * embeddedMetadata?: array|null,
+ * extensionStatus?: null|ExtensionStatus|ExtensionStatusShape,
+ * fileID?: string|null,
+ * filePath?: string|null,
+ * fileType?: string|null,
+ * height?: float|null,
+ * isPrivateFile?: bool|null,
+ * isPublished?: bool|null,
+ * metadata?: null|Metadata|MetadataShape,
+ * name?: string|null,
+ * selectedFieldsSchema?: array|null,
+ * size?: float|null,
+ * tags?: list|null,
+ * thumbnailURL?: string|null,
+ * url?: string|null,
+ * versionInfo?: null|VersionInfo|VersionInfoShape,
+ * videoCodec?: string|null,
+ * width?: float|null,
+ * }
+ */
+final class FileUploadResponse implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * An array of tags assigned to the uploaded file by auto tagging.
+ *
+ * @var list|null $aiTags
+ */
+ #[Optional('AITags', list: AITag::class, nullable: true)]
+ public ?array $aiTags;
+
+ /**
+ * The audio codec used in the video (only for video).
+ */
+ #[Optional]
+ public ?string $audioCodec;
+
+ /**
+ * The bit rate of the video in kbps (only for video).
+ */
+ #[Optional]
+ public ?int $bitRate;
+
+ /**
+ * Value of custom coordinates associated with the image in the format `x,y,width,height`. If `customCoordinates` are not defined, then it is `null`. Send `customCoordinates` in `responseFields` in API request to get the value of this field.
+ */
+ #[Optional(nullable: true)]
+ public ?string $customCoordinates;
+
+ /**
+ * A key-value data associated with the asset. Use `responseField` in API request to get `customMetadata` in the upload API response. Before setting any custom metadata on an asset, you have to create the field using custom metadata fields API. Send `customMetadata` in `responseFields` in API request to get the value of this field.
+ *
+ * @var array|null $customMetadata
+ */
+ #[Optional(map: 'mixed')]
+ public ?array $customMetadata;
+
+ /**
+ * Optional text to describe the contents of the file. Can be set by the user or the ai-auto-description extension.
+ */
+ #[Optional]
+ public ?string $description;
+
+ /**
+ * The duration of the video in seconds (only for video).
+ */
+ #[Optional]
+ public ?int $duration;
+
+ /**
+ * Consolidated embedded metadata associated with the file. It includes exif, iptc, and xmp data. Send `embeddedMetadata` in `responseFields` in API request to get embeddedMetadata in the upload API response.
+ *
+ * @var array|null $embeddedMetadata
+ */
+ #[Optional(map: 'mixed')]
+ public ?array $embeddedMetadata;
+
+ /**
+ * Extension names with their processing status at the time of completion of the request. It could have one of the following status values:
+ *
+ * `success`: The extension has been successfully applied.
+ * `failed`: The extension has failed and will not be retried.
+ * `pending`: The extension will finish processing in some time. On completion, the final status (success / failed) will be sent to the `webhookUrl` provided.
+ *
+ * If no extension was requested, then this parameter is not returned.
+ */
+ #[Optional]
+ public ?ExtensionStatus $extensionStatus;
+
+ /**
+ * Unique fileId. Store this fileld in your database, as this will be used to perform update action on this file.
+ */
+ #[Optional('fileId')]
+ public ?string $fileID;
+
+ /**
+ * The relative path of the file in the media library e.g. `/marketing-assets/new-banner.jpg`.
+ */
+ #[Optional]
+ public ?string $filePath;
+
+ /**
+ * Type of the uploaded file. Possible values are `image`, `non-image`.
+ */
+ #[Optional]
+ public ?string $fileType;
+
+ /**
+ * Height of the image in pixels (Only for images).
+ */
+ #[Optional]
+ public ?float $height;
+
+ /**
+ * Is the file marked as private. It can be either `true` or `false`. Send `isPrivateFile` in `responseFields` in API request to get the value of this field.
+ */
+ #[Optional]
+ public ?bool $isPrivateFile;
+
+ /**
+ * Is the file published or in draft state. It can be either `true` or `false`. Send `isPublished` in `responseFields` in API request to get the value of this field.
+ */
+ #[Optional]
+ public ?bool $isPublished;
+
+ /**
+ * Legacy metadata. Send `metadata` in `responseFields` in API request to get metadata in the upload API response.
+ */
+ #[Optional]
+ public ?Metadata $metadata;
+
+ /**
+ * Name of the asset.
+ */
+ #[Optional]
+ public ?string $name;
+
+ /**
+ * This field is included in the response only if the Path policy feature is available in the plan.
+ * It contains schema definitions for the custom metadata fields selected for the specified file path.
+ * Field selection can only be done when the Path policy feature is enabled.
+ *
+ * Keys are the names of the custom metadata fields; the value object has details about the custom metadata schema.
+ *
+ * @var array|null $selectedFieldsSchema
+ */
+ #[Optional(map: SelectedFieldsSchema::class)]
+ public ?array $selectedFieldsSchema;
+
+ /**
+ * Size of the image file in Bytes.
+ */
+ #[Optional]
+ public ?float $size;
+
+ /**
+ * The array of tags associated with the asset. If no tags are set, it will be `null`. Send `tags` in `responseFields` in API request to get the value of this field.
+ *
+ * @var list|null $tags
+ */
+ #[Optional(list: 'string', nullable: true)]
+ public ?array $tags;
+
+ /**
+ * In the case of an image, a small thumbnail URL.
+ */
+ #[Optional('thumbnailUrl')]
+ public ?string $thumbnailURL;
+
+ /**
+ * A publicly accessible URL of the file.
+ */
+ #[Optional]
+ public ?string $url;
+
+ /**
+ * An object containing the file or file version's `id` (versionId) and `name`.
+ */
+ #[Optional]
+ public ?VersionInfo $versionInfo;
+
+ /**
+ * The video codec used in the video (only for video).
+ */
+ #[Optional]
+ public ?string $videoCodec;
+
+ /**
+ * Width of the image in pixels (Only for Images).
+ */
+ #[Optional]
+ public ?float $width;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param list|null $aiTags
+ * @param array|null $customMetadata
+ * @param array|null $embeddedMetadata
+ * @param ExtensionStatus|ExtensionStatusShape|null $extensionStatus
+ * @param Metadata|MetadataShape|null $metadata
+ * @param array|null $selectedFieldsSchema
+ * @param list|null $tags
+ * @param VersionInfo|VersionInfoShape|null $versionInfo
+ */
+ public static function with(
+ ?array $aiTags = null,
+ ?string $audioCodec = null,
+ ?int $bitRate = null,
+ ?string $customCoordinates = null,
+ ?array $customMetadata = null,
+ ?string $description = null,
+ ?int $duration = null,
+ ?array $embeddedMetadata = null,
+ ExtensionStatus|array|null $extensionStatus = null,
+ ?string $fileID = null,
+ ?string $filePath = null,
+ ?string $fileType = null,
+ ?float $height = null,
+ ?bool $isPrivateFile = null,
+ ?bool $isPublished = null,
+ Metadata|array|null $metadata = null,
+ ?string $name = null,
+ ?array $selectedFieldsSchema = null,
+ ?float $size = null,
+ ?array $tags = null,
+ ?string $thumbnailURL = null,
+ ?string $url = null,
+ VersionInfo|array|null $versionInfo = null,
+ ?string $videoCodec = null,
+ ?float $width = null,
+ ): self {
+ $self = new self;
+
+ null !== $aiTags && $self['aiTags'] = $aiTags;
+ null !== $audioCodec && $self['audioCodec'] = $audioCodec;
+ null !== $bitRate && $self['bitRate'] = $bitRate;
+ null !== $customCoordinates && $self['customCoordinates'] = $customCoordinates;
+ null !== $customMetadata && $self['customMetadata'] = $customMetadata;
+ null !== $description && $self['description'] = $description;
+ null !== $duration && $self['duration'] = $duration;
+ null !== $embeddedMetadata && $self['embeddedMetadata'] = $embeddedMetadata;
+ null !== $extensionStatus && $self['extensionStatus'] = $extensionStatus;
+ null !== $fileID && $self['fileID'] = $fileID;
+ null !== $filePath && $self['filePath'] = $filePath;
+ null !== $fileType && $self['fileType'] = $fileType;
+ null !== $height && $self['height'] = $height;
+ null !== $isPrivateFile && $self['isPrivateFile'] = $isPrivateFile;
+ null !== $isPublished && $self['isPublished'] = $isPublished;
+ null !== $metadata && $self['metadata'] = $metadata;
+ null !== $name && $self['name'] = $name;
+ null !== $selectedFieldsSchema && $self['selectedFieldsSchema'] = $selectedFieldsSchema;
+ null !== $size && $self['size'] = $size;
+ null !== $tags && $self['tags'] = $tags;
+ null !== $thumbnailURL && $self['thumbnailURL'] = $thumbnailURL;
+ null !== $url && $self['url'] = $url;
+ null !== $versionInfo && $self['versionInfo'] = $versionInfo;
+ null !== $videoCodec && $self['videoCodec'] = $videoCodec;
+ null !== $width && $self['width'] = $width;
+
+ return $self;
+ }
+
+ /**
+ * An array of tags assigned to the uploaded file by auto tagging.
+ *
+ * @param list|null $aiTags
+ */
+ public function withAITags(?array $aiTags): self
+ {
+ $self = clone $this;
+ $self['aiTags'] = $aiTags;
+
+ return $self;
+ }
+
+ /**
+ * The audio codec used in the video (only for video).
+ */
+ public function withAudioCodec(string $audioCodec): self
+ {
+ $self = clone $this;
+ $self['audioCodec'] = $audioCodec;
+
+ return $self;
+ }
+
+ /**
+ * The bit rate of the video in kbps (only for video).
+ */
+ public function withBitRate(int $bitRate): self
+ {
+ $self = clone $this;
+ $self['bitRate'] = $bitRate;
+
+ return $self;
+ }
+
+ /**
+ * Value of custom coordinates associated with the image in the format `x,y,width,height`. If `customCoordinates` are not defined, then it is `null`. Send `customCoordinates` in `responseFields` in API request to get the value of this field.
+ */
+ public function withCustomCoordinates(?string $customCoordinates): self
+ {
+ $self = clone $this;
+ $self['customCoordinates'] = $customCoordinates;
+
+ return $self;
+ }
+
+ /**
+ * A key-value data associated with the asset. Use `responseField` in API request to get `customMetadata` in the upload API response. Before setting any custom metadata on an asset, you have to create the field using custom metadata fields API. Send `customMetadata` in `responseFields` in API request to get the value of this field.
+ *
+ * @param array $customMetadata
+ */
+ public function withCustomMetadata(array $customMetadata): self
+ {
+ $self = clone $this;
+ $self['customMetadata'] = $customMetadata;
+
+ return $self;
+ }
+
+ /**
+ * Optional text to describe the contents of the file. Can be set by the user or the ai-auto-description extension.
+ */
+ public function withDescription(string $description): self
+ {
+ $self = clone $this;
+ $self['description'] = $description;
+
+ return $self;
+ }
+
+ /**
+ * The duration of the video in seconds (only for video).
+ */
+ public function withDuration(int $duration): self
+ {
+ $self = clone $this;
+ $self['duration'] = $duration;
+
+ return $self;
+ }
+
+ /**
+ * Consolidated embedded metadata associated with the file. It includes exif, iptc, and xmp data. Send `embeddedMetadata` in `responseFields` in API request to get embeddedMetadata in the upload API response.
+ *
+ * @param array $embeddedMetadata
+ */
+ public function withEmbeddedMetadata(array $embeddedMetadata): self
+ {
+ $self = clone $this;
+ $self['embeddedMetadata'] = $embeddedMetadata;
+
+ return $self;
+ }
+
+ /**
+ * Extension names with their processing status at the time of completion of the request. It could have one of the following status values:
+ *
+ * `success`: The extension has been successfully applied.
+ * `failed`: The extension has failed and will not be retried.
+ * `pending`: The extension will finish processing in some time. On completion, the final status (success / failed) will be sent to the `webhookUrl` provided.
+ *
+ * If no extension was requested, then this parameter is not returned.
+ *
+ * @param ExtensionStatus|ExtensionStatusShape $extensionStatus
+ */
+ public function withExtensionStatus(
+ ExtensionStatus|array $extensionStatus
+ ): self {
+ $self = clone $this;
+ $self['extensionStatus'] = $extensionStatus;
+
+ return $self;
+ }
+
+ /**
+ * Unique fileId. Store this fileld in your database, as this will be used to perform update action on this file.
+ */
+ public function withFileID(string $fileID): self
+ {
+ $self = clone $this;
+ $self['fileID'] = $fileID;
+
+ return $self;
+ }
+
+ /**
+ * The relative path of the file in the media library e.g. `/marketing-assets/new-banner.jpg`.
+ */
+ public function withFilePath(string $filePath): self
+ {
+ $self = clone $this;
+ $self['filePath'] = $filePath;
+
+ return $self;
+ }
+
+ /**
+ * Type of the uploaded file. Possible values are `image`, `non-image`.
+ */
+ public function withFileType(string $fileType): self
+ {
+ $self = clone $this;
+ $self['fileType'] = $fileType;
+
+ return $self;
+ }
+
+ /**
+ * Height of the image in pixels (Only for images).
+ */
+ public function withHeight(float $height): self
+ {
+ $self = clone $this;
+ $self['height'] = $height;
+
+ return $self;
+ }
+
+ /**
+ * Is the file marked as private. It can be either `true` or `false`. Send `isPrivateFile` in `responseFields` in API request to get the value of this field.
+ */
+ public function withIsPrivateFile(bool $isPrivateFile): self
+ {
+ $self = clone $this;
+ $self['isPrivateFile'] = $isPrivateFile;
+
+ return $self;
+ }
+
+ /**
+ * Is the file published or in draft state. It can be either `true` or `false`. Send `isPublished` in `responseFields` in API request to get the value of this field.
+ */
+ public function withIsPublished(bool $isPublished): self
+ {
+ $self = clone $this;
+ $self['isPublished'] = $isPublished;
+
+ return $self;
+ }
+
+ /**
+ * Legacy metadata. Send `metadata` in `responseFields` in API request to get metadata in the upload API response.
+ *
+ * @param Metadata|MetadataShape $metadata
+ */
+ public function withMetadata(Metadata|array $metadata): self
+ {
+ $self = clone $this;
+ $self['metadata'] = $metadata;
+
+ return $self;
+ }
+
+ /**
+ * Name of the asset.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * This field is included in the response only if the Path policy feature is available in the plan.
+ * It contains schema definitions for the custom metadata fields selected for the specified file path.
+ * Field selection can only be done when the Path policy feature is enabled.
+ *
+ * Keys are the names of the custom metadata fields; the value object has details about the custom metadata schema.
+ *
+ * @param array $selectedFieldsSchema
+ */
+ public function withSelectedFieldsSchema(array $selectedFieldsSchema): self
+ {
+ $self = clone $this;
+ $self['selectedFieldsSchema'] = $selectedFieldsSchema;
+
+ return $self;
+ }
+
+ /**
+ * Size of the image file in Bytes.
+ */
+ public function withSize(float $size): self
+ {
+ $self = clone $this;
+ $self['size'] = $size;
+
+ return $self;
+ }
+
+ /**
+ * The array of tags associated with the asset. If no tags are set, it will be `null`. Send `tags` in `responseFields` in API request to get the value of this field.
+ *
+ * @param list|null $tags
+ */
+ public function withTags(?array $tags): self
+ {
+ $self = clone $this;
+ $self['tags'] = $tags;
+
+ return $self;
+ }
+
+ /**
+ * In the case of an image, a small thumbnail URL.
+ */
+ public function withThumbnailURL(string $thumbnailURL): self
+ {
+ $self = clone $this;
+ $self['thumbnailURL'] = $thumbnailURL;
+
+ return $self;
+ }
+
+ /**
+ * A publicly accessible URL of the file.
+ */
+ public function withURL(string $url): self
+ {
+ $self = clone $this;
+ $self['url'] = $url;
+
+ return $self;
+ }
+
+ /**
+ * An object containing the file or file version's `id` (versionId) and `name`.
+ *
+ * @param VersionInfo|VersionInfoShape $versionInfo
+ */
+ public function withVersionInfo(VersionInfo|array $versionInfo): self
+ {
+ $self = clone $this;
+ $self['versionInfo'] = $versionInfo;
+
+ return $self;
+ }
+
+ /**
+ * The video codec used in the video (only for video).
+ */
+ public function withVideoCodec(string $videoCodec): self
+ {
+ $self = clone $this;
+ $self['videoCodec'] = $videoCodec;
+
+ return $self;
+ }
+
+ /**
+ * Width of the image in pixels (Only for Images).
+ */
+ public function withWidth(float $width): self
+ {
+ $self = clone $this;
+ $self['width'] = $width;
+
+ return $self;
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadResponse/AITag.php b/src/Beta/V2/Files/FileUploadResponse/AITag.php
new file mode 100644
index 00000000..f137fa84
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadResponse/AITag.php
@@ -0,0 +1,97 @@
+ */
+ use SdkModel;
+
+ /**
+ * Confidence score of the tag.
+ */
+ #[Optional]
+ public ?float $confidence;
+
+ /**
+ * Name of the tag.
+ */
+ #[Optional]
+ public ?string $name;
+
+ /**
+ * Source of the tag. Possible values are `google-auto-tagging` and `aws-auto-tagging`.
+ */
+ #[Optional]
+ public ?string $source;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ ?float $confidence = null,
+ ?string $name = null,
+ ?string $source = null
+ ): self {
+ $self = new self;
+
+ null !== $confidence && $self['confidence'] = $confidence;
+ null !== $name && $self['name'] = $name;
+ null !== $source && $self['source'] = $source;
+
+ return $self;
+ }
+
+ /**
+ * Confidence score of the tag.
+ */
+ public function withConfidence(float $confidence): self
+ {
+ $self = clone $this;
+ $self['confidence'] = $confidence;
+
+ return $self;
+ }
+
+ /**
+ * Name of the tag.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Source of the tag. Possible values are `google-auto-tagging` and `aws-auto-tagging`.
+ */
+ public function withSource(string $source): self
+ {
+ $self = clone $this;
+ $self['source'] = $source;
+
+ return $self;
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadResponse/ExtensionStatus.php b/src/Beta/V2/Files/FileUploadResponse/ExtensionStatus.php
new file mode 100644
index 00000000..1cee1cbd
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadResponse/ExtensionStatus.php
@@ -0,0 +1,149 @@
+,
+ * aiTasks?: null|AITasks|value-of,
+ * awsAutoTagging?: null|AwsAutoTagging|value-of,
+ * googleAutoTagging?: null|GoogleAutoTagging|value-of,
+ * removeBg?: null|RemoveBg|value-of,
+ * }
+ */
+final class ExtensionStatus implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /** @var value-of|null $aiAutoDescription */
+ #[Optional('ai-auto-description', enum: AIAutoDescription::class)]
+ public ?string $aiAutoDescription;
+
+ /** @var value-of|null $aiTasks */
+ #[Optional('ai-tasks', enum: AITasks::class)]
+ public ?string $aiTasks;
+
+ /** @var value-of|null $awsAutoTagging */
+ #[Optional('aws-auto-tagging', enum: AwsAutoTagging::class)]
+ public ?string $awsAutoTagging;
+
+ /** @var value-of|null $googleAutoTagging */
+ #[Optional('google-auto-tagging', enum: GoogleAutoTagging::class)]
+ public ?string $googleAutoTagging;
+
+ /** @var value-of|null $removeBg */
+ #[Optional('remove-bg', enum: RemoveBg::class)]
+ public ?string $removeBg;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param AIAutoDescription|value-of|null $aiAutoDescription
+ * @param AITasks|value-of|null $aiTasks
+ * @param AwsAutoTagging|value-of|null $awsAutoTagging
+ * @param GoogleAutoTagging|value-of|null $googleAutoTagging
+ * @param RemoveBg|value-of|null $removeBg
+ */
+ public static function with(
+ AIAutoDescription|string|null $aiAutoDescription = null,
+ AITasks|string|null $aiTasks = null,
+ AwsAutoTagging|string|null $awsAutoTagging = null,
+ GoogleAutoTagging|string|null $googleAutoTagging = null,
+ RemoveBg|string|null $removeBg = null,
+ ): self {
+ $self = new self;
+
+ null !== $aiAutoDescription && $self['aiAutoDescription'] = $aiAutoDescription;
+ null !== $aiTasks && $self['aiTasks'] = $aiTasks;
+ null !== $awsAutoTagging && $self['awsAutoTagging'] = $awsAutoTagging;
+ null !== $googleAutoTagging && $self['googleAutoTagging'] = $googleAutoTagging;
+ null !== $removeBg && $self['removeBg'] = $removeBg;
+
+ return $self;
+ }
+
+ /**
+ * @param AIAutoDescription|value-of $aiAutoDescription
+ */
+ public function withAIAutoDescription(
+ AIAutoDescription|string $aiAutoDescription
+ ): self {
+ $self = clone $this;
+ $self['aiAutoDescription'] = $aiAutoDescription;
+
+ return $self;
+ }
+
+ /**
+ * @param AITasks|value-of $aiTasks
+ */
+ public function withAITasks(AITasks|string $aiTasks): self
+ {
+ $self = clone $this;
+ $self['aiTasks'] = $aiTasks;
+
+ return $self;
+ }
+
+ /**
+ * @param AwsAutoTagging|value-of $awsAutoTagging
+ */
+ public function withAwsAutoTagging(
+ AwsAutoTagging|string $awsAutoTagging
+ ): self {
+ $self = clone $this;
+ $self['awsAutoTagging'] = $awsAutoTagging;
+
+ return $self;
+ }
+
+ /**
+ * @param GoogleAutoTagging|value-of $googleAutoTagging
+ */
+ public function withGoogleAutoTagging(
+ GoogleAutoTagging|string $googleAutoTagging
+ ): self {
+ $self = clone $this;
+ $self['googleAutoTagging'] = $googleAutoTagging;
+
+ return $self;
+ }
+
+ /**
+ * @param RemoveBg|value-of $removeBg
+ */
+ public function withRemoveBg(RemoveBg|string $removeBg): self
+ {
+ $self = clone $this;
+ $self['removeBg'] = $removeBg;
+
+ return $self;
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadResponse/ExtensionStatus/AIAutoDescription.php b/src/Beta/V2/Files/FileUploadResponse/ExtensionStatus/AIAutoDescription.php
new file mode 100644
index 00000000..c38a0dcf
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadResponse/ExtensionStatus/AIAutoDescription.php
@@ -0,0 +1,14 @@
+,
+ * defaultValue?: DefaultValueShape|null,
+ * isValueRequired?: bool|null,
+ * maxLength?: float|null,
+ * maxValue?: MaxValueShape|null,
+ * minLength?: float|null,
+ * minValue?: MinValueShape|null,
+ * readOnly?: bool|null,
+ * selectOptions?: list|null,
+ * selectOptionsTruncated?: bool|null,
+ * }
+ */
+final class SelectedFieldsSchema implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * Type of the custom metadata field.
+ *
+ * @var value-of $type
+ */
+ #[Required(enum: Type::class)]
+ public string $type;
+
+ /**
+ * The default value for this custom metadata field. The value should match the `type` of custom metadata field.
+ *
+ * @var DefaultValueVariants|null $defaultValue
+ */
+ #[Optional(union: DefaultValue::class)]
+ public string|float|bool|array|null $defaultValue;
+
+ /**
+ * Specifies if the custom metadata field is required or not.
+ */
+ #[Optional]
+ public ?bool $isValueRequired;
+
+ /**
+ * Maximum length of string. Only set if `type` is set to `Text` or `Textarea`.
+ */
+ #[Optional]
+ public ?float $maxLength;
+
+ /**
+ * Maximum value of the field. Only set if field type is `Date` or `Number`. For `Date` type field, the value will be in ISO8601 string format. For `Number` type field, it will be a numeric value.
+ *
+ * @var MaxValueVariants|null $maxValue
+ */
+ #[Optional]
+ public string|float|null $maxValue;
+
+ /**
+ * Minimum length of string. Only set if `type` is set to `Text` or `Textarea`.
+ */
+ #[Optional]
+ public ?float $minLength;
+
+ /**
+ * Minimum value of the field. Only set if field type is `Date` or `Number`. For `Date` type field, the value will be in ISO8601 string format. For `Number` type field, it will be a numeric value.
+ *
+ * @var MinValueVariants|null $minValue
+ */
+ #[Optional]
+ public string|float|null $minValue;
+
+ /**
+ * Indicates whether the custom metadata field is read only. A read only field cannot be modified after being set. This field is configurable only via the **Path policy** feature.
+ */
+ #[Optional]
+ public ?bool $readOnly;
+
+ /**
+ * An array of allowed values when field type is `SingleSelect` or `MultiSelect`.
+ *
+ * @var list|null $selectOptions
+ */
+ #[Optional(list: SelectOption::class)]
+ public ?array $selectOptions;
+
+ /**
+ * Specifies if the selectOptions array is truncated. It is truncated when number of options are > 100.
+ */
+ #[Optional]
+ public ?bool $selectOptionsTruncated;
+
+ /**
+ * `new SelectedFieldsSchema()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * SelectedFieldsSchema::with(type: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new SelectedFieldsSchema)->withType(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param Type|value-of $type
+ * @param DefaultValueShape|null $defaultValue
+ * @param MaxValueShape|null $maxValue
+ * @param MinValueShape|null $minValue
+ * @param list|null $selectOptions
+ */
+ public static function with(
+ Type|string $type,
+ string|float|bool|array|null $defaultValue = null,
+ ?bool $isValueRequired = null,
+ ?float $maxLength = null,
+ string|float|null $maxValue = null,
+ ?float $minLength = null,
+ string|float|null $minValue = null,
+ ?bool $readOnly = null,
+ ?array $selectOptions = null,
+ ?bool $selectOptionsTruncated = null,
+ ): self {
+ $self = new self;
+
+ $self['type'] = $type;
+
+ null !== $defaultValue && $self['defaultValue'] = $defaultValue;
+ null !== $isValueRequired && $self['isValueRequired'] = $isValueRequired;
+ null !== $maxLength && $self['maxLength'] = $maxLength;
+ null !== $maxValue && $self['maxValue'] = $maxValue;
+ null !== $minLength && $self['minLength'] = $minLength;
+ null !== $minValue && $self['minValue'] = $minValue;
+ null !== $readOnly && $self['readOnly'] = $readOnly;
+ null !== $selectOptions && $self['selectOptions'] = $selectOptions;
+ null !== $selectOptionsTruncated && $self['selectOptionsTruncated'] = $selectOptionsTruncated;
+
+ return $self;
+ }
+
+ /**
+ * Type of the custom metadata field.
+ *
+ * @param Type|value-of $type
+ */
+ public function withType(Type|string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * The default value for this custom metadata field. The value should match the `type` of custom metadata field.
+ *
+ * @param DefaultValueShape $defaultValue
+ */
+ public function withDefaultValue(
+ string|float|bool|array $defaultValue
+ ): self {
+ $self = clone $this;
+ $self['defaultValue'] = $defaultValue;
+
+ return $self;
+ }
+
+ /**
+ * Specifies if the custom metadata field is required or not.
+ */
+ public function withIsValueRequired(bool $isValueRequired): self
+ {
+ $self = clone $this;
+ $self['isValueRequired'] = $isValueRequired;
+
+ return $self;
+ }
+
+ /**
+ * Maximum length of string. Only set if `type` is set to `Text` or `Textarea`.
+ */
+ public function withMaxLength(float $maxLength): self
+ {
+ $self = clone $this;
+ $self['maxLength'] = $maxLength;
+
+ return $self;
+ }
+
+ /**
+ * Maximum value of the field. Only set if field type is `Date` or `Number`. For `Date` type field, the value will be in ISO8601 string format. For `Number` type field, it will be a numeric value.
+ *
+ * @param MaxValueShape $maxValue
+ */
+ public function withMaxValue(string|float $maxValue): self
+ {
+ $self = clone $this;
+ $self['maxValue'] = $maxValue;
+
+ return $self;
+ }
+
+ /**
+ * Minimum length of string. Only set if `type` is set to `Text` or `Textarea`.
+ */
+ public function withMinLength(float $minLength): self
+ {
+ $self = clone $this;
+ $self['minLength'] = $minLength;
+
+ return $self;
+ }
+
+ /**
+ * Minimum value of the field. Only set if field type is `Date` or `Number`. For `Date` type field, the value will be in ISO8601 string format. For `Number` type field, it will be a numeric value.
+ *
+ * @param MinValueShape $minValue
+ */
+ public function withMinValue(string|float $minValue): self
+ {
+ $self = clone $this;
+ $self['minValue'] = $minValue;
+
+ return $self;
+ }
+
+ /**
+ * Indicates whether the custom metadata field is read only. A read only field cannot be modified after being set. This field is configurable only via the **Path policy** feature.
+ */
+ public function withReadOnly(bool $readOnly): self
+ {
+ $self = clone $this;
+ $self['readOnly'] = $readOnly;
+
+ return $self;
+ }
+
+ /**
+ * An array of allowed values when field type is `SingleSelect` or `MultiSelect`.
+ *
+ * @param list $selectOptions
+ */
+ public function withSelectOptions(array $selectOptions): self
+ {
+ $self = clone $this;
+ $self['selectOptions'] = $selectOptions;
+
+ return $self;
+ }
+
+ /**
+ * Specifies if the selectOptions array is truncated. It is truncated when number of options are > 100.
+ */
+ public function withSelectOptionsTruncated(
+ bool $selectOptionsTruncated
+ ): self {
+ $self = clone $this;
+ $self['selectOptionsTruncated'] = $selectOptionsTruncated;
+
+ return $self;
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/DefaultValue.php b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/DefaultValue.php
new file mode 100644
index 00000000..6a8628ea
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/DefaultValue.php
@@ -0,0 +1,32 @@
+
+ * @phpstan-type DefaultValueShape = DefaultValueVariants|list
+ */
+final class DefaultValue implements ConverterSource
+{
+ use SdkUnion;
+
+ /**
+ * @return list|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float', 'bool', new ListOf(Mixed_::class)];
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/DefaultValue/Mixed_.php b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/DefaultValue/Mixed_.php
new file mode 100644
index 00000000..eb226022
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/DefaultValue/Mixed_.php
@@ -0,0 +1,26 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float', 'bool'];
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/MaxValue.php b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/MaxValue.php
new file mode 100644
index 00000000..e9a4ab2c
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/MaxValue.php
@@ -0,0 +1,28 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float'];
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/MinValue.php b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/MinValue.php
new file mode 100644
index 00000000..8bde7ef4
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/MinValue.php
@@ -0,0 +1,28 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float'];
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/SelectOption.php b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/SelectOption.php
new file mode 100644
index 00000000..9f95d64a
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/SelectOption.php
@@ -0,0 +1,26 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float', 'bool'];
+ }
+}
diff --git a/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/Type.php b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/Type.php
new file mode 100644
index 00000000..e41d977e
--- /dev/null
+++ b/src/Beta/V2/Files/FileUploadResponse/SelectedFieldsSchema/Type.php
@@ -0,0 +1,25 @@
+ */
+ use SdkModel;
+
+ /**
+ * Unique identifier of the file version.
+ */
+ #[Optional]
+ public ?string $id;
+
+ /**
+ * Name of the file version.
+ */
+ #[Optional]
+ public ?string $name;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(?string $id = null, ?string $name = null): self
+ {
+ $self = new self;
+
+ null !== $id && $self['id'] = $id;
+ null !== $name && $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier of the file version.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ /**
+ * Name of the file version.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+}
diff --git a/src/Cache/Invalidation/InvalidationCreateParams.php b/src/Cache/Invalidation/InvalidationCreateParams.php
new file mode 100644
index 00000000..360e19c8
--- /dev/null
+++ b/src/Cache/Invalidation/InvalidationCreateParams.php
@@ -0,0 +1,74 @@
+ */
+ use SdkModel;
+ use SdkParams;
+
+ /**
+ * The full URL of the file to be purged.
+ */
+ #[Required]
+ public string $url;
+
+ /**
+ * `new InvalidationCreateParams()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * InvalidationCreateParams::with(url: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new InvalidationCreateParams)->withURL(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(string $url): self
+ {
+ $self = new self;
+
+ $self['url'] = $url;
+
+ return $self;
+ }
+
+ /**
+ * The full URL of the file to be purged.
+ */
+ public function withURL(string $url): self
+ {
+ $self = clone $this;
+ $self['url'] = $url;
+
+ return $self;
+ }
+}
diff --git a/src/Cache/Invalidation/InvalidationGetResponse.php b/src/Cache/Invalidation/InvalidationGetResponse.php
new file mode 100644
index 00000000..185a5189
--- /dev/null
+++ b/src/Cache/Invalidation/InvalidationGetResponse.php
@@ -0,0 +1,63 @@
+
+ * }
+ */
+final class InvalidationGetResponse implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * Status of the purge request.
+ *
+ * @var value-of|null $status
+ */
+ #[Optional(enum: Status::class)]
+ public ?string $status;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param Status|value-of|null $status
+ */
+ public static function with(Status|string|null $status = null): self
+ {
+ $self = new self;
+
+ null !== $status && $self['status'] = $status;
+
+ return $self;
+ }
+
+ /**
+ * Status of the purge request.
+ *
+ * @param Status|value-of $status
+ */
+ public function withStatus(Status|string $status): self
+ {
+ $self = clone $this;
+ $self['status'] = $status;
+
+ return $self;
+ }
+}
diff --git a/src/Cache/Invalidation/InvalidationGetResponse/Status.php b/src/Cache/Invalidation/InvalidationGetResponse/Status.php
new file mode 100644
index 00000000..3b72a61a
--- /dev/null
+++ b/src/Cache/Invalidation/InvalidationGetResponse/Status.php
@@ -0,0 +1,15 @@
+ */
+ use SdkModel;
+
+ /**
+ * Unique identifier of the purge request. This can be used to check the status of the purge request.
+ */
+ #[Optional('requestId')]
+ public ?string $requestID;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(?string $requestID = null): self
+ {
+ $self = new self;
+
+ null !== $requestID && $self['requestID'] = $requestID;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier of the purge request. This can be used to check the status of the purge request.
+ */
+ public function withRequestID(string $requestID): self
+ {
+ $self = clone $this;
+ $self['requestID'] = $requestID;
+
+ return $self;
+ }
+}
diff --git a/src/Client.php b/src/Client.php
new file mode 100644
index 00000000..86d08ed0
--- /dev/null
+++ b/src/Client.php
@@ -0,0 +1,203 @@
+privateKey = (string) ($privateKey ?? Util::getenv(
+ 'IMAGEKIT_PRIVATE_KEY'
+ ));
+ $this->password = (string) ($password ?? Util::getenv(
+ 'OPTIONAL_IMAGEKIT_IGNORES_THIS'
+ ) ?: 'do_not_set');
+ $this->webhookSecret = (string) ($webhookSecret ?? Util::getenv(
+ 'IMAGEKIT_WEBHOOK_SECRET'
+ ));
+
+ $this->baseUrlOverridden = !is_null($baseUrl);
+
+ $baseUrl ??= Util::getenv(
+ 'IMAGE_KIT_BASE_URL'
+ ) ?: 'https://api.imagekit.io';
+
+ $options = RequestOptions::parse(
+ RequestOptions::with(
+ uriFactory: Psr17FactoryDiscovery::findUriFactory(),
+ streamFactory: Psr17FactoryDiscovery::findStreamFactory(),
+ requestFactory: Psr17FactoryDiscovery::findRequestFactory(),
+ transporter: Psr18ClientDiscovery::find(),
+ ),
+ $requestOptions,
+ );
+
+ if (is_null($options->streamingTransporter)) {
+ assert(!is_null($options->transporter));
+ $options->streamingTransporter = new StreamingHttpClient($options->transporter);
+ }
+
+ /** @var array $headers */
+ $headers = [
+ 'Content-Type' => 'application/json',
+ 'Accept' => 'application/json',
+ 'User-Agent' => sprintf('ImageKit/PHP %s', VERSION),
+ 'X-Stainless-Lang' => 'php',
+ 'X-Stainless-Package-Version' => '0.0.1',
+ 'X-Stainless-Arch' => Util::machtype(),
+ 'X-Stainless-OS' => Util::ostype(),
+ 'X-Stainless-Runtime' => php_sapi_name(),
+ 'X-Stainless-Runtime-Version' => phpversion(),
+ ];
+
+ $customHeadersEnv = Util::getenv('IMAGE_KIT_CUSTOM_HEADERS');
+ if (null !== $customHeadersEnv) {
+ foreach (explode("\n", $customHeadersEnv) as $line) {
+ $colon = strpos($line, ':');
+ if (false !== $colon) {
+ $headers[trim(substr($line, 0, $colon))] = trim(substr($line, $colon + 1));
+ }
+ }
+ }
+
+ parent::__construct(
+ headers: $headers,
+ baseUrl: $baseUrl,
+ options: $options
+ );
+
+ $this->customMetadataFields = new CustomMetadataFieldsService($this);
+ $this->files = new FilesService($this);
+ $this->savedExtensions = new SavedExtensionsService($this);
+ $this->assets = new AssetsService($this);
+ $this->cache = new CacheService($this);
+ $this->folders = new FoldersService($this);
+ $this->accounts = new AccountsService($this);
+ $this->beta = new BetaService($this);
+ $this->webhooks = new WebhooksService($this);
+ }
+
+ /** @return array */
+ protected function authHeaders(): array
+ {
+ if (!$this->privateKey && !$this->password) {
+ return [];
+ }
+
+ $base64_credentials = base64_encode(
+ "{$this->privateKey}:{$this->password}"
+ );
+
+ return ['Authorization' => "Basic {$base64_credentials}"];
+ }
+
+ /**
+ * @internal
+ *
+ * @param string|list $path
+ * @param array $query
+ * @param array|null> $headers
+ * @param RequestOpts|null $opts
+ *
+ * @return array{NormalizedRequest, RequestOptions}
+ */
+ protected function buildRequest(
+ string $method,
+ string|array $path,
+ array $query,
+ array $headers,
+ mixed $body,
+ RequestOptions|array|null $opts,
+ ): array {
+ return parent::buildRequest(
+ method: $method,
+ path: $path,
+ query: $query,
+ headers: [...$this->authHeaders(), ...$headers],
+ body: $body,
+ opts: $opts,
+ );
+ }
+}
diff --git a/src/Core.php b/src/Core.php
new file mode 100644
index 00000000..1e035bb1
--- /dev/null
+++ b/src/Core.php
@@ -0,0 +1,5 @@
+|Converter|string|null $type
+ * @param class-string<\BackedEnum>|Converter|null $enum
+ * @param class-string|Converter|null $union
+ * @param class-string|Converter|string|null $list
+ * @param class-string|Converter|string|null $map
+ */
+ public function __construct(
+ ?string $apiName = null,
+ Converter|string|null $type = null,
+ Converter|string|null $enum = null,
+ Converter|string|null $union = null,
+ Converter|string|null $list = null,
+ Converter|string|null $map = null,
+ bool $nullable = false,
+ ) {
+ parent::__construct(apiName: $apiName, type: $type, enum: $enum, union: $union, list: $list, map: $map, nullable: $nullable);
+ $this->optional = true;
+ }
+}
diff --git a/src/Core/Attributes/Required.php b/src/Core/Attributes/Required.php
new file mode 100644
index 00000000..f264dc07
--- /dev/null
+++ b/src/Core/Attributes/Required.php
@@ -0,0 +1,60 @@
+|Converter|string|null */
+ public readonly Converter|string|null $type;
+
+ public readonly ?string $apiName;
+
+ public bool $optional;
+
+ public readonly bool $nullable;
+
+ /**
+ * @param class-string|Converter|string|null $type
+ * @param class-string<\BackedEnum>|Converter|null $enum
+ * @param class-string|Converter|null $union
+ * @param class-string|Converter|string|null $list
+ * @param class-string|Converter|string|null $map
+ */
+ public function __construct(
+ ?string $apiName = null,
+ Converter|string|null $type = null,
+ Converter|string|null $enum = null,
+ Converter|string|null $union = null,
+ Converter|string|null $list = null,
+ Converter|string|null $map = null,
+ bool $nullable = false,
+ ) {
+ $type ??= $union;
+ if (null !== $list) {
+ $type ??= new ListOf($list);
+ }
+ if (null !== $map) {
+ $type ??= new MapOf($map);
+ }
+ if (null !== $enum) {
+ $type ??= $enum instanceof Converter ? $enum : EnumOf::fromBackedEnum($enum);
+ }
+
+ $this->apiName = $apiName;
+ $this->type = $type;
+ $this->optional = false;
+ $this->nullable = $nullable;
+ }
+}
diff --git a/src/Core/BaseClient.php b/src/Core/BaseClient.php
new file mode 100644
index 00000000..89afdd83
--- /dev/null
+++ b/src/Core/BaseClient.php
@@ -0,0 +1,287 @@
+,
+ * headers: array>,
+ * body: mixed,
+ * }
+ */
+abstract class BaseClient
+{
+ protected UriInterface $baseUrl;
+
+ /**
+ * @internal
+ *
+ * @param array|null> $headers
+ */
+ public function __construct(
+ protected array $headers,
+ string $baseUrl,
+ protected ?string $idempotencyHeader = null,
+ protected RequestOptions $options = new RequestOptions,
+ ) {
+ assert(!is_null($this->options->uriFactory));
+ $this->baseUrl = $this->options->uriFactory->createUri($baseUrl);
+ }
+
+ /**
+ * @param string|list $path
+ * @param array $query
+ * @param array $headers
+ * @param string|int|list|null $unwrap
+ * @param class-string>|null $page
+ * @param class-string>|null $stream
+ * @param RequestOptions|array|null $options
+ *
+ * @return BaseResponse
+ */
+ public function request(
+ string $method,
+ string|array $path,
+ array $query = [],
+ array $headers = [],
+ mixed $body = null,
+ string|int|array|null $unwrap = null,
+ string|Converter|ConverterSource|null $convert = null,
+ ?string $page = null,
+ ?string $stream = null,
+ RequestOptions|array|null $options = [],
+ ): BaseResponse {
+ [$req, $opts] = $this->buildRequest(
+ method: $method,
+ // @phpstan-ignore argument.type
+ path: $path,
+ query: $query,
+ // @phpstan-ignore argument.type
+ headers: $headers,
+ body: $body,
+ // @phpstan-ignore argument.type
+ opts: $options,
+ );
+ ['method' => $method, 'path' => $uri, 'headers' => $headers, 'body' => $data] = $req;
+ assert(!is_null($opts->requestFactory));
+
+ $request = $opts->requestFactory->createRequest($method, uri: $uri);
+ $request = Util::withSetHeaders($request, headers: $headers);
+ $request = $this->transformRequest($request);
+
+ // @phpstan-ignore-next-line argument.type
+ $rsp = $this->sendRequest($opts, req: $request, data: $data, redirectCount: 0, retryCount: 0);
+
+ // @phpstan-ignore-next-line argument.type
+ return new RawResponse(client: $this, request: $request, response: $rsp, options: $opts, requestInfo: $req, unwrap: $unwrap, stream: $stream, page: $page, convert: $convert ?? 'null');
+ }
+
+ /**
+ * @internal
+ */
+ protected function generateIdempotencyKey(): string
+ {
+ $hex = bin2hex(random_bytes(32));
+
+ return "stainless-php-retry-{$hex}";
+ }
+
+ /**
+ * @internal
+ *
+ * @param string|list $path
+ * @param array $query
+ * @param array|null> $headers
+ * @param RequestOpts|null $opts
+ *
+ * @return array{NormalizedRequest, RequestOptions}
+ */
+ protected function buildRequest(
+ string $method,
+ string|array $path,
+ array $query,
+ array $headers,
+ mixed $body,
+ RequestOptions|array|null $opts,
+ ): array {
+ $options = RequestOptions::parse($this->options, $opts);
+
+ $parsedPath = Util::parsePath($path);
+
+ /** @var array $mergedQuery */
+ $mergedQuery = array_merge_recursive(
+ $query,
+ $options->extraQueryParams ?? []
+ );
+ $uri = Util::joinUri($this->baseUrl, path: $parsedPath, query: $mergedQuery)->__toString();
+ $idempotencyHeaders = $this->idempotencyHeader && !array_key_exists($this->idempotencyHeader, array: $headers)
+ ? [$this->idempotencyHeader => $this->generateIdempotencyKey()]
+ : [];
+
+ /** @var array|null> $mergedHeaders */
+ $mergedHeaders = [
+ ...$this->headers,
+ ...$headers,
+ ...($options->extraHeaders ?? []),
+ ...$idempotencyHeaders,
+ ];
+
+ $req = ['method' => strtoupper($method), 'path' => $uri, 'query' => $mergedQuery, 'headers' => $mergedHeaders, 'body' => $body];
+
+ return [$req, $options];
+ }
+
+ protected function transformRequest(
+ RequestInterface $request
+ ): RequestInterface {
+ return $request;
+ }
+
+ /**
+ * @internal
+ */
+ protected function followRedirect(
+ ResponseInterface $rsp,
+ RequestInterface $req
+ ): RequestInterface {
+ $location = $rsp->getHeaderLine('Location');
+ if (!$location) {
+ throw new APIConnectionException($req, message: 'Redirection without Location header');
+ }
+
+ $uri = Util::joinUri($req->getUri(), path: $location);
+
+ return $req->withUri($uri);
+ }
+
+ /**
+ * @internal
+ */
+ protected function shouldRetry(
+ RequestOptions $opts,
+ int $retryCount,
+ ?ResponseInterface $rsp
+ ): bool {
+ if ($retryCount >= $opts->maxRetries) {
+ return false;
+ }
+
+ $code = $rsp?->getStatusCode();
+ if (408 == $code || 409 == $code || 429 == $code || $code >= 500) {
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * @internal
+ */
+ protected function retryDelay(
+ RequestOptions $opts,
+ int $retryCount,
+ ?ResponseInterface $rsp
+ ): float {
+ if (!empty($header = $rsp?->getHeaderLine('retry-after'))) {
+ if (is_numeric($header)) {
+ return floatval($header);
+ }
+
+ try {
+ $date = new \DateTimeImmutable($header);
+ $span = time() - $date->getTimestamp();
+
+ return max(0.0, $span);
+ } catch (\DateMalformedStringException) {
+ }
+ }
+
+ $scale = $retryCount ** 2;
+ $jitter = 1 - (0.25 * mt_rand() / mt_getrandmax());
+ $naive = $opts->initialRetryDelay * $scale * $jitter;
+
+ return max(0.0, min($naive, $opts->maxRetryDelay));
+ }
+
+ /**
+ * @internal
+ *
+ * @param bool|int|float|string|resource|\Traversable|array|null $data
+ */
+ protected function sendRequest(
+ RequestOptions $opts,
+ RequestInterface $req,
+ mixed $data,
+ int $retryCount,
+ int $redirectCount,
+ ): ResponseInterface {
+ assert(null !== $opts->streamFactory && null !== $opts->transporter);
+
+ /** @var RequestInterface */
+ $req = $req->withHeader('X-Stainless-Retry-Count', strval($retryCount));
+ $req = Util::withSetBody($opts->streamFactory, req: $req, body: $data);
+
+ $transporter = Util::isStreamingRequest($req)
+ ? ($opts->streamingTransporter ?? $opts->transporter)
+ : $opts->transporter;
+
+ $rsp = null;
+ $err = null;
+
+ try {
+ $rsp = $transporter->sendRequest($req);
+ } catch (ClientExceptionInterface $e) {
+ $err = $e;
+ }
+
+ $code = $rsp?->getStatusCode();
+
+ if ($code >= 300 && $code < 400) {
+ assert(!is_null($rsp));
+
+ if ($redirectCount >= 20) {
+ throw new APIConnectionException($req, message: 'Maximum redirects exceeded');
+ }
+
+ $req = $this->followRedirect($rsp, req: $req);
+
+ return $this->sendRequest($opts, req: $req, data: $data, retryCount: $retryCount, redirectCount: ++$redirectCount);
+ }
+
+ if ($code >= 400 || is_null($rsp)) {
+ if (!$this->shouldRetry($opts, retryCount: $retryCount, rsp: $rsp)) {
+ $exn = is_null($rsp) ? new APIConnectionException($req, previous: $err) : APIStatusException::from(request: $req, response: $rsp);
+
+ throw $exn;
+ }
+
+ $seconds = $this->retryDelay($opts, retryCount: $retryCount, rsp: $rsp);
+ $floor = floor($seconds);
+ time_nanosleep((int) $floor, nanoseconds: (int) ($seconds - $floor) * 10 ** 9);
+
+ return $this->sendRequest($opts, req: $req, data: $data, retryCount: ++$retryCount, redirectCount: $redirectCount);
+ }
+
+ return $rsp;
+ }
+}
diff --git a/src/Core/Concerns/ResponseProxy.php b/src/Core/Concerns/ResponseProxy.php
new file mode 100644
index 00000000..709bfc4f
--- /dev/null
+++ b/src/Core/Concerns/ResponseProxy.php
@@ -0,0 +1,101 @@
+response->getProtocolVersion();
+ }
+
+ public function withProtocolVersion(string $version): static
+ {
+ $self = clone $this;
+ $self->response = $this->response->withProtocolVersion($version);
+
+ return $self;
+ }
+
+ public function getHeaders(): array
+ {
+ return $this->response->getHeaders();
+ }
+
+ public function hasHeader(string $name): bool
+ {
+ return $this->response->hasHeader($name);
+ }
+
+ public function getHeader(string $name): array
+ {
+ return $this->response->getHeader($name);
+ }
+
+ public function getHeaderLine(string $name): string
+ {
+ return $this->response->getHeaderLine($name);
+ }
+
+ public function withHeader(string $name, $value): static
+ {
+ $self = clone $this;
+ $self->response = $this->response->withHeader($name, value: $value);
+
+ return $self;
+ }
+
+ public function withAddedHeader(string $name, $value): static
+ {
+ $self = clone $this;
+ $self->response = $this->response->withAddedHeader($name, value: $value);
+
+ return $self;
+ }
+
+ public function withoutHeader(string $name): static
+ {
+ $self = clone $this;
+ $self->response = $this->response->withoutHeader($name);
+
+ return $self;
+ }
+
+ public function getBody(): StreamInterface
+ {
+ return $this->response->getBody();
+ }
+
+ public function withBody(StreamInterface $body): static
+ {
+ $self = clone $this;
+ $self->response = $this->response->withBody($body);
+
+ return $self;
+ }
+
+ public function getStatusCode(): int
+ {
+ return $this->response->getStatusCode();
+ }
+
+ public function withStatus(int $code, string $reasonPhrase = ''): static
+ {
+ $self = clone $this;
+ $self->response = $this->response->withstatus($code, reasonPhrase: $reasonPhrase);
+
+ return $self;
+ }
+
+ public function getReasonPhrase(): string
+ {
+ return $this->response->getReasonPhrase();
+ }
+}
diff --git a/src/Core/Concerns/SdkEnum.php b/src/Core/Concerns/SdkEnum.php
new file mode 100644
index 00000000..c47f7343
--- /dev/null
+++ b/src/Core/Concerns/SdkEnum.php
@@ -0,0 +1,34 @@
+getReflectionConstants() as $constant) {
+ if ($constant->isPublic()) {
+ array_push($acc, $constant->getValue());
+ }
+ }
+
+ // @phpstan-ignore-next-line return.type
+ return static::$converter = new EnumOf($acc);
+ }
+}
diff --git a/src/Core/Concerns/SdkModel.php b/src/Core/Concerns/SdkModel.php
new file mode 100644
index 00000000..98948b2b
--- /dev/null
+++ b/src/Core/Concerns/SdkModel.php
@@ -0,0 +1,285 @@
+
+ */
+trait SdkModel
+{
+ private static ModelOf $converter;
+
+ /**
+ * @var array keeps track of undocumented data
+ */
+ private array $_data = [];
+
+ /**
+ * @internal
+ *
+ * @return array
+ */
+ public function __serialize(): array
+ {
+ $properties = $this->toProperties();
+
+ return array_map(static fn ($v) => self::serialize($v), array: $properties);
+ }
+
+ /**
+ * @internal
+ *
+ * @param array $data
+ */
+ public function __unserialize(array $data): void
+ {
+ foreach ($data as $key => $value) {
+ // @phpstan-ignore-next-line argument.type
+ $this->offsetSet($key, value: $value);
+ }
+ }
+
+ /**
+ * @internal
+ *
+ * @return array
+ */
+ public function __debugInfo(): array
+ {
+ return $this->__serialize();
+ }
+
+ /**
+ * @internal
+ */
+ public function __toString(): string
+ {
+ return Util::prettyEncodeJson($this->__debugInfo());
+ }
+
+ /**
+ * @internal
+ *
+ * Magic get is intended to occur when we have manually unset
+ * a native class property, indicating an omitted value,
+ * or a property overridden with an incongruent type
+ *
+ * @throws \Exception
+ */
+ public function __get(string $key): mixed
+ {
+ if (!array_key_exists($key, array: self::$converter->properties)) {
+ throw new \RuntimeException("Property '{$key}' does not exist in {$this}::class");
+ }
+
+ // The unset property was overridden by a value with an incongruent type.
+ // It's forbidden for an optional value to be `null` in the payload.
+ if (array_key_exists($key, array: $this->_data)) {
+ throw new \Exception(
+ "The {$key} property is overridden, use the array access ['{$key}'] syntax to the raw payload property.",
+ );
+ }
+
+ // An optional property which was unset to be omitted from serialized is being accessed.
+ // Return null to match user's expectations.
+ // @phpstan-ignore-next-line return.type
+ return null;
+ }
+
+ /**
+ * @internal
+ *
+ * @return Shape
+ */
+ public function toProperties(): array
+ {
+ // @phpstan-ignore-next-line return.type
+ return [...Util::get_object_vars($this), ...$this->_data];
+ }
+
+ /**
+ * @internal
+ *
+ * @param key-of $offset
+ */
+ public function offsetExists(mixed $offset): bool
+ {
+ // @phpstan-ignore-next-line function.alreadyNarrowedType
+ if (!is_string($offset)) {
+ throw new \InvalidArgumentException;
+ }
+
+ if (array_key_exists($offset, array: $this->_data)) {
+ return true;
+ }
+
+ if (array_key_exists($offset, array: self::$converter->properties)) {
+ if (isset($this->{$offset})) {
+ return true;
+ }
+
+ $property = self::$converter->properties[$offset]->property;
+
+ return $property->isInitialized($this);
+ }
+
+ return false;
+ }
+
+ /**
+ * @internal
+ *
+ * @param key-of $offset
+ */
+ public function &offsetGet(mixed $offset): mixed
+ {
+ // @phpstan-ignore-next-line function.alreadyNarrowedType
+ if (!is_string($offset)) {
+ throw new \InvalidArgumentException;
+ }
+
+ // @phpstan-ignore-next-line function.alreadyNarrowedType
+ if (!$this->offsetExists($offset)) {
+ // @phpstan-ignore-next-line return.type
+ return null;
+ }
+
+ if (array_key_exists($offset, array: $this->_data)) {
+ // @phpstan-ignore-next-line return.type
+ return $this->_data[$offset];
+ }
+
+ // @phpstan-ignore-next-line return.type
+ return $this->{$offset};
+ }
+
+ /**
+ * @internal
+ *
+ * @param key-of $offset
+ */
+ public function offsetSet(mixed $offset, mixed $value): void
+ {
+ // @phpstan-ignore-next-line function.alreadyNarrowedType
+ if (!is_string($offset)) {
+ throw new \InvalidArgumentException;
+ }
+
+ $type = array_key_exists($offset, array: self::$converter->properties)
+ ? self::$converter->properties[$offset]->type
+ : 'mixed';
+
+ $coerced = Conversion::coerce($type, value: $value, state: new CoerceState(translateNames: false));
+
+ // @phpstan-ignore-next-line function.alreadyNarrowedType
+ if (property_exists($this, property: $offset)) {
+ try {
+ // @phpstan-ignore-next-line assign.propertyType
+ $this->{$offset} = $coerced;
+ unset($this->_data[$offset]);
+
+ return;
+ // @phpstan-ignore-next-line catch.neverThrown
+ } catch (\TypeError) {
+ unset($this->{$offset});
+ }
+ }
+
+ $this->_data[$offset] = $coerced;
+ }
+
+ /**
+ * @internal
+ *
+ * @param key-of $offset
+ */
+ public function offsetUnset(mixed $offset): void
+ {
+ // @phpstan-ignore-next-line function.alreadyNarrowedType
+ if (!is_string($offset)) {
+ throw new \InvalidArgumentException;
+ }
+
+ // @phpstan-ignore-next-line function.alreadyNarrowedType
+ if (property_exists($this, property: $offset)) {
+ unset($this->{$offset});
+ }
+
+ unset($this->_data[$offset]);
+ }
+
+ /**
+ * @internal
+ *
+ * @return array
+ */
+ public function jsonSerialize(): array
+ {
+ // @phpstan-ignore-next-line argument.type
+ return Conversion::dump(self::converter(), value: $this->__serialize());
+ }
+
+ /**
+ * @param array $data
+ */
+ public static function fromArray(array $data): static
+ {
+ // @phpstan-ignore-next-line argument.type
+ return self::converter()->from($data);
+ }
+
+ /**
+ * @internal
+ */
+ public static function converter(): Converter
+ {
+ if (isset(self::$converter)) {
+ return self::$converter;
+ }
+
+ $class = new \ReflectionClass(static::class);
+
+ return self::$converter = new ModelOf($class);
+ }
+
+ /**
+ * @internal
+ */
+ private function initialize(): void
+ {
+ static::converter();
+
+ foreach (self::$converter->properties as $name => $info) {
+ if ($info->optional) {
+ unset($this->{$name});
+ }
+ }
+ }
+
+ /**
+ * @internal
+ */
+ private static function serialize(mixed $value): mixed
+ {
+ if ($value instanceof BaseModel) {
+ return $value->toProperties();
+ }
+
+ if (is_array($value)) {
+ return array_map(static fn ($v) => self::serialize($v), array: $value);
+ }
+
+ return $value;
+ }
+}
diff --git a/src/Core/Concerns/SdkPage.php b/src/Core/Concerns/SdkPage.php
new file mode 100644
index 00000000..466eb6f1
--- /dev/null
+++ b/src/Core/Concerns/SdkPage.php
@@ -0,0 +1,102 @@
+
+ */
+ abstract public function getItems(): array;
+
+ public function hasNextPage(): bool
+ {
+ return !is_null($this->nextRequest());
+ }
+
+ /**
+ * Get the next page of results.
+ * Before calling this method, you must check if there is a next page
+ * using {@link hasNextPage()}.
+ *
+ * @return static of static-
+ *
+ * @throws APIStatusException
+ */
+ public function getNextPage(): static
+ {
+ $next = $this->nextRequest();
+ if (!$next) {
+ throw new \RuntimeException(
+ 'No next page expected; please check `.hasNextPage()` before calling `.getNextPage()`.'
+ );
+ }
+
+ [$req, $opts] = $next;
+
+ // @phpstan-ignore-next-line argument.type
+ /** @var BaseResponse */
+ $response = $this->client->request(...$req, convert: $this->convert, page: $this::class, options: $opts);
+
+ // @phpstan-ignore-next-line return.type
+ return $response->parse();
+ }
+
+ /**
+ * Iterator yielding each page (instance of static).
+ *
+ * @return \Generator
+ */
+ public function getIterator(): \Generator
+ {
+ $page = $this;
+
+ yield $page;
+ while ($page->hasNextPage()) {
+ $page = $page->getNextPage();
+
+ yield $page;
+ }
+ }
+
+ /**
+ * Iterator yielding each item across all pages.
+ *
+ * @return \Generator
-
+ */
+ public function pagingEachItem(): \Generator
+ {
+ foreach ($this as $page) {
+ foreach ($page->getItems() as $item) {
+ yield $item;
+ }
+ }
+ }
+
+ /**
+ * @internal
+ *
+ * @return array{NormalizedRequest, RequestOptions}
+ */
+ abstract protected function nextRequest(): ?array;
+}
diff --git a/src/Core/Concerns/SdkParams.php b/src/Core/Concerns/SdkParams.php
new file mode 100644
index 00000000..ab53ae51
--- /dev/null
+++ b/src/Core/Concerns/SdkParams.php
@@ -0,0 +1,36 @@
+|RequestOptions|null $options
+ *
+ * @return array{array, RequestOptions}
+ */
+ public static function parseRequest(mixed $params, array|RequestOptions|null $options): array
+ {
+ $converter = self::converter();
+ $state = new DumpState;
+ $dumped = (array) Conversion::dump($converter, value: $params, state: $state);
+ // @phpstan-ignore-next-line argument.type
+ $opts = RequestOptions::parse($options);
+
+ if (!$state->canRetry) {
+ $opts->maxRetries = 0;
+ }
+
+ // @phpstan-ignore-next-line return.type
+ return [$dumped, $opts];
+ }
+}
diff --git a/src/Core/Concerns/SdkUnion.php b/src/Core/Concerns/SdkUnion.php
new file mode 100644
index 00000000..90e3d812
--- /dev/null
+++ b/src/Core/Concerns/SdkUnion.php
@@ -0,0 +1,39 @@
+|list
+ */
+ public static function variants(): array
+ {
+ return [];
+ }
+
+ public static function converter(): Converter
+ {
+ if (isset(static::$converter)) {
+ return static::$converter;
+ }
+
+ return static::$converter = new UnionOf(discriminator: static::discriminator(), variants: static::variants());
+ }
+}
diff --git a/src/Core/Contracts/BaseModel.php b/src/Core/Contracts/BaseModel.php
new file mode 100644
index 00000000..ec1fbe74
--- /dev/null
+++ b/src/Core/Contracts/BaseModel.php
@@ -0,0 +1,18 @@
+
+ */
+interface BaseModel extends \ArrayAccess, \JsonSerializable, \Stringable, ConverterSource
+{
+ /** @return array */
+ public function toProperties(): array;
+}
diff --git a/src/Core/Contracts/BasePage.php b/src/Core/Contracts/BasePage.php
new file mode 100644
index 00000000..d1fed191
--- /dev/null
+++ b/src/Core/Contracts/BasePage.php
@@ -0,0 +1,34 @@
+
+ */
+interface BasePage extends \IteratorAggregate
+{
+ public function hasNextPage(): bool;
+
+ /**
+ * @return list
-
+ */
+ public function getItems(): array;
+
+ /**
+ * @return static
-
+ */
+ public function getNextPage(): static;
+
+ /**
+ * @return \Generator
-
+ */
+ public function pagingEachItem(): \Generator;
+}
diff --git a/src/Core/Contracts/BaseResponse.php b/src/Core/Contracts/BaseResponse.php
new file mode 100644
index 00000000..f5638ee4
--- /dev/null
+++ b/src/Core/Contracts/BaseResponse.php
@@ -0,0 +1,21 @@
+
+ */
+interface BaseStream extends \IteratorAggregate
+{
+ public function __construct(
+ Converter|ConverterSource|string $convert,
+ RequestInterface $request,
+ ResponseInterface $response,
+ mixed $parsedBody,
+ );
+
+ /**
+ * Manually force the stream to close early.
+ * Iterating through will automatically close as well.
+ */
+ public function close(): void;
+}
diff --git a/src/Core/Conversion.php b/src/Core/Conversion.php
new file mode 100644
index 00000000..2d89651f
--- /dev/null
+++ b/src/Core/Conversion.php
@@ -0,0 +1,229 @@
+ self::dump_unknown($v, state: $state), array: $value);
+ }
+
+ if (is_object($value)) {
+ if ($value instanceof FileParam) {
+ return $value;
+ }
+
+ if (is_a($value, class: ConverterSource::class)) {
+ return $value::converter()->dump($value, state: $state);
+ }
+
+ if (is_a($value, class: \BackedEnum::class)) {
+ return $value->value;
+ }
+
+ if (is_a($value, class: \DateTimeInterface::class)) {
+ return date_format($value, format: \DateTimeInterface::RFC3339);
+ }
+
+ if (is_a($value, class: \JsonSerializable::class)) {
+ return $value->jsonSerialize();
+ }
+
+ $acc = get_object_vars($value);
+
+ return empty($acc) ? (object) $acc : self::dump_unknown($acc, state: $state);
+ }
+
+ return $value;
+ }
+
+ public static function coerce(Converter|ConverterSource|string $target, mixed $value, CoerceState $state = new CoerceState): mixed
+ {
+ if ($value instanceof $target) {
+ ++$state->yes;
+
+ return $value;
+ }
+
+ if (is_a($target, class: ConverterSource::class, allow_string: true)) {
+ $target = $target::converter();
+ }
+
+ if ($target instanceof Converter) {
+ return $target->coerce($value, state: $state);
+ }
+
+ // BackedEnum class-name targets: wrap in EnumOf so enum values are scored
+ // against the enum's cases. Without this, tryConvert's default case scores
+ // any class-name target as `no`, even when the value is a valid enum member.
+ if (is_a($target, class: \BackedEnum::class, allow_string: true)) {
+ return EnumOf::fromBackedEnum($target)->coerce($value, state: $state);
+ }
+
+ return self::tryConvert($target, value: $value, state: $state);
+ }
+
+ public static function dump(Converter|ConverterSource|string $target, mixed $value, DumpState $state = new DumpState): mixed
+ {
+ if ($target instanceof Converter) {
+ return $target->dump($value, state: $state);
+ }
+
+ if (is_a($target, class: ConverterSource::class, allow_string: true)) {
+ return $target::converter()->dump($value, state: $state);
+ }
+
+ // BackedEnum class-name targets: wrap in EnumOf so enum values are scored
+ // against the enum's cases. Without this, tryConvert's default case scores
+ // any class-name target as `no`, even when the value is a valid enum member.
+ if (is_a($target, class: \BackedEnum::class, allow_string: true)) {
+ return EnumOf::fromBackedEnum($target)->dump($value, state: $state);
+ }
+
+ self::tryConvert($target, value: $value, state: $state);
+
+ return self::dump_unknown($value, state: $state);
+ }
+
+ private static function tryConvert(Converter|ConverterSource|string $target, mixed $value, CoerceState|DumpState $state): mixed
+ {
+ switch ($target) {
+ case 'mixed':
+ ++$state->yes;
+
+ return $value;
+
+ case 'null':
+ if (is_null($value)) {
+ ++$state->yes;
+
+ return null;
+ }
+
+ ++$state->maybe;
+
+ return null;
+
+ case 'bool':
+ if (is_bool($value)) {
+ ++$state->yes;
+
+ return $value;
+ }
+
+ ++$state->no;
+
+ return $value;
+
+ case 'int':
+ if (is_int($value)) {
+ ++$state->yes;
+
+ return $value;
+ }
+
+ if (is_float($value)) {
+ ++$state->maybe;
+
+ return (int) $value;
+ }
+
+ if (is_string($value) && ctype_digit($value)) {
+ ++$state->maybe;
+
+ return (int) $value;
+ }
+
+ ++$state->no;
+
+ return $value;
+
+ case 'float':
+ if (is_numeric($value)) {
+ ++$state->yes;
+
+ return (float) $value;
+ }
+
+ if (is_string($value) && is_numeric($value)) {
+ ++$state->maybe;
+
+ return (float) $value;
+ }
+
+ ++$state->no;
+
+ return $value;
+
+ case 'string':
+ if (is_string($value)) {
+ ++$state->yes;
+
+ return $value;
+ }
+
+ if (is_numeric($value)) {
+ ++$state->maybe;
+
+ return (string) $value;
+ }
+
+ if ($value instanceof \Generator) {
+ return implode('', iterator_to_array($value));
+ }
+
+ ++$state->no;
+
+ return $value;
+
+ case 'DateTimeInterface':
+ case 'DateTimeImmutable':
+ if (is_string($value)) {
+ try {
+ ++$state->maybe;
+
+ return new \DateTimeImmutable($value);
+ } catch (\Exception) {
+ --$state->maybe;
+ }
+ }
+
+ ++$state->no;
+
+ return $value;
+
+ case 'DateTime':
+ if (is_string($value)) {
+ try {
+ ++$state->maybe;
+
+ return new \DateTime($value);
+ } catch (\Exception) {
+ --$state->maybe;
+ }
+ }
+
+ ++$state->no;
+
+ return $value;
+
+ default:
+ ++$state->no;
+
+ return $value;
+ }
+ }
+}
diff --git a/src/Core/Conversion/CoerceState.php b/src/Core/Conversion/CoerceState.php
new file mode 100644
index 00000000..b1de64d7
--- /dev/null
+++ b/src/Core/Conversion/CoerceState.php
@@ -0,0 +1,19 @@
+type = $type ?? $enum ?? $union;
+ assert(!is_null($this->type));
+ }
+
+ public function coerce(mixed $value, CoerceState $state): mixed
+ {
+ if (!is_array($value)) {
+ return $value;
+ }
+ ++$state->yes;
+
+ $acc = [];
+ foreach ($value as $k => $v) {
+ if ($this->nullable && is_null($v)) {
+ ++$state->yes;
+ $acc[$k] = null;
+ } else {
+ $acc[$k] = Conversion::coerce($this->type, value: $v, state: $state);
+ }
+ }
+
+ return $acc;
+ }
+
+ public function dump(mixed $value, DumpState $state): mixed
+ {
+ if (!is_array($value)) {
+ return Conversion::dump_unknown($value, state: $state);
+ }
+ ++$state->yes;
+
+ if (empty($value)) {
+ return $this->empty();
+ }
+
+ $acc = [];
+ foreach ($value as $k => $v) {
+ if ($this->nullable && is_null($v)) {
+ ++$state->yes;
+ $acc[$k] = null;
+ } else {
+ $acc[$k] = Conversion::dump($this->type, value: $v, state: $state);
+ }
+ }
+
+ return $acc;
+ }
+
+ // @phpstan-ignore-next-line missingType.iterableValue
+ private function empty(): array|object
+ {
+ return (object) [];
+ }
+}
diff --git a/src/Core/Conversion/Contracts/Converter.php b/src/Core/Conversion/Contracts/Converter.php
new file mode 100644
index 00000000..dadf46de
--- /dev/null
+++ b/src/Core/Conversion/Contracts/Converter.php
@@ -0,0 +1,24 @@
+, self> */
+ private static array $cache = [];
+
+ /**
+ * @param list $members
+ */
+ public function __construct(private readonly array $members)
+ {
+ $type = 'NULL';
+ foreach ($this->members as $member) {
+ $type = gettype($member);
+ }
+ $this->type = $type;
+ }
+
+ /** @param class-string<\BackedEnum> $enum */
+ public static function fromBackedEnum(string $enum): self
+ {
+ // @phpstan-ignore-next-line argument.type
+ return self::$cache[$enum] ??= new self(array_column($enum::cases(), column_key: 'value'));
+ }
+
+ public function coerce(mixed $value, CoerceState $state): mixed
+ {
+ $this->tally($value, state: $state);
+
+ return $value;
+ }
+
+ public function dump(mixed $value, DumpState $state): mixed
+ {
+ $this->tally($value, state: $state);
+
+ return Conversion::dump_unknown($value, state: $state);
+ }
+
+ private function tally(mixed $value, CoerceState|DumpState $state): void
+ {
+ $needle = $value instanceof \BackedEnum ? $value->value : $value;
+ if (in_array($needle, haystack: $this->members, strict: true)) {
+ ++$state->yes;
+ } elseif ($this->type === gettype($needle)) {
+ ++$state->maybe;
+ } else {
+ ++$state->no;
+ }
+ }
+}
diff --git a/src/Core/Conversion/ListOf.php b/src/Core/Conversion/ListOf.php
new file mode 100644
index 00000000..31a262e6
--- /dev/null
+++ b/src/Core/Conversion/ListOf.php
@@ -0,0 +1,22 @@
+
+ */
+ public readonly array $properties;
+
+ /**
+ * @param \ReflectionClass $class
+ */
+ public function __construct(public readonly \ReflectionClass $class)
+ {
+ $properties = [];
+
+ foreach ($this->class->getProperties() as $property) {
+ $attributes = [...$property->getAttributes(Required::class), ...$property->getAttributes(Optional::class)];
+
+ if (!empty($attributes)) {
+ $name = $property->getName();
+ $properties[$name] = new PropertyInfo($property);
+ }
+ }
+ $this->properties = $properties;
+ }
+
+ public function coerce(mixed $value, CoerceState $state): mixed
+ {
+ if ($value instanceof $this->class->name) {
+ ++$state->yes;
+
+ return $value;
+ }
+
+ if (!is_array($value) || (!empty($value) && array_is_list($value))) {
+ ++$state->no;
+
+ return $value;
+ }
+
+ ++$state->yes;
+
+ $val = [...$value];
+ $acc = [];
+
+ foreach ($this->properties as $name => $info) {
+ $srcName = $state->translateNames ? $info->apiName : $name;
+ if (!array_key_exists($srcName, array: $val)) {
+ if ($info->optional) {
+ ++$state->yes;
+ } elseif ($info->nullable) {
+ ++$state->maybe;
+ } else {
+ ++$state->no;
+ }
+
+ continue;
+ }
+
+ $item = $val[$srcName];
+ unset($val[$srcName]);
+
+ if (is_null($item) && ($info->nullable || $info->optional)) {
+ if ($info->nullable) {
+ ++$state->yes;
+ } elseif ($info->optional) {
+ ++$state->maybe;
+ }
+ $acc[$name] = null;
+ } else {
+ $coerced = Conversion::coerce($info->type, value: $item, state: $state);
+ $acc[$name] = $coerced;
+ }
+ }
+
+ foreach ($val as $name => $item) {
+ $acc[$name] = $item;
+ }
+
+ // @phpstan-ignore-next-line return.type
+ return $this->from($acc);
+ }
+
+ public function dump(mixed $value, DumpState $state): mixed
+ {
+ if ($value instanceof BaseModel) {
+ $value = $value->toProperties();
+ }
+
+ if (is_array($value)) {
+ ++$state->yes;
+ $acc = [];
+
+ foreach ($value as $name => $item) {
+ if (array_key_exists($name, array: $this->properties)) {
+ ++$state->yes;
+ $info = $this->properties[$name];
+ $acc[$info->apiName] = Conversion::dump($info->type, value: $item, state: $state);
+ } else {
+ $acc[$name] = Conversion::dump_unknown($item, state: $state);
+ }
+ }
+
+ return empty($acc) ? ((object) $acc) : $acc;
+ }
+
+ ++$state->no;
+
+ return Conversion::dump_unknown($value, state: $state);
+ }
+
+ /**
+ * @param array $data
+ */
+ public function from(array $data): BaseModel
+ {
+ $instance = $this->class->newInstanceWithoutConstructor();
+ // @phpstan-ignore-next-line
+ $instance->__unserialize($data);
+
+ return $instance;
+ }
+}
diff --git a/src/Core/Conversion/PropertyInfo.php b/src/Core/Conversion/PropertyInfo.php
new file mode 100644
index 00000000..0cebd935
--- /dev/null
+++ b/src/Core/Conversion/PropertyInfo.php
@@ -0,0 +1,79 @@
+getType()?->allowsNull() ?? false;
+
+ $apiName = $property->getName();
+ $type = $property->getType();
+ $optional = false;
+ $attributes = [...$property->getAttributes(Required::class), ...$property->getAttributes(Optional::class)];
+
+ foreach ($attributes as $attr) {
+ /** @var Required $attribute */
+ $attribute = $attr->newInstance();
+
+ $apiName = $attribute->apiName ?? $apiName;
+ $optional = $attribute->optional;
+ $nullable |= $attribute->nullable;
+ $type = $attribute->type ?? $type;
+ }
+
+ $this->apiName = $apiName;
+ $this->type = self::parse($type);
+ $this->nullable = (bool) $nullable;
+ $this->optional = $optional;
+ }
+
+ /**
+ * @param array|Converter|ConverterSource|\ReflectionType|string|null $type
+ */
+ private static function parse(array|Converter|ConverterSource|\ReflectionType|string|null $type): Converter|ConverterSource|string
+ {
+ if (is_string($type) || $type instanceof Converter) {
+ return $type;
+ }
+
+ if (is_array($type)) {
+ // @phpstan-ignore-next-line return.type
+ return new UnionOf($type);
+ }
+
+ if ($type instanceof \ReflectionUnionType) {
+ // @phpstan-ignore-next-line argument.type
+ return new UnionOf(array_map(static fn ($t) => self::parse($t), array: $type->getTypes()));
+ }
+
+ if ($type instanceof \ReflectionNamedType) {
+ return $type->getName();
+ }
+
+ if ($type instanceof \ReflectionIntersectionType) {
+ throw new \ValueError;
+ }
+
+ return 'mixed';
+ }
+}
diff --git a/src/Core/Conversion/UnionOf.php b/src/Core/Conversion/UnionOf.php
new file mode 100644
index 00000000..181643c8
--- /dev/null
+++ b/src/Core/Conversion/UnionOf.php
@@ -0,0 +1,132 @@
+|list $variants
+ */
+ public function __construct(
+ private readonly array $variants,
+ private readonly ?string $discriminator = null,
+ ) {}
+
+ public function coerce(mixed $value, CoerceState $state): mixed
+ {
+ if (!is_null($target = $this->resolveVariant(value: $value))) {
+ return Conversion::coerce($target, value: $value, state: $state);
+ }
+
+ $alternatives = [];
+ foreach ($this->variants as $_ => $variant) {
+ ++$state->branched;
+ $newState = new CoerceState;
+
+ $coerced = Conversion::coerce($variant, value: $value, state: $newState);
+ if (($newState->no + $newState->maybe) === 0) {
+ $state->yes += $newState->yes;
+
+ return $coerced;
+ }
+ if ($newState->maybe > 0) {
+ $alternatives[] = [[-$newState->yes, -$newState->maybe, $newState->no], $newState, $coerced];
+ }
+ }
+
+ usort(
+ $alternatives,
+ static fn (array $a, array $b): int => $a[0][0] <=> $b[0][0] ?: $a[0][1] <=> $b[0][1] ?: $a[0][2] <=> $b[0][2]
+ );
+
+ if (empty($alternatives)) {
+ ++$state->no;
+
+ return $value;
+ }
+
+ [[,$newState, $best]] = $alternatives;
+ $state->yes += $newState->yes;
+ $state->maybe += $newState->maybe;
+ $state->no += $newState->no;
+
+ return $best;
+ }
+
+ public function dump(mixed $value, DumpState $state): mixed
+ {
+ if (!is_null($target = $this->resolveVariant(value: $value))) {
+ return Conversion::dump($target, value: $value, state: $state);
+ }
+
+ $alternatives = [];
+ foreach ($this->variants as $_ => $variant) {
+ ++$state->branched;
+ if ($value instanceof $variant) {
+ return Conversion::dump($variant, value: $value, state: $state);
+ }
+
+ $newState = new DumpState;
+ $dumped = Conversion::dump($variant, value: $value, state: $newState);
+ if (($newState->no + $newState->maybe) === 0) {
+ $state->yes += $newState->yes;
+
+ return $dumped;
+ }
+ if ($newState->maybe > 0) {
+ $alternatives[] = [[-$newState->yes, -$newState->maybe, $newState->no], $newState, $dumped];
+ }
+ }
+
+ usort(
+ $alternatives,
+ static fn (array $a, array $b): int => $a[0][0] <=> $b[0][0] ?: $a[0][1] <=> $b[0][1] ?: $a[0][2] <=> $b[0][2]
+ );
+
+ if (empty($alternatives)) {
+ ++$state->no;
+
+ return Conversion::dump_unknown($value, state: $state);
+ }
+
+ [[,$newState, $best]] = $alternatives;
+ $state->yes += $newState->yes;
+ $state->maybe += $newState->maybe;
+ $state->no += $newState->no;
+
+ return $best;
+ }
+
+ private function resolveVariant(
+ mixed $value,
+ ): Converter|ConverterSource|string|null {
+ if ($value instanceof BaseModel) {
+ return $value::class;
+ }
+
+ if (
+ null !== $this->discriminator
+ && is_array($value)
+ && array_key_exists($this->discriminator, array: $value)
+ ) {
+ $discriminator = $value[$this->discriminator];
+ if (!is_string($discriminator)) {
+ return null;
+ }
+
+ return $this->variants[$discriminator] ?? null;
+ }
+
+ return null;
+ }
+}
diff --git a/src/Core/Exceptions/APIConnectionException.php b/src/Core/Exceptions/APIConnectionException.php
new file mode 100644
index 00000000..c897edb5
--- /dev/null
+++ b/src/Core/Exceptions/APIConnectionException.php
@@ -0,0 +1,9 @@
+response = $response;
+ $this->status = $response->getStatusCode();
+
+ $summary = Util::prettyEncodeJson(['status' => $this->status, 'body' => Util::decodeJson($response->getBody())]);
+
+ if ('' != $message) {
+ $summary .= $message.PHP_EOL.$summary;
+ }
+
+ parent::__construct(request: $request, message: $summary, previous: $previous);
+ }
+
+ public static function from(
+ RequestInterface $request,
+ ResponseInterface $response,
+ string $message = ''
+ ): self {
+ $status = $response->getStatusCode();
+
+ $cls = match (true) {
+ 400 === $status => BadRequestException::class,
+ 401 === $status => AuthenticationException::class,
+ 403 === $status => PermissionDeniedException::class,
+ 404 === $status => NotFoundException::class,
+ 409 === $status => ConflictException::class,
+ 422 === $status => UnprocessableEntityException::class,
+ 429 === $status => RateLimitException::class,
+ $status >= 500 => InternalServerException::class,
+ default => APIStatusException::class
+ };
+
+ return new $cls(request: $request, response: $response, message: $message);
+ }
+}
diff --git a/src/Core/Exceptions/APITimeoutException.php b/src/Core/Exceptions/APITimeoutException.php
new file mode 100644
index 00000000..94d0216a
--- /dev/null
+++ b/src/Core/Exceptions/APITimeoutException.php
@@ -0,0 +1,19 @@
+files->upload(file: FileParam::fromResource(fopen('data.csv', 'r')));
+ *
+ * // From a string:
+ * $client->files->upload(file: FileParam::fromString('csv data...', 'data.csv'));
+ * ```
+ */
+final class FileParam
+{
+ public const DEFAULT_CONTENT_TYPE = 'application/octet-stream';
+
+ /**
+ * @param resource|string $data the file content as a resource or string
+ */
+ private function __construct(
+ public readonly mixed $data,
+ public readonly string $filename,
+ public readonly string $contentType = self::DEFAULT_CONTENT_TYPE,
+ ) {}
+
+ /**
+ * Create a FileParam from an open resource (e.g. from fopen()).
+ *
+ * @param resource $resource an open file resource
+ * @param string|null $filename Override the filename. Defaults to the resource URI basename.
+ * @param string $contentType override the content type
+ */
+ public static function fromResource(mixed $resource, ?string $filename = null, string $contentType = self::DEFAULT_CONTENT_TYPE): self
+ {
+ if (!is_resource($resource)) {
+ throw new \InvalidArgumentException('Expected a resource, got '.get_debug_type($resource));
+ }
+
+ if (is_null($filename)) {
+ $meta = stream_get_meta_data($resource);
+ $filename = basename($meta['uri'] ?? 'upload');
+ }
+
+ return new self($resource, filename: $filename, contentType: $contentType);
+ }
+
+ /**
+ * Create a FileParam from a string.
+ *
+ * @param string $content the file content
+ * @param string $filename the filename for the Content-Disposition header
+ * @param string $contentType override the content type
+ */
+ public static function fromString(string $content, string $filename, string $contentType = self::DEFAULT_CONTENT_TYPE): self
+ {
+ return new self($content, filename: $filename, contentType: $contentType);
+ }
+}
diff --git a/src/Core/Implementation/RawResponse.php b/src/Core/Implementation/RawResponse.php
new file mode 100644
index 00000000..2e0c8f5b
--- /dev/null
+++ b/src/Core/Implementation/RawResponse.php
@@ -0,0 +1,106 @@
+
+ */
+class RawResponse implements BaseResponse
+{
+ use ResponseProxy;
+
+ private mixed $decodedBody;
+
+ /** @var R */
+ private mixed $coercedResponse;
+
+ private bool $decoded = false;
+ private bool $coerced = false;
+
+ /**
+ * @param NormalizedRequest $requestInfo
+ * @param list|string|int|null $unwrap
+ */
+ public function __construct(
+ private BaseClient $client,
+ private RequestOptions $options,
+ private RequestInterface $request,
+ private ResponseInterface $response,
+ private array $requestInfo,
+ private array|string|int|null $unwrap,
+ private Converter|ConverterSource|string $convert,
+ private ?string $page,
+ private ?string $stream,
+ ) {}
+
+ public function getRequest(): RequestInterface
+ {
+ return $this->request;
+ }
+
+ public function parse(): mixed
+ {
+ if (!$this->coerced) {
+ if (!is_null($this->stream)) {
+ // @phpstan-ignore-next-line assign.propertyType
+ $this->coercedResponse = new $this->stream(
+ convert: $this->convert,
+ request: $this->request,
+ response: $this->response,
+ parsedBody: $this->getDecoded(),
+ );
+ } elseif (!is_null($this->page)) {
+ // @phpstan-ignore-next-line assign.propertyType
+ $this->coercedResponse = new $this->page(
+ convert: $this->convert,
+ client: $this->client,
+ requestInfo: $this->requestInfo,
+ options: $this->options,
+ response: $this->response,
+ parsedBody: $this->getDecoded(),
+ );
+ } else {
+ // @phpstan-ignore-next-line assign.propertyType
+ $this->coercedResponse = Conversion::coerce(
+ $this->convert,
+ value: $this->getDecoded(),
+ );
+ }
+
+ $this->coerced = true;
+ }
+
+ return $this->coercedResponse;
+ }
+
+ private function getDecoded(): mixed
+ {
+ if (!$this->decoded) {
+ $decoded = Util::decodeContent($this->response);
+ if (!is_null($this->unwrap)) {
+ $decoded = Util::dig($decoded, key: $this->unwrap);
+ }
+ $this->decodedBody = $decoded;
+ $this->decoded = true;
+ }
+
+ return $this->decodedBody;
+ }
+}
diff --git a/src/Core/Implementation/StreamingHttpClient.php b/src/Core/Implementation/StreamingHttpClient.php
new file mode 100644
index 00000000..6beb2593
--- /dev/null
+++ b/src/Core/Implementation/StreamingHttpClient.php
@@ -0,0 +1,29 @@
+inner, '\GuzzleHttp\Client')) {
+ return $this->inner->send($request, ['stream' => true]);
+ }
+
+ return $this->inner->sendRequest($request);
+ }
+}
diff --git a/src/Core/Util.php b/src/Core/Util.php
new file mode 100644
index 00000000..4b60030b
--- /dev/null
+++ b/src/Core/Util.php
@@ -0,0 +1,577 @@
+
+ */
+ public static function get_object_vars(object $object): array
+ {
+ return get_object_vars($object);
+ }
+
+ public static function machtype(): string
+ {
+ $arch = php_uname('m');
+
+ return match (true) {
+ str_contains($arch, 'aarch64'), str_contains($arch, 'arm64') => 'arm64',
+ str_contains($arch, 'x86_64'), str_contains($arch, 'amd64') => 'x64',
+ str_contains($arch, 'i386'), str_contains($arch, 'i686') => 'x32',
+ str_contains($arch, 'arm') => 'arm',
+ default => 'unknown',
+ };
+ }
+
+ public static function ostype(): string
+ {
+ return match ($os = strtolower(PHP_OS_FAMILY)) {
+ 'linux' => 'Linux',
+ 'darwin' => 'MacOS',
+ 'windows' => 'Windows',
+ 'solaris' => 'Solaris',
+ // @phpstan-ignore-next-line match.alwaysFalse
+ 'bsd', 'freebsd', 'openbsd' => 'BSD',
+ default => "Other:{$os}",
+ };
+ }
+
+ /**
+ * @template T
+ *
+ * @param array $array
+ * @param array $map
+ *
+ * @return array
+ */
+ public static function array_transform_keys(array $array, array $map): array
+ {
+ $acc = [];
+ foreach ($array as $key => $value) {
+ $acc[$map[$key] ?? $key] = $value;
+ }
+
+ return $acc;
+ }
+
+ public static function strVal(mixed $value): string
+ {
+ if (is_bool($value)) {
+ return $value ? 'true' : 'false';
+ }
+
+ if (is_object($value) && is_a($value, class: \DateTimeInterface::class)) {
+ return date_format($value, format: \DateTimeInterface::RFC3339);
+ }
+
+ // @phpstan-ignore-next-line argument.type
+ return strval($value);
+ }
+
+ /**
+ * @param callable $callback
+ */
+ public static function mapRecursive(mixed $callback, mixed $value): mixed
+ {
+ $mapped = match (true) {
+ is_array($value) => array_map(static fn ($v) => self::mapRecursive($callback, value: $v), $value),
+ default => $value,
+ };
+
+ return $callback($mapped);
+ }
+
+ public static function removeNulls(mixed $value): mixed
+ {
+ $mapped = self::mapRecursive(
+ static fn ($vs) => is_array($vs) && !array_is_list($vs) ? array_filter($vs, callback: static fn ($v) => !is_null($v)) : $vs,
+ value: $value
+ );
+
+ return $mapped;
+ }
+
+ /**
+ * @param string|int|list|callable $key
+ */
+ public static function dig(
+ mixed $array,
+ string|int|array|callable $key
+ ): mixed {
+ if (is_callable($key)) {
+ return $key($array);
+ }
+
+ if (is_array($array)) {
+ if ((is_string($key) || is_int($key)) && array_key_exists($key, array: $array)) {
+ return $array[$key];
+ }
+
+ if (is_array($key) && !empty($key)) {
+ if (array_key_exists($fst = $key[0], array: $array)) {
+ return self::dig($array[$fst], key: array_slice($key, 1));
+ }
+ }
+ }
+
+ return null;
+ }
+
+ /**
+ * @param string|list $path
+ */
+ public static function parsePath(string|array $path): string
+ {
+ if (is_string($path)) {
+ return $path;
+ }
+
+ if (empty($path)) {
+ return '';
+ }
+
+ [$template] = $path;
+ $mapped = array_map(static fn ($s) => rawurlencode(self::strVal($s)), array: array_slice($path, 1));
+
+ return sprintf($template, ...$mapped);
+ }
+
+ /**
+ * @param array $query
+ */
+ public static function joinUri(
+ UriInterface $base,
+ string $path,
+ array $query = []
+ ): UriInterface {
+ $parsed = parse_url($path);
+ if ($scheme = $parsed['scheme'] ?? null) {
+ $base = $base->withScheme($scheme);
+ }
+ if ($host = $parsed['host'] ?? null) {
+ $base = $base->withHost($host);
+ }
+ if ($port = $parsed['port'] ?? null) {
+ $base = $base->withPort($port);
+ }
+ if (($user = $parsed['user'] ?? null) || ($pass = $parsed['pass'] ?? null)) {
+ $base = $base->withUserInfo($user ?? '', $pass ?? null);
+ }
+ if ($path = $parsed['path'] ?? null) {
+ $base = str_starts_with($path, '/') ? $base->withPath($path) : $base->withPath($base->getPath().'/'.$path);
+ }
+
+ [$q1, $q2] = [[], []];
+ parse_str($base->getQuery(), $q1);
+ parse_str($parsed['query'] ?? '', $q2);
+
+ $mergedQuery = array_merge_recursive($q1, $q2, $query);
+
+ /** @var array */
+ $normalizedQuery = self::mapRecursive(
+ static fn ($v) => is_bool($v) || is_numeric($v) ? self::strVal($v) : $v,
+ value: $mergedQuery
+ );
+ $qs = http_build_query($normalizedQuery, encoding_type: PHP_QUERY_RFC3986);
+
+ return $base->withQuery($qs);
+ }
+
+ public static function isStreamingRequest(RequestInterface $request): bool
+ {
+ $accept = $request->getHeaderLine('Accept');
+
+ return !empty(array_filter(
+ self::STREAMING_CONTENT_TYPE,
+ static fn (string $pattern) => (bool) preg_match($pattern, subject: $accept),
+ ));
+ }
+
+ /**
+ * @param array|null> $headers
+ */
+ public static function withSetHeaders(
+ RequestInterface $req,
+ array $headers
+ ): RequestInterface {
+ foreach ($headers as $name => $value) {
+ if (is_null($value)) {
+ /** @var RequestInterface */
+ $req = $req->withoutHeader($name);
+ } else {
+ $value = is_array($value) ? array_map(static fn ($v) => self::strVal($v), array: $value) : self::strVal($value);
+
+ /** @var RequestInterface */
+ $req = $req->withHeader($name, $value);
+ }
+ }
+
+ return $req;
+ }
+
+ /**
+ * @return \Iterator
+ */
+ public static function streamIterator(StreamInterface $stream): \Iterator
+ {
+ if (!$stream->isReadable()) {
+ return;
+ }
+
+ try {
+ while (!$stream->eof()) {
+ yield $stream->read(self::BUF_SIZE);
+ }
+ } finally {
+ $stream->close();
+ }
+ }
+
+ /**
+ * @param bool|int|float|string|resource|\Traversable|array|null $body
+ */
+ public static function withSetBody(
+ StreamFactoryInterface $factory,
+ RequestInterface $req,
+ mixed $body
+ ): RequestInterface {
+ if ($body instanceof StreamInterface) {
+ /** @var RequestInterface */
+ return $req->withBody($body);
+ }
+
+ $contentType = $req->getHeaderLine('Content-Type');
+ if (preg_match(self::JSON_CONTENT_TYPE, $contentType)) {
+ if (is_array($body) || is_object($body)) {
+ $encoded = json_encode($body, flags: self::JSON_ENCODE_FLAGS);
+ $stream = $factory->createStream($encoded);
+
+ /** @var RequestInterface */
+ return $req->withBody($stream);
+ }
+ }
+
+ if (preg_match('/^multipart\/form-data/', $contentType)) {
+ [$boundary, $gen] = self::encodeMultipartStreaming($body);
+ $encoded = implode('', iterator_to_array($gen, preserve_keys: false));
+ $stream = $factory->createStream($encoded);
+
+ /** @var RequestInterface */
+ return $req->withHeader('Content-Type', "{$contentType}; boundary={$boundary}")->withBody($stream);
+ }
+
+ if (is_resource($body)) {
+ $stream = $factory->createStreamFromResource($body);
+
+ /** @var RequestInterface */
+ return $req->withBody($stream);
+ }
+
+ if (is_string($body)) {
+ $stream = $factory->createStream($body);
+
+ // @var RequestInterface
+ return $req->withBody($stream);
+ }
+
+ return $req;
+ }
+
+ /**
+ * @param \Iterator $stream
+ *
+ * @return \Iterator
+ */
+ public static function decodeLines(\Iterator $stream): \Iterator
+ {
+ $buf = '';
+ foreach ($stream as $chunk) {
+ $buf .= $chunk;
+ while (($pos = strpos($buf, "\n")) !== false) {
+ yield substr($buf, 0, $pos);
+ $buf = substr($buf, $pos + 1);
+ }
+ }
+ if ('' !== $buf) {
+ yield $buf;
+ }
+ }
+
+ /**
+ * @param \Iterator $lines
+ *
+ * @return \Generator
+ */
+ public static function decodeSSE(\Iterator $lines): \Generator
+ {
+ $blank = ['event' => null, 'data' => null, 'id' => null, 'retry' => null];
+ $acc = [];
+
+ foreach ($lines as $line) {
+ $line = rtrim($line);
+ if ('' === $line) {
+ if (empty($acc)) {
+ continue;
+ }
+
+ yield [...$blank, ...$acc];
+ $acc = [];
+ }
+
+ if (str_starts_with($line, ':')) {
+ continue;
+ }
+
+ $matches = [];
+ if (preg_match('/^([^:]+):\s?(.*)$/', $line, $matches)) {
+ [, $field, $value] = $matches;
+
+ switch ($field) {
+ case 'event':
+ $acc['event'] = $value;
+
+ break;
+
+ case 'data':
+ if (isset($acc['data'])) {
+ $acc['data'] .= "\n".$value;
+ } else {
+ $acc['data'] = $value;
+ }
+
+ break;
+
+ case 'id':
+ $acc['id'] = $value;
+
+ break;
+
+ case 'retry':
+ $acc['retry'] = (int) $value;
+
+ break;
+ }
+ }
+ }
+
+ if (!empty($acc)) {
+ yield [...$blank, ...$acc];
+ }
+ }
+
+ public static function decodeJson(string $json): mixed
+ {
+ return json_decode($json, associative: true, flags: JSON_THROW_ON_ERROR);
+ }
+
+ public static function decodeContent(ResponseInterface $rsp): mixed
+ {
+ if (204 == $rsp->getStatusCode()) {
+ return null;
+ }
+
+ $content_type = $rsp->getHeaderLine('Content-Type');
+ $body = $rsp->getBody();
+
+ if (preg_match(self::JSON_CONTENT_TYPE, subject: $content_type)) {
+ $json = $body->getContents();
+
+ return self::decodeJson($json);
+ }
+
+ if (preg_match(self::JSONL_CONTENT_TYPE, subject: $content_type)) {
+ $it = self::streamIterator($body);
+ $lines = self::decodeLines($it);
+
+ return (function () use ($lines) {
+ foreach ($lines as $line) {
+ yield static::decodeJson($line);
+ }
+ })();
+ }
+
+ if (str_contains($content_type, needle: 'text/event-stream')) {
+ $it = self::streamIterator($body);
+ $lines = self::decodeLines($it);
+
+ return self::decodeSSE($lines);
+ }
+
+ return self::streamIterator($body);
+ }
+
+ public static function prettyEncodeJson(mixed $obj): string
+ {
+ return json_encode($obj, flags: JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT) ?: '';
+ }
+
+ /**
+ * @param list $closing
+ *
+ * @return \Generator
+ */
+ private static function writeMultipartContent(
+ mixed $val,
+ array &$closing,
+ ?string $contentType = null
+ ): \Generator {
+ $contentLine = "Content-Type: %s\r\n\r\n";
+
+ if ($val instanceof FileParam) {
+ $ct = $val->contentType ?? $contentType;
+
+ yield sprintf($contentLine, $ct);
+ $data = $val->data;
+ if (is_string($data)) {
+ yield $data;
+ } else { // resource
+ while (!feof($data)) {
+ if ($read = fread($data, length: self::BUF_SIZE)) {
+ yield $read;
+ }
+ }
+ }
+ } elseif (is_string($val) || is_numeric($val) || is_bool($val)) {
+ yield sprintf($contentLine, $contentType ?? 'text/plain');
+
+ yield self::strVal($val);
+ } else {
+ yield sprintf($contentLine, $contentType ?? 'application/json');
+
+ yield json_encode($val, flags: self::JSON_ENCODE_FLAGS);
+ }
+
+ yield "\r\n";
+ }
+
+ /**
+ * @param list $closing
+ *
+ * @return \Generator
+ */
+ private static function writeMultipartChunk(
+ string $boundary,
+ ?string $key,
+ mixed $val,
+ array &$closing
+ ): \Generator {
+ yield "--{$boundary}\r\n";
+
+ yield 'Content-Disposition: form-data';
+
+ if (!is_null($key)) {
+ $name = str_replace(['"', "\r", "\n"], replace: '', subject: $key);
+
+ yield "; name=\"{$name}\"";
+ }
+
+ // File uploads require a filename in the Content-Disposition header,
+ // e.g. `Content-Disposition: form-data; name="file"; filename="data.csv"`
+ // Without this, many servers will reject the upload with a 400.
+ if ($val instanceof FileParam) {
+ $filename = str_replace(['"', "\r", "\n"], replace: '', subject: $val->filename);
+
+ yield "; filename=\"{$filename}\"";
+ }
+
+ yield "\r\n";
+ foreach (self::writeMultipartContent($val, closing: $closing) as $chunk) {
+ yield $chunk;
+ }
+ }
+
+ /**
+ * Expands list arrays into separate multipart parts, applying the configured array key format.
+ *
+ * @param list $closing
+ *
+ * @return \Generator
+ */
+ private static function writeMultipartField(
+ string $boundary,
+ ?string $key,
+ mixed $val,
+ array &$closing
+ ): \Generator {
+ if (is_array($val) && array_is_list($val)) {
+ foreach ($val as $item) {
+ yield from self::writeMultipartField(boundary: $boundary, key: $key, val: $item, closing: $closing);
+ }
+ } else {
+ yield from self::writeMultipartChunk(boundary: $boundary, key: $key, val: $val, closing: $closing);
+ }
+ }
+
+ /**
+ * @param bool|int|float|string|resource|\Traversable|array|null $body
+ *
+ * @return array{string, \Generator}
+ */
+ private static function encodeMultipartStreaming(mixed $body): array
+ {
+ $boundary = rtrim(strtr(base64_encode(random_bytes(60)), '+/', '-_'), '=');
+ $gen = (function () use ($boundary, $body) {
+ $closing = [];
+
+ try {
+ if (is_array($body) || is_object($body)) {
+ foreach ((array) $body as $key => $val) {
+ yield from static::writeMultipartField(boundary: $boundary, key: $key, val: $val, closing: $closing);
+ }
+ } else {
+ yield from static::writeMultipartField(boundary: $boundary, key: null, val: $body, closing: $closing);
+ }
+
+ yield "--{$boundary}--\r\n";
+ } finally {
+ foreach ($closing as $c) {
+ $c();
+ }
+ }
+ })();
+
+ return [$boundary, $gen];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataField.php b/src/CustomMetadataFields/CustomMetadataField.php
new file mode 100644
index 00000000..415487b0
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataField.php
@@ -0,0 +1,141 @@
+ */
+ use SdkModel;
+
+ /**
+ * Unique identifier for the custom metadata field. Use this to update the field.
+ */
+ #[Required]
+ public string $id;
+
+ /**
+ * Human readable name of the custom metadata field. This name is displayed as form field label to the users while setting field value on the asset in the media library UI.
+ */
+ #[Required]
+ public string $label;
+
+ /**
+ * API name of the custom metadata field. This becomes the key while setting `customMetadata` (key-value object) for an asset using upload or update API.
+ */
+ #[Required]
+ public string $name;
+
+ /**
+ * An object that describes the rules for the custom metadata field value.
+ */
+ #[Required]
+ public Schema $schema;
+
+ /**
+ * `new CustomMetadataField()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * CustomMetadataField::with(id: ..., label: ..., name: ..., schema: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new CustomMetadataField)
+ * ->withID(...)
+ * ->withLabel(...)
+ * ->withName(...)
+ * ->withSchema(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param Schema|SchemaShape $schema
+ */
+ public static function with(
+ string $id,
+ string $label,
+ string $name,
+ Schema|array $schema
+ ): self {
+ $self = new self;
+
+ $self['id'] = $id;
+ $self['label'] = $label;
+ $self['name'] = $name;
+ $self['schema'] = $schema;
+
+ return $self;
+ }
+
+ /**
+ * Unique identifier for the custom metadata field. Use this to update the field.
+ */
+ public function withID(string $id): self
+ {
+ $self = clone $this;
+ $self['id'] = $id;
+
+ return $self;
+ }
+
+ /**
+ * Human readable name of the custom metadata field. This name is displayed as form field label to the users while setting field value on the asset in the media library UI.
+ */
+ public function withLabel(string $label): self
+ {
+ $self = clone $this;
+ $self['label'] = $label;
+
+ return $self;
+ }
+
+ /**
+ * API name of the custom metadata field. This becomes the key while setting `customMetadata` (key-value object) for an asset using upload or update API.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * An object that describes the rules for the custom metadata field value.
+ *
+ * @param Schema|SchemaShape $schema
+ */
+ public function withSchema(Schema|array $schema): self
+ {
+ $self = clone $this;
+ $self['schema'] = $schema;
+
+ return $self;
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataField/Schema.php b/src/CustomMetadataFields/CustomMetadataField/Schema.php
new file mode 100644
index 00000000..18e262ba
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataField/Schema.php
@@ -0,0 +1,254 @@
+,
+ * defaultValue?: DefaultValueShape|null,
+ * isValueRequired?: bool|null,
+ * maxLength?: float|null,
+ * maxValue?: MaxValueShape|null,
+ * minLength?: float|null,
+ * minValue?: MinValueShape|null,
+ * selectOptions?: list|null,
+ * }
+ */
+final class Schema implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * Type of the custom metadata field.
+ *
+ * @var value-of $type
+ */
+ #[Required(enum: Type::class)]
+ public string $type;
+
+ /**
+ * The default value for this custom metadata field. Data type of default value depends on the field type.
+ *
+ * @var DefaultValueVariants|null $defaultValue
+ */
+ #[Optional(union: DefaultValue::class)]
+ public string|float|bool|array|null $defaultValue;
+
+ /**
+ * Specifies if the this custom metadata field is required or not.
+ */
+ #[Optional]
+ public ?bool $isValueRequired;
+
+ /**
+ * Maximum length of string. Only set if `type` is set to `Text` or `Textarea`.
+ */
+ #[Optional]
+ public ?float $maxLength;
+
+ /**
+ * Maximum value of the field. Only set if field type is `Date` or `Number`. For `Date` type field, the value will be in ISO8601 string format. For `Number` type field, it will be a numeric value.
+ *
+ * @var MaxValueVariants|null $maxValue
+ */
+ #[Optional]
+ public string|float|null $maxValue;
+
+ /**
+ * Minimum length of string. Only set if `type` is set to `Text` or `Textarea`.
+ */
+ #[Optional]
+ public ?float $minLength;
+
+ /**
+ * Minimum value of the field. Only set if field type is `Date` or `Number`. For `Date` type field, the value will be in ISO8601 string format. For `Number` type field, it will be a numeric value.
+ *
+ * @var MinValueVariants|null $minValue
+ */
+ #[Optional]
+ public string|float|null $minValue;
+
+ /**
+ * An array of allowed values when field type is `SingleSelect` or `MultiSelect`.
+ *
+ * @var list|null $selectOptions
+ */
+ #[Optional(list: SelectOption::class)]
+ public ?array $selectOptions;
+
+ /**
+ * `new Schema()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * Schema::with(type: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new Schema)->withType(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param Type|value-of $type
+ * @param DefaultValueShape|null $defaultValue
+ * @param MaxValueShape|null $maxValue
+ * @param MinValueShape|null $minValue
+ * @param list|null $selectOptions
+ */
+ public static function with(
+ Type|string $type,
+ string|float|bool|array|null $defaultValue = null,
+ ?bool $isValueRequired = null,
+ ?float $maxLength = null,
+ string|float|null $maxValue = null,
+ ?float $minLength = null,
+ string|float|null $minValue = null,
+ ?array $selectOptions = null,
+ ): self {
+ $self = new self;
+
+ $self['type'] = $type;
+
+ null !== $defaultValue && $self['defaultValue'] = $defaultValue;
+ null !== $isValueRequired && $self['isValueRequired'] = $isValueRequired;
+ null !== $maxLength && $self['maxLength'] = $maxLength;
+ null !== $maxValue && $self['maxValue'] = $maxValue;
+ null !== $minLength && $self['minLength'] = $minLength;
+ null !== $minValue && $self['minValue'] = $minValue;
+ null !== $selectOptions && $self['selectOptions'] = $selectOptions;
+
+ return $self;
+ }
+
+ /**
+ * Type of the custom metadata field.
+ *
+ * @param Type|value-of $type
+ */
+ public function withType(Type|string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * The default value for this custom metadata field. Data type of default value depends on the field type.
+ *
+ * @param DefaultValueShape $defaultValue
+ */
+ public function withDefaultValue(
+ string|float|bool|array $defaultValue
+ ): self {
+ $self = clone $this;
+ $self['defaultValue'] = $defaultValue;
+
+ return $self;
+ }
+
+ /**
+ * Specifies if the this custom metadata field is required or not.
+ */
+ public function withIsValueRequired(bool $isValueRequired): self
+ {
+ $self = clone $this;
+ $self['isValueRequired'] = $isValueRequired;
+
+ return $self;
+ }
+
+ /**
+ * Maximum length of string. Only set if `type` is set to `Text` or `Textarea`.
+ */
+ public function withMaxLength(float $maxLength): self
+ {
+ $self = clone $this;
+ $self['maxLength'] = $maxLength;
+
+ return $self;
+ }
+
+ /**
+ * Maximum value of the field. Only set if field type is `Date` or `Number`. For `Date` type field, the value will be in ISO8601 string format. For `Number` type field, it will be a numeric value.
+ *
+ * @param MaxValueShape $maxValue
+ */
+ public function withMaxValue(string|float $maxValue): self
+ {
+ $self = clone $this;
+ $self['maxValue'] = $maxValue;
+
+ return $self;
+ }
+
+ /**
+ * Minimum length of string. Only set if `type` is set to `Text` or `Textarea`.
+ */
+ public function withMinLength(float $minLength): self
+ {
+ $self = clone $this;
+ $self['minLength'] = $minLength;
+
+ return $self;
+ }
+
+ /**
+ * Minimum value of the field. Only set if field type is `Date` or `Number`. For `Date` type field, the value will be in ISO8601 string format. For `Number` type field, it will be a numeric value.
+ *
+ * @param MinValueShape $minValue
+ */
+ public function withMinValue(string|float $minValue): self
+ {
+ $self = clone $this;
+ $self['minValue'] = $minValue;
+
+ return $self;
+ }
+
+ /**
+ * An array of allowed values when field type is `SingleSelect` or `MultiSelect`.
+ *
+ * @param list $selectOptions
+ */
+ public function withSelectOptions(array $selectOptions): self
+ {
+ $self = clone $this;
+ $self['selectOptions'] = $selectOptions;
+
+ return $self;
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataField/Schema/DefaultValue.php b/src/CustomMetadataFields/CustomMetadataField/Schema/DefaultValue.php
new file mode 100644
index 00000000..16fb1365
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataField/Schema/DefaultValue.php
@@ -0,0 +1,32 @@
+
+ * @phpstan-type DefaultValueShape = DefaultValueVariants|list
+ */
+final class DefaultValue implements ConverterSource
+{
+ use SdkUnion;
+
+ /**
+ * @return list|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float', 'bool', new ListOf(Mixed_::class)];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataField/Schema/DefaultValue/Mixed_.php b/src/CustomMetadataFields/CustomMetadataField/Schema/DefaultValue/Mixed_.php
new file mode 100644
index 00000000..eb6905b8
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataField/Schema/DefaultValue/Mixed_.php
@@ -0,0 +1,26 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float', 'bool'];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataField/Schema/MaxValue.php b/src/CustomMetadataFields/CustomMetadataField/Schema/MaxValue.php
new file mode 100644
index 00000000..19073221
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataField/Schema/MaxValue.php
@@ -0,0 +1,28 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float'];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataField/Schema/MinValue.php b/src/CustomMetadataFields/CustomMetadataField/Schema/MinValue.php
new file mode 100644
index 00000000..cf627712
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataField/Schema/MinValue.php
@@ -0,0 +1,28 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float'];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataField/Schema/SelectOption.php b/src/CustomMetadataFields/CustomMetadataField/Schema/SelectOption.php
new file mode 100644
index 00000000..501e46fd
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataField/Schema/SelectOption.php
@@ -0,0 +1,26 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float', 'bool'];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataField/Schema/Type.php b/src/CustomMetadataFields/CustomMetadataField/Schema/Type.php
new file mode 100644
index 00000000..3c5e1691
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataField/Schema/Type.php
@@ -0,0 +1,25 @@
+ */
+ use SdkModel;
+ use SdkParams;
+
+ /**
+ * Human readable name of the custom metadata field. This should be unique across all non deleted custom metadata fields. This name is displayed as form field label to the users while setting field value on an asset in the media library UI.
+ */
+ #[Required]
+ public string $label;
+
+ /**
+ * API name of the custom metadata field. This should be unique across all (including deleted) custom metadata fields.
+ */
+ #[Required]
+ public string $name;
+
+ #[Required]
+ public Schema $schema;
+
+ /**
+ * `new CustomMetadataFieldCreateParams()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * CustomMetadataFieldCreateParams::with(label: ..., name: ..., schema: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new CustomMetadataFieldCreateParams)
+ * ->withLabel(...)
+ * ->withName(...)
+ * ->withSchema(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param Schema|SchemaShape $schema
+ */
+ public static function with(
+ string $label,
+ string $name,
+ Schema|array $schema
+ ): self {
+ $self = new self;
+
+ $self['label'] = $label;
+ $self['name'] = $name;
+ $self['schema'] = $schema;
+
+ return $self;
+ }
+
+ /**
+ * Human readable name of the custom metadata field. This should be unique across all non deleted custom metadata fields. This name is displayed as form field label to the users while setting field value on an asset in the media library UI.
+ */
+ public function withLabel(string $label): self
+ {
+ $self = clone $this;
+ $self['label'] = $label;
+
+ return $self;
+ }
+
+ /**
+ * API name of the custom metadata field. This should be unique across all (including deleted) custom metadata fields.
+ */
+ public function withName(string $name): self
+ {
+ $self = clone $this;
+ $self['name'] = $name;
+
+ return $self;
+ }
+
+ /**
+ * @param Schema|SchemaShape $schema
+ */
+ public function withSchema(Schema|array $schema): self
+ {
+ $self = clone $this;
+ $self['schema'] = $schema;
+
+ return $self;
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema.php b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema.php
new file mode 100644
index 00000000..0e699657
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema.php
@@ -0,0 +1,252 @@
+,
+ * defaultValue?: DefaultValueShape|null,
+ * isValueRequired?: bool|null,
+ * maxLength?: float|null,
+ * maxValue?: MaxValueShape|null,
+ * minLength?: float|null,
+ * minValue?: MinValueShape|null,
+ * selectOptions?: list|null,
+ * }
+ */
+final class Schema implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * Type of the custom metadata field.
+ *
+ * @var value-of $type
+ */
+ #[Required(enum: Type::class)]
+ public string $type;
+
+ /**
+ * The default value for this custom metadata field. This property is only required if `isValueRequired` property is set to `true`. The value should match the `type` of custom metadata field.
+ *
+ * @var DefaultValueVariants|null $defaultValue
+ */
+ #[Optional(union: DefaultValue::class)]
+ public string|float|bool|array|null $defaultValue;
+
+ /**
+ * Sets this custom metadata field as required. Setting custom metadata fields on an asset will throw error if the value for all required fields are not present in upload or update asset API request body.
+ */
+ #[Optional]
+ public ?bool $isValueRequired;
+
+ /**
+ * Maximum length of string. Only set this property if `type` is set to `Text` or `Textarea`.
+ */
+ #[Optional]
+ public ?float $maxLength;
+
+ /**
+ * Maximum value of the field. Only set this property if field type is `Date` or `Number`. For `Date` type field, set the minimum date in ISO8601 string format. For `Number` type field, set the minimum numeric value.
+ *
+ * @var MaxValueVariants|null $maxValue
+ */
+ #[Optional]
+ public string|float|null $maxValue;
+
+ /**
+ * Minimum length of string. Only set this property if `type` is set to `Text` or `Textarea`.
+ */
+ #[Optional]
+ public ?float $minLength;
+
+ /**
+ * Minimum value of the field. Only set this property if field type is `Date` or `Number`. For `Date` type field, set the minimum date in ISO8601 string format. For `Number` type field, set the minimum numeric value.
+ *
+ * @var MinValueVariants|null $minValue
+ */
+ #[Optional]
+ public string|float|null $minValue;
+
+ /**
+ * An array of allowed values. This property is only required if `type` property is set to `SingleSelect` or `MultiSelect`.
+ *
+ * @var list|null $selectOptions
+ */
+ #[Optional(list: SelectOption::class)]
+ public ?array $selectOptions;
+
+ /**
+ * `new Schema()` is missing required properties by the API.
+ *
+ * To enforce required parameters use
+ * ```
+ * Schema::with(type: ...)
+ * ```
+ *
+ * Otherwise ensure the following setters are called
+ *
+ * ```
+ * (new Schema)->withType(...)
+ * ```
+ */
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param Type|value-of $type
+ * @param DefaultValueShape|null $defaultValue
+ * @param MaxValueShape|null $maxValue
+ * @param MinValueShape|null $minValue
+ * @param list|null $selectOptions
+ */
+ public static function with(
+ Type|string $type,
+ string|float|bool|array|null $defaultValue = null,
+ ?bool $isValueRequired = null,
+ ?float $maxLength = null,
+ string|float|null $maxValue = null,
+ ?float $minLength = null,
+ string|float|null $minValue = null,
+ ?array $selectOptions = null,
+ ): self {
+ $self = new self;
+
+ $self['type'] = $type;
+
+ null !== $defaultValue && $self['defaultValue'] = $defaultValue;
+ null !== $isValueRequired && $self['isValueRequired'] = $isValueRequired;
+ null !== $maxLength && $self['maxLength'] = $maxLength;
+ null !== $maxValue && $self['maxValue'] = $maxValue;
+ null !== $minLength && $self['minLength'] = $minLength;
+ null !== $minValue && $self['minValue'] = $minValue;
+ null !== $selectOptions && $self['selectOptions'] = $selectOptions;
+
+ return $self;
+ }
+
+ /**
+ * Type of the custom metadata field.
+ *
+ * @param Type|value-of $type
+ */
+ public function withType(Type|string $type): self
+ {
+ $self = clone $this;
+ $self['type'] = $type;
+
+ return $self;
+ }
+
+ /**
+ * The default value for this custom metadata field. This property is only required if `isValueRequired` property is set to `true`. The value should match the `type` of custom metadata field.
+ *
+ * @param DefaultValueShape $defaultValue
+ */
+ public function withDefaultValue(
+ string|float|bool|array $defaultValue
+ ): self {
+ $self = clone $this;
+ $self['defaultValue'] = $defaultValue;
+
+ return $self;
+ }
+
+ /**
+ * Sets this custom metadata field as required. Setting custom metadata fields on an asset will throw error if the value for all required fields are not present in upload or update asset API request body.
+ */
+ public function withIsValueRequired(bool $isValueRequired): self
+ {
+ $self = clone $this;
+ $self['isValueRequired'] = $isValueRequired;
+
+ return $self;
+ }
+
+ /**
+ * Maximum length of string. Only set this property if `type` is set to `Text` or `Textarea`.
+ */
+ public function withMaxLength(float $maxLength): self
+ {
+ $self = clone $this;
+ $self['maxLength'] = $maxLength;
+
+ return $self;
+ }
+
+ /**
+ * Maximum value of the field. Only set this property if field type is `Date` or `Number`. For `Date` type field, set the minimum date in ISO8601 string format. For `Number` type field, set the minimum numeric value.
+ *
+ * @param MaxValueShape $maxValue
+ */
+ public function withMaxValue(string|float $maxValue): self
+ {
+ $self = clone $this;
+ $self['maxValue'] = $maxValue;
+
+ return $self;
+ }
+
+ /**
+ * Minimum length of string. Only set this property if `type` is set to `Text` or `Textarea`.
+ */
+ public function withMinLength(float $minLength): self
+ {
+ $self = clone $this;
+ $self['minLength'] = $minLength;
+
+ return $self;
+ }
+
+ /**
+ * Minimum value of the field. Only set this property if field type is `Date` or `Number`. For `Date` type field, set the minimum date in ISO8601 string format. For `Number` type field, set the minimum numeric value.
+ *
+ * @param MinValueShape $minValue
+ */
+ public function withMinValue(string|float $minValue): self
+ {
+ $self = clone $this;
+ $self['minValue'] = $minValue;
+
+ return $self;
+ }
+
+ /**
+ * An array of allowed values. This property is only required if `type` property is set to `SingleSelect` or `MultiSelect`.
+ *
+ * @param list $selectOptions
+ */
+ public function withSelectOptions(array $selectOptions): self
+ {
+ $self = clone $this;
+ $self['selectOptions'] = $selectOptions;
+
+ return $self;
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/DefaultValue.php b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/DefaultValue.php
new file mode 100644
index 00000000..783cbc57
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/DefaultValue.php
@@ -0,0 +1,32 @@
+
+ * @phpstan-type DefaultValueShape = DefaultValueVariants|list
+ */
+final class DefaultValue implements ConverterSource
+{
+ use SdkUnion;
+
+ /**
+ * @return list|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float', 'bool', new ListOf(Mixed_::class)];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/DefaultValue/Mixed_.php b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/DefaultValue/Mixed_.php
new file mode 100644
index 00000000..5f579928
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/DefaultValue/Mixed_.php
@@ -0,0 +1,26 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float', 'bool'];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/MaxValue.php b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/MaxValue.php
new file mode 100644
index 00000000..7f76b4a1
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/MaxValue.php
@@ -0,0 +1,28 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float'];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/MinValue.php b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/MinValue.php
new file mode 100644
index 00000000..81ec0a2f
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/MinValue.php
@@ -0,0 +1,28 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float'];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/SelectOption.php b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/SelectOption.php
new file mode 100644
index 00000000..792afdb4
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/SelectOption.php
@@ -0,0 +1,26 @@
+|array
+ */
+ public static function variants(): array
+ {
+ return ['string', 'float', 'bool'];
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/Type.php b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/Type.php
new file mode 100644
index 00000000..9918b486
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldCreateParams/Schema/Type.php
@@ -0,0 +1,25 @@
+
+ */
+final class CustomMetadataFieldDeleteResponse implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(): self
+ {
+ return new self;
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldListParams.php b/src/CustomMetadataFields/CustomMetadataFieldListParams.php
new file mode 100644
index 00000000..be00d9be
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldListParams.php
@@ -0,0 +1,84 @@
+ */
+ use SdkModel;
+ use SdkParams;
+
+ /**
+ * The folder path (e.g., `/path/to/folder`) for which to retrieve applicable custom metadata fields. Useful for determining path-specific field selections when the [Path policy](https://imagekit.io/docs/dam/path-policy) feature is in use.
+ */
+ #[Optional]
+ public ?string $folderPath;
+
+ /**
+ * Set it to `true` to include deleted field objects in the API response.
+ */
+ #[Optional]
+ public ?bool $includeDeleted;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ */
+ public static function with(
+ ?string $folderPath = null,
+ ?bool $includeDeleted = null
+ ): self {
+ $self = new self;
+
+ null !== $folderPath && $self['folderPath'] = $folderPath;
+ null !== $includeDeleted && $self['includeDeleted'] = $includeDeleted;
+
+ return $self;
+ }
+
+ /**
+ * The folder path (e.g., `/path/to/folder`) for which to retrieve applicable custom metadata fields. Useful for determining path-specific field selections when the [Path policy](https://imagekit.io/docs/dam/path-policy) feature is in use.
+ */
+ public function withFolderPath(string $folderPath): self
+ {
+ $self = clone $this;
+ $self['folderPath'] = $folderPath;
+
+ return $self;
+ }
+
+ /**
+ * Set it to `true` to include deleted field objects in the API response.
+ */
+ public function withIncludeDeleted(bool $includeDeleted): self
+ {
+ $self = clone $this;
+ $self['includeDeleted'] = $includeDeleted;
+
+ return $self;
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldUpdateParams.php b/src/CustomMetadataFields/CustomMetadataFieldUpdateParams.php
new file mode 100644
index 00000000..a653f397
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldUpdateParams.php
@@ -0,0 +1,89 @@
+ */
+ use SdkModel;
+ use SdkParams;
+
+ /**
+ * Human readable name of the custom metadata field. This should be unique across all non deleted custom metadata fields. This name is displayed as form field label to the users while setting field value on an asset in the media library UI. This parameter is required if `schema` is not provided.
+ */
+ #[Optional]
+ public ?string $label;
+
+ /**
+ * An object that describes the rules for the custom metadata key. This parameter is required if `label` is not provided. Note: `type` cannot be updated and will be ignored if sent with the `schema`. The schema will be validated as per the existing `type`.
+ */
+ #[Optional]
+ public ?Schema $schema;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param Schema|SchemaShape|null $schema
+ */
+ public static function with(
+ ?string $label = null,
+ Schema|array|null $schema = null
+ ): self {
+ $self = new self;
+
+ null !== $label && $self['label'] = $label;
+ null !== $schema && $self['schema'] = $schema;
+
+ return $self;
+ }
+
+ /**
+ * Human readable name of the custom metadata field. This should be unique across all non deleted custom metadata fields. This name is displayed as form field label to the users while setting field value on an asset in the media library UI. This parameter is required if `schema` is not provided.
+ */
+ public function withLabel(string $label): self
+ {
+ $self = clone $this;
+ $self['label'] = $label;
+
+ return $self;
+ }
+
+ /**
+ * An object that describes the rules for the custom metadata key. This parameter is required if `label` is not provided. Note: `type` cannot be updated and will be ignored if sent with the `schema`. The schema will be validated as per the existing `type`.
+ *
+ * @param Schema|SchemaShape $schema
+ */
+ public function withSchema(Schema|array $schema): self
+ {
+ $self = clone $this;
+ $self['schema'] = $schema;
+
+ return $self;
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldUpdateParams/Schema.php b/src/CustomMetadataFields/CustomMetadataFieldUpdateParams/Schema.php
new file mode 100644
index 00000000..c8c84f9c
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldUpdateParams/Schema.php
@@ -0,0 +1,212 @@
+|null,
+ * }
+ */
+final class Schema implements BaseModel
+{
+ /** @use SdkModel */
+ use SdkModel;
+
+ /**
+ * The default value for this custom metadata field. This property is only required if `isValueRequired` property is set to `true`. The value should match the `type` of custom metadata field.
+ *
+ * @var DefaultValueVariants|null $defaultValue
+ */
+ #[Optional(union: DefaultValue::class)]
+ public string|float|bool|array|null $defaultValue;
+
+ /**
+ * Sets this custom metadata field as required. Setting custom metadata fields on an asset will throw error if the value for all required fields are not present in upload or update asset API request body.
+ */
+ #[Optional]
+ public ?bool $isValueRequired;
+
+ /**
+ * Maximum length of string. Only set this property if `type` is set to `Text` or `Textarea`.
+ */
+ #[Optional]
+ public ?float $maxLength;
+
+ /**
+ * Maximum value of the field. Only set this property if field type is `Date` or `Number`. For `Date` type field, set the minimum date in ISO8601 string format. For `Number` type field, set the minimum numeric value.
+ *
+ * @var MaxValueVariants|null $maxValue
+ */
+ #[Optional]
+ public string|float|null $maxValue;
+
+ /**
+ * Minimum length of string. Only set this property if `type` is set to `Text` or `Textarea`.
+ */
+ #[Optional]
+ public ?float $minLength;
+
+ /**
+ * Minimum value of the field. Only set this property if field type is `Date` or `Number`. For `Date` type field, set the minimum date in ISO8601 string format. For `Number` type field, set the minimum numeric value.
+ *
+ * @var MinValueVariants|null $minValue
+ */
+ #[Optional]
+ public string|float|null $minValue;
+
+ /**
+ * An array of allowed values. This property is only required if `type` property is set to `SingleSelect` or `MultiSelect`.
+ *
+ * @var list|null $selectOptions
+ */
+ #[Optional(list: SelectOption::class)]
+ public ?array $selectOptions;
+
+ public function __construct()
+ {
+ $this->initialize();
+ }
+
+ /**
+ * Construct an instance from the required parameters.
+ *
+ * You must use named parameters to construct any parameters with a default value.
+ *
+ * @param DefaultValueShape|null $defaultValue
+ * @param MaxValueShape|null $maxValue
+ * @param MinValueShape|null $minValue
+ * @param list|null $selectOptions
+ */
+ public static function with(
+ string|float|bool|array|null $defaultValue = null,
+ ?bool $isValueRequired = null,
+ ?float $maxLength = null,
+ string|float|null $maxValue = null,
+ ?float $minLength = null,
+ string|float|null $minValue = null,
+ ?array $selectOptions = null,
+ ): self {
+ $self = new self;
+
+ null !== $defaultValue && $self['defaultValue'] = $defaultValue;
+ null !== $isValueRequired && $self['isValueRequired'] = $isValueRequired;
+ null !== $maxLength && $self['maxLength'] = $maxLength;
+ null !== $maxValue && $self['maxValue'] = $maxValue;
+ null !== $minLength && $self['minLength'] = $minLength;
+ null !== $minValue && $self['minValue'] = $minValue;
+ null !== $selectOptions && $self['selectOptions'] = $selectOptions;
+
+ return $self;
+ }
+
+ /**
+ * The default value for this custom metadata field. This property is only required if `isValueRequired` property is set to `true`. The value should match the `type` of custom metadata field.
+ *
+ * @param DefaultValueShape $defaultValue
+ */
+ public function withDefaultValue(
+ string|float|bool|array $defaultValue
+ ): self {
+ $self = clone $this;
+ $self['defaultValue'] = $defaultValue;
+
+ return $self;
+ }
+
+ /**
+ * Sets this custom metadata field as required. Setting custom metadata fields on an asset will throw error if the value for all required fields are not present in upload or update asset API request body.
+ */
+ public function withIsValueRequired(bool $isValueRequired): self
+ {
+ $self = clone $this;
+ $self['isValueRequired'] = $isValueRequired;
+
+ return $self;
+ }
+
+ /**
+ * Maximum length of string. Only set this property if `type` is set to `Text` or `Textarea`.
+ */
+ public function withMaxLength(float $maxLength): self
+ {
+ $self = clone $this;
+ $self['maxLength'] = $maxLength;
+
+ return $self;
+ }
+
+ /**
+ * Maximum value of the field. Only set this property if field type is `Date` or `Number`. For `Date` type field, set the minimum date in ISO8601 string format. For `Number` type field, set the minimum numeric value.
+ *
+ * @param MaxValueShape $maxValue
+ */
+ public function withMaxValue(string|float $maxValue): self
+ {
+ $self = clone $this;
+ $self['maxValue'] = $maxValue;
+
+ return $self;
+ }
+
+ /**
+ * Minimum length of string. Only set this property if `type` is set to `Text` or `Textarea`.
+ */
+ public function withMinLength(float $minLength): self
+ {
+ $self = clone $this;
+ $self['minLength'] = $minLength;
+
+ return $self;
+ }
+
+ /**
+ * Minimum value of the field. Only set this property if field type is `Date` or `Number`. For `Date` type field, set the minimum date in ISO8601 string format. For `Number` type field, set the minimum numeric value.
+ *
+ * @param MinValueShape $minValue
+ */
+ public function withMinValue(string|float $minValue): self
+ {
+ $self = clone $this;
+ $self['minValue'] = $minValue;
+
+ return $self;
+ }
+
+ /**
+ * An array of allowed values. This property is only required if `type` property is set to `SingleSelect` or `MultiSelect`.
+ *
+ * @param list $selectOptions
+ */
+ public function withSelectOptions(array $selectOptions): self
+ {
+ $self = clone $this;
+ $self['selectOptions'] = $selectOptions;
+
+ return $self;
+ }
+}
diff --git a/src/CustomMetadataFields/CustomMetadataFieldUpdateParams/Schema/DefaultValue.php b/src/CustomMetadataFields/CustomMetadataFieldUpdateParams/Schema/DefaultValue.php
new file mode 100644
index 00000000..41b9726c
--- /dev/null
+++ b/src/CustomMetadataFields/CustomMetadataFieldUpdateParams/Schema/DefaultValue.php
@@ -0,0 +1,32 @@
+
+ * @phpstan-type DefaultValueShape = DefaultValueVariants|list
+ */
+final class DefaultValue implements ConverterSource
+{
+ use SdkUnion;
+
+ /**
+ * @return list