2017 © Pedro Peláez
 

library laravel-ntlm-soap

A SoapClient wrapper integration for Laravel with NTLM support

image

benyanke/laravel-ntlm-soap

A SoapClient wrapper integration for Laravel with NTLM support

  • Monday, October 2, 2017
  • by benyanke
  • Repository
  • 1 Watchers
  • 0 Stars
  • 1,276 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 76 Forks
  • 0 Open issues
  • 3 Versions
  • 1 % Grown

The README.md

Laravel SoapClient Wrapper

A SoapClient wrapper integration for Laravel, built on top of jamesiarmes/php-ntlm.br/ Makes it easy to use Soap in a Laravel application.br/, (*1)

Please report any bugs or features here: br/ https://github.com/benyanke/laravel-ntlm-soap/issues/, (*2)

Installation

Laravel

Add benyanke/laravel-ntlm-soap as requirement to composer.json, (*3)

{
    "require": {
        "benyanke/laravel-ntlm-soap": "0.1.*"
    }
}

Add the service provider in app/config/app.php., (*4)

'benyanke\SoapWrapper\ServiceProvider'

To use the facade add this to the facades in app/config/app.php., (*5)

'SoapWrapper' => 'benyanke\SoapWrapper\Facade'

Lumen

Open bootstrap/app.php and register the required service provider:, (*6)

$app->register(benyanke\SoapWrapper\ServiceProvider::class);

register class alias:, (*7)

class_alias('benyanke\SoapWrapper\Facade', 'SoapWrapper');

Facades must be enabled., (*8)

Usage

How to add a service to the wrapper and use it., (*9)

<?php

namespace App\Http\Controllers;

use benyanke\SoapWrapper\SoapWrapper;
use App\Soap\Request\GetConversionAmount;
use App\Soap\Response\GetConversionAmountResponse;

class SoapController
{
  /**
   * @var SoapWrapper
   */
  protected $soapWrapper;

  /**
   * SoapController constructor.
   *
   * @param SoapWrapper $soapWrapper
   */
  public function __construct(SoapWrapper $soapWrapper)
  {
    $this->soapWrapper = $soapWrapper;
  }

  /**
   * Use the SoapWrapper
   */
  public function show() 
  {
    $this->soapWrapper->add('Currency', function ($service) {
      $service
        ->wsdl('http://currencyconverter.kowabunga.net/converter.asmx?WSDL')
        ->trace(true)
        ->classmap([
          GetConversionAmount::class,
          GetConversionAmountResponse::class,
        ]);
    });

    // Without classmap
    $response = $this->soapWrapper->call('Currency.GetConversionAmount', [
      'CurrencyFrom' => 'USD', 
      'CurrencyTo'   => 'EUR', 
      'RateDate'     => '2014-06-05', 
      'Amount'       => '1000',
    ]);

    var_dump($response);

    // With classmap
    $response = $this->soapWrapper->call('Currency.GetConversionAmount', [
      new GetConversionAmount('USD', 'EUR', '2014-06-05', '1000')
    ]);

    var_dump($response);
    exit;
  }
}

Service functions

$this->soapWrapper->add('Currency', function ($service) {
    $service
        ->wsdl()                 // The WSDL url
        ->trace(true)            // Optional: (parameter: true/false)
        ->header()               // Optional: (parameters: $namespace,$name,$data,$mustunderstand,$actor)
        ->customHeader()         // Optional: (parameters: $customerHeader) Use this to add a custom SoapHeader or extended class                
        ->cookie()               // Optional: (parameters: $name,$value)
        ->location()             // Optional: (parameter: $location)
        ->certificate()          // Optional: (parameter: $certLocation)
        ->cache(WSDL_CACHE_NONE) // Optional: Set the WSDL cache

        // Optional: Set some extra options
        ->options([
            'login' => 'username',
            'password' => 'password'
        ])

        // Optional: Classmap
        ->classmap([
          GetConversionAmount::class,
          GetConversionAmountResponse::class,
        ]);
});

Classmap

If you are using classmap you can add folders like for example: - App\Soap - App\Soap\Request - App\Soap\Response, (*10)

Request: App\Soap\Request\GetConversionAmount, (*11)

<?php

namespace App\Soap\Request;

class GetConversionAmount
{
  /**
   * @var string
   */
  protected $CurrencyFrom;

  /**
   * @var string
   */
  protected $CurrencyTo;

  /**
   * @var string
   */
  protected $RateDate;

  /**
   * @var string
   */
  protected $Amount;

  /**
   * GetConversionAmount constructor.
   *
   * @param string $CurrencyFrom
   * @param string $CurrencyTo
   * @param string $RateDate
   * @param string $Amount
   */
  public function __construct($CurrencyFrom, $CurrencyTo, $RateDate, $Amount)
  {
    $this->CurrencyFrom = $CurrencyFrom;
    $this->CurrencyTo   = $CurrencyTo;
    $this->RateDate     = $RateDate;
    $this->Amount       = $Amount;
  }

  /**
   * @return string
   */
  public function getCurrencyFrom()
  {
    return $this->CurrencyFrom;
  }

  /**
   * @return string
   */
  public function getCurrencyTo()
  {
    return $this->CurrencyTo;
  }

  /**
   * @return string
   */
  public function getRateDate()
  {
    return $this->RateDate;
  }

  /**
   * @return string
   */
  public function getAmount()
  {
    return $this->Amount;
  }
}

Response: App\Soap\Response\GetConversionAmountResponse, (*12)

<?php

namespace App\Soap\Response;

class GetConversionAmountResponse
{
  /**
   * @var string
   */
  protected $GetConversionAmountResult;

  /**
   * GetConversionAmountResponse constructor.
   *
   * @param string
   */
  public function __construct($GetConversionAmountResult)
  {
    $this->GetConversionAmountResult = $GetConversionAmountResult;
  }

  /**
   * @return string
   */
  public function getGetConversionAmountResult()
  {
    return $this->GetConversionAmountResult;
  }
}

The Versions

02/10 2017

dev-master

9999999-dev

A SoapClient wrapper integration for Laravel with NTLM support

  Sources   Download

MIT

The Requires

 

by Ben Yanke

laravel wrapper client soap

02/10 2017

0.0.1

0.0.1.0

A SoapClient wrapper integration for Laravel with NTLM support

  Sources   Download

MIT

The Requires

 

by Ben Yanke

laravel wrapper client soap

25/01 2017

dev-develop

dev-develop

A SoapClient wrapper integration for Laravel

  Sources   Download

MIT

The Requires

  • php >=5.4.0
  • ext-soap *

 

by Michael van de Rijt

laravel wrapper client soap