CINXE.COM
Packagist
<!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <title>Packagist</title> <meta name="description" content="The PHP Package Repository" /> <meta name="author" content="Jordi Boggiano" /> <meta name="canonical" href="https://packagist.org/apidoc" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <link rel="shortcut icon" href="/favicon.ico?v=1743695794" /> <link rel="stylesheet" href="/build/app.css?v=1743695794" /> <link rel="alternate" type="application/rss+xml" title="Newly Submitted Packages - Packagist" href="https://packagist.org/feeds/packages.rss" /> <link rel="alternate" type="application/rss+xml" title="New Releases - Packagist" href="https://packagist.org/feeds/releases.rss" /> <link rel="search" type="application/opensearchdescription+xml" href="/search.osd?v=1743695794" title="Packagist" /> <script nonce="su1CPKanQT6gyX86/pxDRw=="> var onloadRecaptchaCallback = function() { document.querySelectorAll('.recaptcha-protected').forEach((el) => { el.closest('form').querySelectorAll('button, input[type="submit"]').forEach((submit) => { grecaptcha.render(submit, { 'sitekey' : '6LfKiPoUAAAAAGlKWkhEEx7X8muIVYy6oA0GNdX0', 'callback' : function (token) { submit.form.submit(); } }); }) }); }; </script> </head> <body> <section class="wrap"> <header class="navbar-wrapper navbar-fixed-top"> <section class="banner alert-error hidden"> Composer v1 support is <a href="https://blog.packagist.com/shutting-down-packagist-org-support-for-composer-1-x/">coming to an end</a> <i class="glyphicon glyphicon-remove banner-close" data-banner-id="composer1eol"></i> </section> <nav class="container"> <div class="navbar" role="navigation"> <div class="navbar-header"> <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse"> <span class="sr-only">Toggle navigation</span> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button> <h1 class="navbar-brand"><a href="/">Packagist</a> <em class="hidden-sm hidden-xs">The PHP Package Repository</em></h1> </div> <div class="collapse navbar-collapse"> <ul class="nav navbar-nav"> <li> <a href="/explore/">Browse</a> </li> <li> <a href="/packages/submit">Submit</a> </li> <li> <a href="/register/">Create account</a> </li> <li class="nav-user"> <section class="nav-user-signin"> <a href="/login/">Sign in</a> <section class="signin-box"> <form action="/login/" method="POST" id="nav_login"> <div class="input-group"> <input class="form-control" type="text" id="_username" name="_username" placeholder="Username / Email"> <span class="input-group-addon"><span class="icon-user"></span></span> </div> <div class="input-group"> <input class="form-control" type="password" id="_password" name="_password" placeholder="Password"> <span class="input-group-addon"><span class="icon-lock"></span></span> </div> <div class="checkbox"> <label for="_remember_me"> <input type="checkbox" id="_remember_me" name="_remember_me" value="on" checked="checked" /> Remember me </label> </div> <div class="signin-box-buttons"> <a href="/login/github" class="pull-right btn btn-primary btn-github"><span class="icon-github"></span>Use Github</a> <button type="submit" class="btn btn-success" id="_submit_mini" name="_submit">Log in</button> </div> </form> <div class="signin-box-register"> <a href="/register/">No account yet? Create one now!</a> </div> </section> </section> </li> </ul> </div> </div> </nav> </header> <section class="wrapper wrapper-search"> <div class="container with-description"> <form name="search_query" method="get" action="/search/" id="search-form" autocomplete="off"> <div class="sortable row"> <div class="col-xs-12 js-search-field-wrapper col-md-9"> <input type="search" id="search_query_query" name="query" required="required" autocomplete="off" placeholder="Search packages..." tabindex="1" class=" form-control" value="" /> </div> </div> </form> <div class="row"> <div class="col-sm-9 hidden-xs"> <img src="/img/logo-small.png?v=1743695794" class="logo"> <p>Packagist is the main <a href="https://getcomposer.org/">Composer</a> repository. It aggregates public PHP packages installable with Composer. </p> </div> </div> </div> </section> <section class="wrapper"> <section class="container content" role="main"> <div id="search-container" class="hidden"> <div class="row"> <div class="search-list col-md-9"></div> <div class="search-facets col-md-3"> <div class="search-facets-active-filters"></div> <div class="search-facets-type"></div> <div class="search-facets-tags"></div> </div> </div> <div class="row"> <div class="col-md-9"> <div id="powered-by"> Search by <a href="https://www.algolia.com/"><img src="/img/algolia-logo-light.svg?v=1743695794"></a> </div> <div id="pagination-container"> <div class="pagination"></div> </div> </div> </div> </div> <h2 class="title">API documentation</h2> <ul class="toc"> <li><a href="#best-practices">Best practices</a></li> <li><a href="#list-packages">Listing package names</a> <ul> <li><a href="#list-packages-all">All packages</a></li> <li><a href="#list-packages-by-organization">By organization</a></li> <li><a href="#list-packages-by-type">By type</a></li> <li><a href="#list-packages-with-fields">With additional data</a></li> </ul> </li> <li><a href="#list-popular-packages">List popular packages</a></li> <li><a href="#search-packages">Searching for packages</a> <ul> <li><a href="#search-packages-by-tag">By tag</a></li> <li><a href="#search-packages-by-name">By name</a></li> <li><a href="#search-packages-by-type">By type</a></li> </ul> </li> <li><a href="#get-package-data">Getting package data</a></li> <li><a href="#get-package-stats">Get package download stats</a></li> <li><a href="#track-package-updates">Track package updates</a></li> <li><a href="#get-statistics">Get statistics</a></li> <li><a href="#list-security-advisories">List security advisories</a></li> <li><a href="#create-package">Create a package</a></li> <li><a href="#edit-package">Edit a package</a></li> <li><a href="#update-package">Update a package</a></li> </ul> <section class="col-d-12"> <h3 id="best-practices">Best practices when using the Packagist.org API</h3> <ul> <li>If you do scheduled jobs, <strong>avoid running things at midnight or once an hour at XX:00</strong>. Most people do so and we do see traffic peaks every hour. Pick a "random" time by hand for your cron jobs, or even better (if you can) is to make it run on a really randomized schedule.</li> <li><strong>Send a User-Agent header</strong> with all your requests including an email or twitter or some sort of contact information so we can reach out to you if we have an issue with the way you use the API. If not you can leave us with no choice but to block IPs which we'd rather not do.</li> <li>If you send requests in parallel, be a good citizen and do a <strong>maximum of 10 concurrent requests</strong>, or up to 20 if you only fetch static files. Huge bursts in requests can cause issues for other regular users so try to spread out the load.</li> <li>Use an <strong>HTTP/2</strong>-capable client and make sure you enable that, it is much more efficient than reconnecting for every request.</li> </ul> </section> <section class="col-d-12"> <h3 id="list-packages">Listing package names</h3> <h4 id="list-packages-all">All packages</h4> <pre> GET https://packagist.org/packages/list.json <code> { "packageNames": [ "[vendor]/[package]", ... ] } </code></pre> <p>Working example: <code><a href="https://packagist.org/packages/list.json">https://packagist.org/packages/list.json</a></code></p> <h4 id="list-packages-by-organization">List packages by organization</h4> <pre> GET https://packagist.org/packages/list.json?vendor=[vendor] <code> { "packageNames": [ "[vendor]/[package]", ... ] } </code></pre> <p>Working example: <code><a href="https://packagist.org/packages/list.json?vendor=composer">https://packagist.org/packages/list.json?vendor=composer</a></code></p> <h4 id="list-packages-by-type">List packages by type</h4> <pre> GET https://packagist.org/packages/list.json?type=[type] <code> { "packageNames": [ "[vendor]/[package]", ... ] } </code></pre> <p>Working example: <code><a href="https://packagist.org/packages/list.json?type=composer-plugin">https://packagist.org/packages/list.json?type=composer-plugin</a></code></p> <h4 id="list-packages-with-fields">Retrieving additional data if the name is not enough</h4> <p>If you need more than just package names you can additionally request one or more fields to be returned with every package. Currently supported fields are: <code>repository</code>, <code>type</code>, and <code>abandoned</code>.</p> <p>Note that when requesting fields, the response structure is different.</p> <pre> GET https://packagist.org/packages/list.json?vendor=[type]&fields[]=type&fields[]=repository&fields[]=abandoned <code> { "package": { "[vendor]/[package]": { "type": "library", "repository": "https://...", "abandoned": false|true|string (with advised replacement) }, ... } } </code></pre> <p>Working example: <code><a href="https://packagist.org/packages/list.json?vendor=composer&fields[]=repository&fields[]=type">https://packagist.org/packages/list.json?vendor=composer&fields[]=repository&fields[]=type</a></code></p> </section> <section class="col-d-12"> <h3 id="list-popular-packages">List popular packages</h3> <p>If you need to retrieve the most popular (this is sorted by downloads over the last week, not overall downloads to ensure we demote formerly-popular packages) packages please use this endpoint to avoid having to request the download stats for all of our 300K+ packages individually. This also includes faver count (github stars + packagist.org favorites) and downloads count. The API is paginated if you need more than 100.</p> <pre> GET https://packagist.org/explore/popular.json?per_page=100 <code> { "packages": [ { "name": "[vendor]/[package]", "description": "[description]", "url": "https://packagist.org/packages/[vendor]/[package]", "downloads": 123456, "favers": 123 }, ... ], "total": 123456, "next": "https://packagist.org/explore/popular.json?page=2&per_page=100" } </code></pre> <p>Working example: <code><a href="https://packagist.org/explore/popular.json?per_page=100">https://packagist.org/explore/popular.json?per_page=100</a></code></p> </section> <section class="col-d-12"> <h3 id="search-packages">Searching for packages</h3> <p>Search results are paginated and you can change the pagination step by using the per_page parameter. For example <code>https://packagist.org/search.json?q=[query]&per_page=5</code></p> <h4 id="search-packages-by-name">Search packages by name</h4> <pre> GET https://packagist.org/search.json?q=[query] <code> { "results" : [ { "name": "[vendor]/[package]", "description": "[description]", "url": "https://packagist.org/packages/[vendor]/[package]", "repository": [repository url], "downloads": [number of downloads], "favers": [number of favers] }, ... ], "total": [number of results], "next": "https://packagist.org/search.json?q=[query]&page=[next page number]" } </code></pre> <p>Working example: <code><a href="https://packagist.org/search.json?q=monolog">https://packagist.org/search.json?q=monolog</a></code></p> <h4 id="search-packages-by-tag">Search packages by tag</h4> <pre> GET https://packagist.org/search.json?tags=[tag] <code> { "results": [ { "name": "[vendor]/[package]", "description": "[description]", "url": "https://packagist.org/packages/[vendor]/[package]", "repository": "[repository url]", "downloads": [number of downloads], "favers": [number of favers] } ... ], "total": [numbers of results] } </code></pre> <p>Working example: <code><a href="https://packagist.org/search.json?q=monolog&tags=psr-3">https://packagist.org/search.json?q=monolog&tags=psr-3</a></code></p> <h4 id="search-packages-by-type">Search packages by type</h4> <pre> GET https://packagist.org/search.json?q=[query]&type=symfony-bundle <code> { "results" : [ { "name": "[vendor]/[package]", "description": "[description]", "url": "https://packagist.org/packages/[vendor]/[package]", "repository": [repository url], "downloads": [number of downloads], "favers": [number of favers] }, ... ], "total": [number of results], "next": "https://packagist.org/search.json?q=[query]&page=[next page number]" } </code></pre> <p>Working example: <code><a href="https://packagist.org/search.json?q=monolog&type=symfony-bundle">https://packagist.org/search.json?q=monolog&type=symfony-bundle</a></code></p> </section> <section class="col-d-12"> <h3 id="get-package-data">Getting package data</h3> <h4 id="get-package-metadata-v2">Using the Composer v2 metadata</h4> <p>This is the preferred way to access the data as it is always up to date, and dumped to static files so it is very efficient on our end.</p> <p>You can also send <code>If-Modified-Since</code> headers to limit your bandwidth usage and cache the files on your end with the proper filemtime set according to our <code>Last-Modified</code> header.</p> <p>There are a few gotchas though with using this method: <ul> <li>It only provides you with the package metadata but not information about the maintainers, download stats or github info.</li> <li>It is in a compressed format for efficiency which requires you to use <code><a href="https://github.com/composer/metadata-minifier/blob/main/src/MetadataMinifier.php#L17">Composer\MetadataMinifier\MetadataMinifier::expand($response['packages'][$packageName])</a></code> from the <a href="https://packagist.org/packages/composer/metadata-minifier">composer/metadata-minifier</a> package to restore it to the full data.</li> <li>The <code>p2/$vendor/$package.json</code> file contains only tagged releases. If you want to fetch information about branches (i.e. dev versions) you need to download <code>p2/$vendor/$package~dev.json</code>.</li> </ul> </p> <pre> GET https://repo.packagist.org/p2/[vendor]/[package].json <code> { "packages": { "[vendor]/[package]": [ { "name": "[vendor]/[package], "description": [description], "version": "[version1]", // ... }, { "version": "[version2]", // ... } // ... ] }, "minified": "composer/2.0" } </code></pre> <p>Working examples:</p> <ul> <li>For tagged releases: <code><a href="https://repo.packagist.org/p2/monolog/monolog.json">https://repo.packagist.org/p2/monolog/monolog.json</a></code></li> <li>For dev releases: <code><a href="https://repo.packagist.org/p2/monolog/monolog~dev.json">https://repo.packagist.org/p2/monolog/monolog~dev.json</a></code></li> </ul> <p>Looking to remain up to date and know when packages updated? See the <a href="#track-package-updates">Track package updates</a> API.</p> <h4 id="get-package-metadata-v1">Using the Composer v1 metadata (<a href="https://blog.packagist.com/shutting-down-packagist-org-support-for-composer-1-x/">DEPRECATED</a>, not updated anymore as of February 1st 2025, will be inaccessible from August 1st 2025)</h4> <p>You can also send <code>If-Modified-Since</code> headers to limit your bandwidth usage and cache the files on your end with the proper filemtime set according to our <code>Last-Modified</code> header.</p> <p>There are a few gotchas though with using this method: <ul> <li>It only provides you with the package metadata but not information about the maintainers, download stats or github info.</li> <li>It contains providers information which must be ignored but can appear confusing at first. This will disappear in the future though.</li> <li>It does not provide all packages due to the deprecation of the v1 metadata. <a href="https://blog.packagist.com/deprecating-composer-1-support/">See the announcement</a> for details.</li> </ul> </p> <pre> GET https://repo.packagist.org/p/[vendor]/[package].json <code> { "packages": { "[vendor]/[package]": { "[version1]": { "name": "[vendor]/[package], "description": [description], // ... }, "[version2]": { // ... } // ... } } } </code></pre> <p>Working example: <code><a href="https://repo.packagist.org/p/monolog/monolog.json">https://repo.packagist.org/p/monolog/monolog.json</a></code></p> <h4 id="get-package-by-name">Using the API</h4> <p>The JSON API for packages gives you all the infos we have including downloads, dependents count, github info, etc. However it is generated dynamically so for performance reason we cache the responses for twelve hours. As such if the static file endpoint described above is enough please use it instead.</p> <pre> GET https://packagist.org/packages/[vendor]/[package].json <code> { "package": { "name": "[vendor]/[package], "description": [description], "time": [packagist package creation datetime], "maintainers": [list of maintainers], "versions": [list of versions and their dependencies, the same data of <a href="https://getcomposer.org/doc/01-basic-usage.md#package-versions">composer.json</a>] "type": [package type], "repository": [repository url], "downloads": { "total": [numbers of download], "monthly": [numbers of download per month], "daily": [numbers of download per day] }, "favers": [number of favers] } } </code></pre> <p>Working example: <code><a href="https://packagist.org/packages/monolog/monolog.json">https://packagist.org/packages/monolog/monolog.json</a></code></p> </section> <section class="col-d-12"> <h3 id="get-package-stats">Get package download stats</h3> <p>If you need complete package information and use <a href="#get-package-by-name">the JSON API</a> already then please use the <code>downloads</code> key to retrieve stats from that response.</p> <p>However if you are only interested in download stats for a set of package names, you can use the stats endpoint which includes overall download stats + the faver count (github stars + packagist.org favorites):</p> <pre> GET https://packagist.org/packages/[vendor]/[package]/stats.json <code> { "downloads": { "total": 100, "monthly": 10, "daily": 1 }, "versions": [ "[list of versions]", "[list of versions]" ], "date": "2022-09-15" # stats collection start date } </code></pre> <p>Working example: <code><a href="https://packagist.org/packages/monolog/monolog/stats.json">https://packagist.org/packages/monolog/monolog/stats.json</a></code></p> </section> <section class="col-d-12"> <h3 id="track-package-updates">Track package updates</h3> <p>This endpoint provides you with a feed of metadata changes you can poll to know what packages you need to update.</p> <p>First to initialize this you can poll the API without timestamp to get the most current timestamp, or make your own by using <code>10000 * time()</code>:</p> <pre> GET https://packagist.org/metadata/changes.json <code> { "error": "Invalid or missing "since" query parameter, make sure you store the timestamp at the initial point you started mirroring, then send that to begin receiving changes, e.g. https://packagist.org/metadata/changes.json?since=16142636710498 for example.", "timestamp": 16142636710498 } </code></pre> <p>Working example: <code><a href="https://packagist.org/metadata/changes.json">https://packagist.org/metadata/changes.json</a></code></p> <p>After that, you should store the timestamp for the next time you want to call the API, let's say 10 minutes later you want to know what changed, you call this again but this time you pass the previous timestamp:</p> <pre> GET https://packagist.org/metadata/changes.json?since=16142636710498 <code> { "actions": [ { "type": "update", "package": "acme/package", "time": 1614264954 }, { "type": "update", "package": "foo/bar~dev", "time": 1614264951 }, { "type": "delete", "package": "acme/gone", "time": 1614264953 } ] }</code></pre> <p>Working example: <code><a href="https://packagist.org/metadata/changes.json?since=17438584210000">https://packagist.org/metadata/changes.json?since=17438584210000</a></code></p> <p>In the example above, you receive 3 changes, let's go over what they mean and what you should do to sync these up:</p> <ul> <li><code>acme/update</code> was updated (tagged releases of <code>acme/update</code>), you can fetch <code>https://repo.packagist.org/p2/acme/update.json</code> and should ensure that the <code>Last-Modified</code> is AT LEAST (<code>>=</code>) equal to the <code>time</code> value. If it is older than that, wait a few seconds and retry. Due to internal mirroring delays it may happen that you get a race condition and get an outdated file.</li> <li><code>foo/bar~dev</code> was updated (dev releases of <code>foo/bar</code>, you can fetch <code>https://repo.packagist.org/p2/foo/bar~dev.json</code> and should ensure that the <code>Last-Modified</code> is AT LEAST (<code>>=</code>) equal to the <code>time</code> value.</li> <li><code>acme/gone</code> was deleted, you can delete it on your end as well, this means both <code>acme/gone</code> and <code>acme/gone~dev</code> are deleted.</li> </ul> <p><strong>Warning:</strong> The changes log is kept for up to 24h on our end, so make sure you fetch the API at least once a day or you will get a resync response like the following:</p> <pre> GET https://packagist.org/metadata/changes.json?since=16140636710498 <code> { "actions": [ { "type": "resync", "package": "*", "time": 1614264954 } ] }</code></pre> <p>If you get this, you should assume your data is stale and you should revalidate everything (if you cached files using <code>Last-Modified</code> headers, you can still keep that and make sure with <code>If-Modified-Since</code> requests for every file that it is still up to date).</p> </section> <section class="col-d-12"> <h3 id="get-statistics">Get statistics</h3> <p>This endpoint provides basic some statistics.</p> <pre> GET https://packagist.org/statistics.json <code> { "totals": { "downloads": [numbers of download] } } </code></pre> <p>Working example: <code><a href="https://packagist.org/statistics.json">https://packagist.org/statistics.json</a></code></p> </section> <section class="col-d-12"> <h3 id="list-security-advisories">List security advisories</h3> <p>This endpoint provides a list of security advisories. Either a list of packages as query or request parameter or a timestamp as updatedSince query parameter need to be passed.</p> <p>When querying with a list of packages, known packages will be included in the response with an empty array if they don't have any listed vulnerability. Package names which are not known to have no vulnerability will not be included at all to show that we do not have data on those.</p> <pre> GET https://packagist.org/api/security-advisories/?updatedSince=[timestamp]&packages[]=[vendor/package] <code> { "advisories": { "[vendor]/[package]": [ { "advisoryId": "[unique id]", "packageName": "[vendor]/[package]", "remoteId": "[deprecated, use sources instead]", "title": "[title]", "link": "[url to issue disclosure]", "cve": "[cve if available]", "affectedVersions": [affected version in form of a composer constraint]", "source": "[deprecated, use sources instead]", "sources": [ { "name": "[Name of the source where the advisory was found e.g. GitHub or FriendsOfPHP/security-advisories]" "remoteId": "[A reference to identify the advisory in the source e.g. the GitHub advisory id]" } ], "reportedAt": "[date the issue was reported]", "composerRepository": "[composer repository the package can be found in]", "severity": [severity if available, following the CVSS3 spec] } ] } } </code></pre> <p>Working examples:</p> <ul> <li>Using one or more package names: <code><a href="https://packagist.org/api/security-advisories/?packages[]=monolog/monolog">https://packagist.org/api/security-advisories/?packages[]=monolog/monolog</a></code></li> <li>Fetching new data / updates: <code><a href="https://packagist.org/api/security-advisories/?updatedSince=1743254221">https://packagist.org/api/security-advisories/?updatedSince=1743254221</a></code></li> </ul> </section> <section class="col-d-12"> <h3 id="create-package">Create a package</h3> <p>This endpoint creates a package for a specific repo. Parameters <code>username</code> and <code>apiToken</code> are required. Only the <code>POST</code> method is allowed. The <code>content-type: application/json</code> header is required.</p> <p>This endpoint is considered UNSAFE and requires your main <a href="/profile/">API token</a> to be used.</p> <pre> POST https://packagist.org/api/create-package?username=[username]&apiToken=[apiToken] {"repository":"[url]"} <code> { "status": "success" } </code></pre> <p>Working example:<br/> <code>curl -X POST -H'Content-Type:application/json' 'https://packagist.org/api/create-package?username=USERNAME&apiToken=********' -d '{"repository":"https://github.com/Seldaek/monolog"}'</code> </p> </section> <section class="col-d-12"> <h3 id="edit-package">Edit a package</h3> <p>This endpoint allows you to edit a package URL. Parameters <code>username</code> and <code>apiToken</code> are required. Only the <code>PUT</code> method is allowed. The <code>content-type: application/json</code> header is required.</p> <p>This endpoint is considered UNSAFE and requires your main <a href="/profile/">API token</a> to be used.</p> <pre> PUT https://packagist.org/api/packages/[package name]?username=[username]&apiToken=[apiToken] {"repository":"[url]"} <code> { "status": "success" } </code></pre> <p>Working example:<br/> <code>curl -X POST -H'Content-Type:application/json' 'https://packagist.org/api/packages/monolog/monolog?username=USERNAME&apiToken=********' -d '{"repository":"https://github.com/Seldaek/monolog"}'</code> </p> </section> <section class="col-d-12"> <h3 id="update-package">Update a package</h3> <p>This endpoint updates a package by canonical repository URL or packagist.org package URL. Parameters <code>username</code> and <code>apiToken</code> are required. Only the <code>POST</code> method is allowed. The <code>content-type: application/json</code> header is required.</p> <p>This endpoint is considered SAFE and allows either your main or safe <a href="/profile/">API token</a> to be used.</p> <pre> POST https://packagist.org/api/update-package?username=[username]&apiToken=[apiToken] {"repository":"[url]"} <code> { "status": "success", "jobs": ["job-id", ".."] } </code></pre> <p>Working examples:<br/> <code>curl -X POST -H'Content-Type:application/json' 'https://packagist.org/api/update-package?username=USERNAME&apiToken=********' -d '{"repository":"https://github.com/Seldaek/monolog"}'</code><br/> <code>curl -X POST -H'Content-Type:application/json' 'https://packagist.org/api/update-package?username=USERNAME&apiToken=********' -d '{"repository":"https://packagist.org/monolog/monolog"}'</code> </p> </section> </section> </section> </section> <footer class="wrapper-footer"> <nav class="container"> <div class="row"> <ul class="social col-xs-7 col-sm-4 col-md-2 pull-right"> <li><a href="http://github.com/composer/packagist" title="GitHub"><span class="icon-github"></span></a></li> <li><a href="https://twitter.com/packagist" title="Follow @packagist"><span class="icon-twitter"></span></a></li> <li><a href="mailto:contact@packagist.org" title="Contact"><span class="icon-mail"></span></a></li> </ul> <ul class="col-xs-4 col-sm-4 col-md-2"> <li><a href="/about">About Packagist</a></li> <li><a href="/feeds/" rel="nofollow">Atom/RSS Feeds</a></li> </ul> <div class="clearfix visible-xs-block"></div> <ul class="col-xs-3 col-sm-4 col-md-2"> <li><a href="/statistics" rel="nofollow">Statistics</a></li> <li><a href="/explore/">Browse Packages</a></li> </ul> <div class="clearfix visible-xs-block visible-sm-block"></div> <ul class="col-xs-3 col-sm-4 col-md-2"> <li><a href="/apidoc">API</a></li> <li><a href="/mirrors">Mirrors</a></li> </ul> <div class="clearfix visible-xs-block"></div> <ul class="col-xs-3 col-sm-4 col-md-2"> <li><a href="https://status.packagist.org/">Status</a></li> <li><a href="https://p.datadoghq.com/sb/x98w56x71erzshui-4a54c45f82bacc991e83302548934b6a">Dashboard</a></li> </ul> </div> <div class="row sponsor"> <p class="col-xs-12 col-md-6">Maintenance and hosting provided by <a href="https://packagist.com/"><img alt="Private Packagist" src="/img/private-packagist.svg?v=1743695794" /></a></p> <p class="col-xs-12 col-md-6">Bandwidth and CDN provided by <a href="https://bunny.net/"><img alt="Bunny.net" src="/img/bunny-net.svg?v=1743695794" /></a></p> <p class="col-xs-12 col-md-6">Monitoring provided by <a href="https://datadog.com/"><img alt="Datadog" src="/img/datadog-light.png?v=1743695794" /></a></p> </div> </nav> </footer> <script nonce="su1CPKanQT6gyX86/pxDRw=="> var algoliaConfig = {"app_id":"M58222SH95","search_key":"5ae4d03c98685bd7364c2e0fd819af05","index_name":"packagist"}; window.process = { env: { DEBUG: undefined }, }; </script> <script nonce="su1CPKanQT6gyX86/pxDRw==" src="/build/app.js?v=1743695794"></script> </body> </html>