flexsim/flexnet-operations

A package for connecting with the FlexNet Operations api


README

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

This is where your description should go. Limit it to a paragraph or two. Consider adding a small example.

Installation

You can install the package via composer:

composer require flexsim/flexnet-operations

You can publish the config file with:

php artisan vendor:publish --tag="flexnet-operations-config"

This is the contents of the published config file:

return [
];

Optionally, you can publish the views using

php artisan vendor:publish --tag="flexnet-operations-views"

Usage

$flexnetOperations = new Flexsim\FlexnetOperations();
echo $flexnetOperations->echoPhrase('Hello, Flexsim!');

Type Generation

  1. Fix types in wsdl files

    1. ProductPackagineService
      • featureBundlesListType - add minOccurs="0" to the "featureBundle" property
      • featuresListType - add minOccurs="0" to the "feature" property
      • getProductRelationshipsResponseType - add minOccurs="0" to the "relationship" property
    2. LicenseService
      • fulfillmentHistoryDetailsType - add minOccurs="0" to the "record" property
  2. Normalize Extension types in the wsdl file by extracting them from the base type into the child type

  3. Run the flexnet WSDL file through the xml to json tool here: https://codebeautify.org/xmlviewer

Client Factory Generation

Make sure client factories use the BasicAuth middleware like so:

public static function factory(string $wsdl, string $username, string $password): EntitlementOrderServiceClient
{
    $engine = DefaultEngineFactory::create(
        ExtSoapOptions::defaults($wsdl, [])
            ->withClassMap(EntitlementOrderServiceClassmap::getCollection()),
        Psr18Transport::createForClient(
            new PluginClient(
                Psr18ClientDiscovery::find(),
                [
                    new AuthenticationPlugin(new BasicAuth($username, $password)),
                ]
            )
        )
    );
}

Testing

composer test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

The MIT License (MIT). Please see License File for more information.