PHP code example of private-packagist / api-client

1. Go to this page and download the library: Download private-packagist/api-client library. Choose the download type require.

2. Extract the ZIP file and open the index.php.

3. Add this code to the index.php.
    
        
<?php
require_once('vendor/autoload.php');

/* Start to develop here. Best regards https://php-download.com/ */

    

private-packagist / api-client example snippets




// This file is generated by Composer
lient();
$client->authenticate('api-key', 'api-secret');
$packages = $client->packages()->all();

$jobs = $client->organization()->sync();

use PrivatePackagist\ApiClient\TeamPermissions;

$permissions = new TeamPermissions;
// Grant all permissions.
$permissions->canEditTeamPackages = true;
$permissions->canAddPackages = true;
$permissions->canCreateSuborganizations = true;
$permissions->canManageVendorCustomers = true;
$permissions->canManageVendorCustomers = true;

use PrivatePackagist\ApiClient\TeamPermissions;

$permissions = TeamPermissions::fromFlags(
    TeamPermissions::PERMISSION_CAN_EDIT_TEAM_PACKAGES | TeamPermissions::PERMISSION_CAN_ADD_PACKAGES,
);

use PrivatePackagist\ApiClient\TeamPermissions;

$team = $client->teams()->all()[0];
$permissions = TeamPermissions::fromTeamResponse($team);

$teams = $client->teams()->all();

use PrivatePackagist\ApiClient\TeamPermissions;

$permissions = new TeamPermissions;
$team = $client->teams()->create('New Team Name', $permissions);


$team = $client->teams()->show($teamId);

use PrivatePackagist\ApiClient\TeamPermissions;

$permissions = new TeamPermissions;
$team = $client->teams()->edit($teamId, 'Altered Team Name', $permissions);

$team = $client->teams()->grantAccessToAllPackages($teamId);

$team = $client->teams()->revokeAccessToAllPackages($teamId);

$client->teams()->remove($teamId);

$team = $client->teams()->addMember($teamId, $userId);

$client->teams()->removeMember($teamId, $userId);

$teamId = 1;
$packages = $client->teams()->packages($teamId);

$teamId = 1;
$packages = $client->teams()->addPackages($teamId, ['acme-website/package', 1]);

$teamId = 1;
$packages = $client->teams()->removePackage($teamId, 'acme-website/package');

$tokens = $client->tokens()->all();

// Create a new token with access to all packages
$token = $client->tokens()->create([
    'description' => 'New Team Token',
    'access' => 'read',
    'accessToAllPackages' => true,
]);

// Create a new token with access to packages a team has access to
$token = $client->tokens()->create([
    'description' => 'New Team Token',
    'access' => 'read',
    'teamId' => 1, // Get teamId from the list of teams to determine to which packages the token has access to
]);

$client->tokens()->remove($tokenId));

$customerId = 42;
$confirmation = [
    'IConfirmOldTokenWillStopWorkingImmediately' => true,
];
$token = $client->tokens()->regenerateToken($tokenId, $confirmation);

$customers = $client->customers()->all();

$customerId = 42;
$customer = $client->customers()->show($customerId);
// or
$customerUrlName = 'customer-url-name';
$customer = $client->customers()->show($customerUrlName);

$customer = $client->customers()->create('New customer name');
// or
$customer = $client->customers()->create('New customer name', false, 'customer-url-name', 'beta', true);

$customerId = 42;
$customerData = [
    'name' => $name,
    'urlName' => 'customer',
    'accessToVersionControlSource' => false,
    'minimumAccessibleStability' => 'beta',
    'assignAllPackages' => true,
];
$customer = $client->customers()->edit($customerId, $customerData);

$customerId = 42;
$client->customers()->remove($customerId);

$customerId = 42;
$customer = $client->customers()->enable($customerId);

$customerId = 42;
$customer = $client->customers()->disable($customerId);

$customerId = 42;
$packages = $client->customers()->listPackages($customerId);

$customerId = 42;
$package = $client->customers()->showPackage($customerId, $packageName);
$accessibleVersions = $package['versions'];

$customerId = 42;
$packages = [
    [
        'name' => 'acme-website/package',
        'versionConstraint' => '^1.0 | ^2.0', // optional version constraint to limit updates the customer receives
        'expirationDate' => (new \DateTime())->add(new \DateInterval('P1Y'))->format('c'), // optional expiration date to limit updates the customer receives
        'minimumAccessibleStability' => 'beta', // optional stability to restrict customers to specific package version stabilities like alpha, beta, or RC
    ],
];
$packages = $client->customers()->addOrEditPackages($customerId, $packages);

