Библиотека для работы c Alba

Библиотека содержит два базовых класса AlbaService и AlbaCallback предназначенных для наследования.

AlbaService - сервис в Alba. Позволяет получить список доступных способов оплаты, инициировать транзакцию, получать информацию о ней. Необходимо создать по экземпляру на каждый существующий сервис.

AlbaCallback - обработчик для обратного вызова от Alba. Проверяет подпись и вызывает соответствующий параметру "command" метод.

В процессе работы может сработать исключение AlbaException.

Пример использования для инициации транзакции:

   $service = new AlbaService(<service-id>, '<service-secret>');
   try {
       $service->initPayment('mc', 10, 'Test', 'test@example.com', '71111111111');
   } catch (AlbaException $e) {
       echo $e->getMessage();
   }

Пример использования для обратного вызова:

   class MyAlbaCallback extends AlbaCallback {

       public function callbackSuccess($data) {
           // фиксирование успешной транзакции
       }
   }

   $service1 = new AlbaService(<service1-id>, '<service1-secret>');
   $service2 = new AlbaService(<service2-id>, '<service2-secret>');
   $callback = new MyAlbaCallback(array($service1, $service2]));
   $callback->handle(<массив-c-POST-данными>)

Пример использования для проведение рекуррентных платежей:

   $service = new AlbaService(<service-id>, '<service-secret>');
   
   try {
        // Получение токена. 
        // Доступно олько для тех сервисов у которых доступна данная опция
        // Остальные сервисы должны иницировать оплату без использования background API
        $token = $service->createCardToken(
            '4300000000000777', 11, '19', '123', True
        );
        echo "Card token: " . $token;

    } catch (AlbaException $e) {
        echo $e->getMessage();
    }

    try {
        // Инициация первого рекуррентного платежа
        $first_order_id = 'first-' . uniqid();
        $recurrent_params = RecurrentParams::first_pay(
            // Ссылка на подробное описание правил предоставления рекуррентного платежа
            'http://example.com/rules', 
             // Текстовое описание за что производится регистрация РП	
            'Test'
        );
        $service->initPayment(
             'spg_test',
             10,
             'Test',
             'test@example.com',
             '71111111111',
             $first_order_id, 
             'partner',
             $token,
             $recurrent_params
        );
     } catch (AlbaException $e) {
        echo $e->getMessage();
     }

     try {
        // Инициация последующего рекуррентного платежа
        $recurrent_params = RecurrentParams::next_pay(
            // order_id первого рекуррентного платежа
            $first_order_id  
        );
        $service->initPayment(
            'spg_test',
            10,
            'Test',
            'test@example.com',
            '71111111111',
            uniqid(),  // order_id текущего платежа
            'partner',
            $token,
            $recurrent_params
        );
      } catch (AlbaException $e) {
        echo $e->getMessage();
      }