You are here

class SmartlingApiFactory in TMGMT Translator Smartling 8.4

Same name and namespace in other branches
  1. 8.2 src/Smartling/SmartlingApiFactory.php \Drupal\tmgmt_smartling\Smartling\SmartlingApiFactory
  2. 8.3 src/Smartling/SmartlingApiFactory.php \Drupal\tmgmt_smartling\Smartling\SmartlingApiFactory

Class SmartlingApiFactory @package Drupal\tmgmt_smartling\Smartling

Hierarchy

Expanded class hierarchy of SmartlingApiFactory

1 string reference to 'SmartlingApiFactory'
tmgmt_smartling.services.yml in ./tmgmt_smartling.services.yml
tmgmt_smartling.services.yml
1 service uses SmartlingApiFactory
tmgmt_smartling.smartling_api_factory in ./tmgmt_smartling.services.yml
\Drupal\tmgmt_smartling\Smartling\SmartlingApiFactory

File

src/Smartling/SmartlingApiFactory.php, line 28
SmartlingApiFactory.php.

Namespace

Drupal\tmgmt_smartling\Smartling
View source
class SmartlingApiFactory {

  /**
   * Returns API object as a service.
   *
   * @param array $settings
   * @param string $api_type
   *
   * @return \Smartling\BaseApiAbstract
   * @throws \Exception
   * @throws \Smartling\Exceptions\SmartlingApiException
   */
  public static function create(array $settings, $api_type) {
    require_once __DIR__ . '/../../vendor/autoload.php';
    if (empty($settings['user_id']) || empty($settings['project_id']) || empty($settings['token_secret'])) {
      throw new SmartlingApiException('The "User Id", "Token Secret", or "Project Id" are not correct.');
    }
    ConnectorInfo::setUpCurrentClientInfo();
    $auth_provider = AuthTokenProvider::create($settings['user_id'], $settings['token_secret']);
    $logger = \Drupal::logger('smartling_api');
    $api = NULL;
    switch ($api_type) {
      case 'file':
        $api = FileApi::create($auth_provider, $settings['project_id'], $logger);
        break;
      case 'project':
        $api = ProjectApi::create($auth_provider, $settings['project_id'], $logger);
        break;
      case 'jobs':
        $api = JobsApi::create($auth_provider, $settings['project_id'], $logger);
        break;
      case 'batch':
        $api = BatchApi::create($auth_provider, $settings['project_id'], $logger);
        break;
      case 'context':
        $api = ContextApi::create($auth_provider, $settings['project_id'], $logger);
        break;
      case 'progress':
        $api = ProgressTrackerApi::create($auth_provider, $settings['project_id'], $logger);
        break;
      case 'translation_request':
        $api = TranslationRequestsApi::create($auth_provider, $settings['project_id'], $logger);
        break;
      case 'translation_request_v3':
        $api = TranslationRequestsApiV3::create($auth_provider, $settings['project_id'], $logger);
        break;
      case 'audit':
        $api = AuditLogApi::create($auth_provider, $settings['project_id'], $logger);
        break;
      default:
        throw new Exception('Unsupported API has been requested: ' . $api_type);
    }
    return $api;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
SmartlingApiFactory::create public static function Returns API object as a service.