$customerId = 42;
$packageName = 'acme-website/package';
$client->customers()->removePackage($customerId, $packageName);

$customerId = 42;
$confirmation = [
    'IConfirmOldTokenWillStopWorkingImmediately' => true,
];
$composerRepository = $client->customers()->regenerateToken($customerId, $confirmation);

$customerId = 42;
$packages = $client->customers()->vendorBundles()->listVendorBundles($customerId);

$customerId = 42;
$vendorBundleId = 12;
$expirationDate = (new \DateTime())->add(new \DateInterval('P1Y'))->format('c'), // optional expiration date to limit updates the customer receives
$packages = $client->customers()->vendorBundles()->addOrEditVendorBundle($customerId, $vendorBundleId, $expirationDate);

$customerId = 42;
$vendorBundleId = 12;
$client->customers()->vendorBundles()->removeVendorBundle($customerId, $vendorBundleId);

$vendorBundles = $client->vendorBundles()->all();

$vendorBundleId = 42;
$vendorBundle = $client->vendorBundles()->show($vendorBundleId);

$vendorBundle = $client->vendorBundles()->create('New bundle name');
// or
$vendorBundle = $client->vendorBundles()->create('New bundle name', 'dev', '^1.0', true, [123]);

$vendorBundleId = 42;
$vendorBundleData = [
    'name' => 'Bundle name',
    'minimumAccessibleStability' => 'dev',
    'versionConstraint' => '^1.0',
    'assignAllPackages' => true,
    'synchronizationIds' => [123], // A list of synchronization ids for which new packages should automatically be added to the bundle.
];
$vendorBundle = $client->vendorBundles()->edit($vendorBundleId, $vendorBundleData);

$vendorBundleId = 42;
$client->vendorBundles()->remove($vendorBundleId);

$vendorBundleId = 42;
$packages = $client->vendorBundles()->packages()->listPackages($vendorBundleId);

$vendorBundleId = 42;
$packages = [
    [
        'name' => 'acme-website/package',
        'versionConstraint' => '^1.0 | ^2.0', // optional version constraint to limit updates the customer receives
        'minimumAccessibleStability' => 'beta', // optional stability to restrict customers to specific package version stabilities like alpha, beta, or RC
    ],
];
$packages = $client->vendorBundles()->packages()->addOrEditPackages($vendorBundleId, $packages);

$vendorBundleId = 42;
$packageName = 'acme-website/package';
$client->vendorBundles()->packages()->removePackage($vendorBundleId, $packageName);

$suborganizations = $client->suborganizations()->all();

$suborganizationName = 'suborganization';
$suborganization = $client->suborganizations()->show($suborganizationName);

$suborganization = $client->suborganizations()->create('New suborganization name');

$suborganizationName = 'suborganization';
$client->suborganizations()->remove($suborganizationName);

$suborganizationName = 'suborganization';
$teams = $client->suborganizations()->listTeams($suborganizationName);

$suborganizationName = 'suborganization';
$teams = [
    [
        'id' => 12,
        'permission' => 'owner',
    ],
];
$teams = $client->suborganizations()->addOrEditTeams($suborganizationName, $teams);

$suborganizationName = 'suborganization';
$teamId = 12;
$client->suborganizations()->removeTeam($suborganizationName, $teamId);

$suborganizationName = 'suborganization';
$packages = $client->suborganizations()->packages()->all($suborganizationName);

$suborganizationName = 'suborganization';
// Either use package name:
$package = $client->suborganizations()->packages()->show($suborganizationName, 'acme-website/package');
// Or the package ID: 
$package = $client->suborganizations()->packages()->show($suborganizationName, 123);

$suborganizationName = 'suborganization';
$job = $client->suborganizations()->packages()->createVcsPackage($suborganizationName, 'https://github.com/acme-website/package');

$suborganizationName = 'suborganization';
$credentialId = 42;
$job = $client->suborganizations()->packages()->createVcsPackage($suborganizationName,'https://github.com/acme-website/package', $credentialId);

$suborganizationName = 'suborganization';
$packageDefinition = '{...}';
$job = $client->suborganizations()->packages()->createCustomPackage($suborganizationName, $packageDefinition);

$suborganizationName = 'suborganization';
$packageDefinition = '{...}';
$credentialId = 42;
$job = $client->suborganizations()->packages()->createCustomPackage($suborganizationName, $packageDefinition, $credentialId);

$suborganizationName = 'suborganization';
$job = $client->suborganizations()->packages()->editVcsPackage($suborganizationName, 'acme-website/package', 'https://github.com/acme-website/package');

$suborganizationName = 'suborganization';
$packageDefinition = '{...}';
$job = $client->suborganizations()->packages()->editCustomPackage($suborganizationName, 'acme-website/package', $packageDefinition);

$suborganizationName = 'suborganization';
$client->suborganizations()->packages()->remove($suborganizationName, 'acme-website/package');

$suborganizationName = 'suborganization';
$client->suborganizations()->packages()->listDependents($suborganizationName, 'acme-website/package');

$suborganizationName = 'suborganization';
$tokens = $client->suborganizations()->listTokens($suborganizationName);

$suborganizationName = 'suborganization';
$data = [
  'description' => 'Suborganization Token',
  'access' => 'read',
];
$token = $client->suborganizations()->createToken($suborganizationName, $data);

$suborganizationName = 'suborganization';
$tokenId = 33;
$client->suborganizations()->removeToken($suborganizationName, $tokenId);

$suborganizationName = 'suborganization';
$tokenId = 33;
$confirmation = [
    'IConfirmOldTokenWillStopWorkingImmediately' => true,
];
$token = $client->suborganizations()->regenerateToken($suborganizationName, $confirmation);

$suborganizationName = 'suborganization';
$mirroredRepositories = $client->suborganizations()->mirroredRepositories()->all($suborganizationName);

$suborganizationName = 'suborganization';
$mirroredRepositoryId = 42;
$mirroredRepository = $client->suborganizations()->mirroredRepositories()->show($suborganizationName, $mirroredRepositoryId);

$suborganizationName = 'suborganization';
$mirroredRepositoriesToAdd = [
    ['id' => 12, 'mirroringBehavior' => 'add_on_use'],
];
$mirroredRepository = $client->suborganizations()->mirroredRepositories()->add($suborganizationName, $mirroredRepositoriesToAdd);

$suborganizationName = 'suborganization';
$mirroredRepositoryId = 42;
$mirroredRepository = $client->suborganizations()->mirroredRepositories()->create($suborganizationName, $mirroredRepositoryId, 'add_on_use');

$suborganizationName = 'suborganization';
$mirroredRepositoryId = 42;
$client->suborganizations()->mirroredRepositories()->remove($suborganizationName, $mirroredRepositoryId);

$suborganizationName = 'suborganization';
$mirroredRepositoryId = 42;
$packages = $client->suborganizations()->mirroredRepositories()->listPackages($suborganizationName, $mirroredRepositoryId);

$suborganizationName = 'suborganization';
$mirroredRepositoryId = 42;
$packages = [
    'acme/cool-lib
];
$jobs = $client->suborganizations()->mirroredRepositories()->addPackages($suborganizationName, $mirroredRepositoryId, $packages);

$suborganizationName = 'suborganization';
$mirroredRepositoryId = 42;
$client->suborganizations()->mirroredRepositories()->removePackages($suborganizationName, $mirroredRepositoryId);

$filters = [
    'origin' => \PrivatePackagist\ApiClient\Api\Packages::ORIGIN_PRIVATE, // optional filter to only receive packages that can be added to customers,
    'security-issue-state' => \PrivatePackagist\ApiClient\Api\SecurityIssues::STATE_OPEN, // optional filter to filter packages with open security issues,
];
$packages = $client->packages()->all($filters);

// Either use package name:
$package = $client->packages()->show('acme-website/package');
// Or the package ID: 
$package = $client->packages()->show(123);

$job = $client->packages()->createVcsPackage('https://github.com/acme-website/package');

$credentialId = 42;
$job = $client->packages()->createVcsPackage('https://github.com/acme-website/package', $credentialId);

$job = $client->packages()->createVcsPackage('https://github.com/acme-website/package', null, 'git');

$packageDefinition = '{...}';
$job = $client->packages()->createCustomPackage($packageDefinition);

$packageDefinition = '{...}';
$credentialId = 42;
$job = $client->packages()->createCustomPackage($packageDefinition, $credentialId);

$job = $client->packages()->editVcsPackage('acme-website/package', 'https://github.com/acme-website/package');

$packageDefinition = '{...}';
$job = $client->packages()->editCustomPackage('acme-website/package', $packageDefinition);

$client->packages()->remove('acme-website/package');

$client->packages()->listDependents('acme-website/package');

$client->packages()->listCustomers('acme-website/package');

$filters = [
    'security-issue-state' => \PrivatePackagist\ApiClient\Api\SecurityIssues::STATE_OPEN,
];
$client->packages()->listSecurityIssues('acme-website/package', $filters);

$client->packages()->showSecurityMonitoringConfig('acme-website/package');

$config = [
    "monitorAllBranches" => false, // If set to true then monitoredBranches will be ignored and can be omitted 
    "monitoredBranches" => [
        "dev-main"
    ],
];
$client->packages()->editSecurityMonitoringConfig('acme-website/package', $config);

$fileName = 'package1.zip'; // your package archive artifact containing a valid composer.json in root directory
$file = file_get_contents($fileName);
$client->packages()->artifacts()->create($file, 'application/zip', $fileName);

$fileName = 'package1.zip';
$file = file_get_contents($fileName);
$response = $client->packages()->artifacts()->create($file, 'application/zip', $fileName);
$artifactId = $response['id'];
$client->packages()->createArtifactPackage([$artifactId]);

$packageName = 'acme/artifact';
$fileName = 'package1.zip';
$file = file_get_contents($fileName);
$client->packages()->artifacts()->add($packageName, $file, 'application/zip', $fileName);

// in case you want to replace the artifact file with a newly uploaded one
// 1. get current artifact ids
$result = $client->packages()->artifacts()->showPackageArtifacts('acme-website/package');
$artifactIds = array_column($result, 'id'); // [41, 42]

// 2. upload the new artifact file
$fileName = 'package1.zip';
$file = file_get_contents($fileName);
$response = $client->packages()->artifacts()->create($file, 'application/zip', $fileName);
$newArtifactId = $response['id'];

// 3. let's say we don't want to have the artifact file id = 41 and use the newly uploaded file instead
$artifactIds = array_shift($artifactIds);
$artifactIds[] = $newArtifactId;
$client->packages()->editArtifactPackage('acme-website/package', $artifactIds);

$credentials = $client->credentials()->all();

$credentialId = 42;
$credential = $client->credentials()->show($credentialId);

$type = \PrivatePackagist\ApiClient\Api\Credentials::TYPE_HTTP_BASIC;
$credential = $client->credentials()->create('ACME http auth', $type, 'acme-website.com', 'username', 'password');

$credentialId = 42;
$type = \PrivatePackagist\ApiClient\Api\Credentials::TYPE_HTTP_BASIC;
$credential = $client->credentials()->edit($credentialId, $type, 'username', 'password');

$credentialId = 42;
$client->credentials()->remove($credentialId);

$mirroredRepositories = $client->mirroredRepositories()->all();

$mirroredRepositoryId = 42;
$mirroredRepository = $client->mirroredRepositories()->show($mirroredRepositoryId);

$mirroredRepository = $client->mirroredRepositories()->create('Mirrored Repository', 'https://composer.example.com', 'add_on_use', 543);
php
$mirroredRepositoryId = 42;
$mirroredRepository = $client->mirroredRepositories()->create($mirroredRepositoryId, 'Mirrored Repository', 'https://composer.example.com', 'add_on_use', 543);
php
$mirroredRepositoryId = 42;
$client->mirroredRepositories()->remove($mirroredRepositoryId);
php
$mirroredRepositoryId = 42;
$packages = $client->mirroredRepositories()->listPackages($mirroredRepositoryId);
php
$mirroredRepositoryId = 42;
$packages = [
    'acme/cool-lib
];
$jobs = $client->mirroredRepositories()->addPackages($mirroredRepositoryId, $packages);
php
$mirroredRepositoryId = 42;
$client->mirroredRepositories()->removePackages($mirroredRepositoryId);
php
$job = $client->jobs()->show($jobId);
php
$filters = [
    'security-issue-state' => \PrivatePackagist\ApiClient\Api\SecurityIssues::STATE_OPEN, // optional filter to filter packages with open security issues,
];
$packages = $client->securityIssues()->all($filters);
php
$customerId = 42;
$legacyKeys = $client->customers()->magentoLegacyKeys()->all($customerId);
php
$legacyKey = $client->customers()->magentoLegacyKeys()->create($customerId, $publicKey, $privateKey);
php
$client->customers()->magentoLegacyKeys()->remove($customerId, $publicKey);
php
$request = /** any Psr7 request */;
$secret = 'webhook-secret';
$webhookSignature = new \PrivatePackagist\ApiClient\WebhookSignature($secret);
$requestSignature = $request->hasHeader('Packagist-Signature') ? $request->getHeader('Packagist-Signature')[0] : null;
$webhookSignature->validate($requestSignature, (string) $request->getBody());