FOSSology  4.5.1
Open Source License Compliance by Open Source Software
AdminObligationFromCSV.php
1 <?php
2 /*
3  SPDX-FileCopyrightText: © 2008-2013 Hewlett-Packard Development Company, L.P.
4  SPDX-FileCopyrightText: © 2014-2017 Siemens AG
5 
6  SPDX-License-Identifier: GPL-2.0-only
7 */
8 
9 namespace Fossology\UI\Page;
10 
17 use GuzzleHttp\Client;
18 use GuzzleHttp\Exception\GuzzleException;
19 use GuzzleHttp\Exception\RequestException;
20 use Symfony\Component\HttpFoundation\File\UploadedFile;
21 use Symfony\Component\HttpFoundation\Request;
22 use Symfony\Component\HttpFoundation\Response;
23 use League\OAuth2\Client\Provider\GenericProvider;
24 
29 {
30  const NAME = "admin_obligation_from_csv";
31  const KEY_UPLOAD_MAX_FILESIZE = 'upload_max_filesize';
32  const FILE_INPUT_NAME = 'file_input';
33  const FILE_INPUT_NAME_V2 = 'fileInput';
34 
38  private $oidcProvider;
39 
43  private $sysconfig;
44 
45  function __construct()
46  {
47  global $SysConf;
48  parent::__construct(self::NAME, array(
49  self::TITLE => "Admin Obligation Import",
50  self::MENU_LIST => "Admin::Obligation Admin::Obligation Import",
51  self::REQUIRES_LOGIN => true,
52  self::PERMISSION => Auth::PERM_ADMIN
53  ));
55  $this->obligationsCsvImport = $GLOBALS['container']->get('app.obligation_csv_import');
56  $this->sysconfig = $SysConf;
57  $this->configuration = [
58  'uri' => trim($this->sysconfig['SYSCONFIG']['LicenseDBBaseURL']),
59  'content' => trim($this->sysconfig['SYSCONFIG']['LicenseDBContentObligations']),
60  'health' => trim($this->sysconfig['SYSCONFIG']['LicenseDBHealth']),
61  'token' => empty(trim($this->sysconfig['SYSCONFIG']['LicenseDBToken'])) ? null : trim($this->sysconfig['SYSCONFIG']['LicenseDBToken']),
62  ];
63 
64  if ($this->configuration['token'] == null) {
65  $this->oidcProvider = new GenericProvider([
66  "clientId" => trim($this->sysconfig['SYSCONFIG']['OidcAppId']),
67  "clientSecret" => trim($this->sysconfig['SYSCONFIG']['OidcSecret']),
68  "redirectUri" => trim($this->sysconfig['SYSCONFIG']['OidcRedirectURL']),
69  "urlAuthorize" => trim($this->sysconfig['SYSCONFIG']['OidcAuthorizeURL']),
70  "urlAccessToken" => trim($this->sysconfig['SYSCONFIG']['OidcAccessTokenURL']),
71  "urlResourceOwnerDetails" => trim($this->sysconfig['SYSCONFIG']['OidcResourceURL']),
72  ]);
73 
74  if (isset($this->sysconfig['SYSCONFIG']['OidcScope'])) {
75  $this->configuration['scope'] = trim($this->sysconfig['SYSCONFIG']['OidcScope']);
76  }
77  } else {
78  $this->oidcProvider = null;
79  }
80  }
81 
85  public function getFileInputName($apiVersion = ApiVersion::V1)
86  {
87  if ($apiVersion == ApiVersion::V2) {
88  return $this::FILE_INPUT_NAME_V2;
89  } else {
90  return $this::FILE_INPUT_NAME;
91  }
92  }
93 
98  protected function handle(Request $request)
99  {
100  $vars = array();
101  if (!$request->isMethod('POST')) {
102  $getHealth = $this->configuration['uri'] . $this->configuration['health'];
103  $guzzleClient = HttpUtils::getGuzzleClient($this->sysconfig, $this->configuration['uri']);
104  $vars['licenseDBHealth'] = HttpUtils::checkLicenseDBHealth($getHealth, $guzzleClient);
105  }
106  if ($request->isMethod('POST')) {
107  if ($request->get('importFrom') === 'licensedb') {
108  $startTime = microtime(true);
109  $vars['message'] = $this->handleLicenseDbObligationImport();
110  $fetchLicenseTime = microtime(true) - $startTime;
111  $this->fileLogger->debug("Fetching Obligations and Check time took: " . sprintf("%0.3fms", 1000 * $fetchLicenseTime));
112  $this->fileLogger->debug("****************** Message From LicenseDB import [" . date('Y-m-d H:i:s') . "] ******************");
113  $this->fileLogger->debug($vars["message"]);
114  $this->fileLogger->debug("****************** End Message From LicenseDB import ******************");
115  } else {
116  $uploadFile = $request->files->get(self::FILE_INPUT_NAME);
117  $delimiter = $request->get('delimiter') ?: ',';
118  $enclosure = $request->get('enclosure') ?: '"';
119  $result = $this->handleFileUpload($uploadFile, $delimiter, $enclosure);
120  $vars['message'] = is_array($result) ? $result[1] : $result;
121  }
122  }
123 
124  $vars[self::KEY_UPLOAD_MAX_FILESIZE] = ini_get(self::KEY_UPLOAD_MAX_FILESIZE);
125  $vars['baseUrl'] = $request->getBaseUrl();
126  $vars['license_csv_import'] = false;
127 
128  if (!empty(trim($this->configuration['uri']))) {
129  $vars['baseURL'] = !empty($this->configuration['uri']);
130  $vars['tokenConfig'] = !empty($this->configuration['token']) || $this->oidcProvider != null;
131  $vars['exportEndpoint'] = !empty($this->configuration['content']);
132  return $this->render("admin_license_from_licensedb.html.twig", $this->mergeWithDefault($vars));
133  } else {
134  return $this->render("admin_license_from_csv.html.twig", $this->mergeWithDefault($vars));
135  }
136  }
137 
146  {
147  $msg = '<br>';
148  $data = null;
149  $finalURL = $this->configuration['uri'] . $this->configuration['content'];
150  try {
151  $startTimeReq = microtime(true);
152 
153  $accessToken = null;
154  if ($this->configuration['token'] != null) {
155  $accessToken = $this->configuration['token'];
156  } else {
157  $options = [];
158  if (isset($this->configuration['scope'])) {
159  $options['scope'] = $this->configuration['scope'];
160  }
161  $accessToken = $this->oidcProvider->getAccessToken('client_credentials', $options);
162  }
163  $guzzleClient = HttpUtils::getGuzzleClient($this->sysconfig, $this->configuration['uri'], $accessToken);
164  $response = $guzzleClient->get($finalURL);
165  $fetchLicenseTimeReq = microtime(true) - $startTimeReq;
166  $this->fileLogger->debug("LicenseDB req:' took " . sprintf("%0.3fms", 1000 * $fetchLicenseTimeReq));
167 
168  $data = HttpUtils::processHttpResponse($response);
169  return $this->obligationsCsvImport->importJsonData($data, $msg);
170  } catch (HttpClientException $e) {
171  return $msg . $e->getMessage();
172  } catch (RequestException | GuzzleException $e) {
173  return $msg . _('Something Went Wrong, check if host is accessible') . ': ' . $e->getMessage();
174  }
175  }
176 
181  public function handleFileUpload($uploadedFile, $delimiter = ',', $enclosure = '"', $fromRest = false)
182  {
183  $errMsg = '';
184  if (!($uploadedFile instanceof UploadedFile)) {
185  $errMsg = _("No file selected");
186  } elseif ($uploadedFile->getSize() == 0 && $uploadedFile->getError() == 0) {
187  $errMsg = _("Larger than upload_max_filesize ") . ini_get(self::KEY_UPLOAD_MAX_FILESIZE);
188  } elseif (
189  $uploadedFile->getClientOriginalExtension() != 'csv'
190  && $uploadedFile->getClientOriginalExtension() != 'json'
191  ) {
192  $errMsg = _('Invalid extension ') .
193  $uploadedFile->getClientOriginalExtension() . ' of file ' .
194  $uploadedFile->getClientOriginalName();
195  }
196  if (!empty($errMsg)) {
197  if ($fromRest) {
198  return array(false, $errMsg, 400);
199  }
200  return $errMsg;
201  }
202  $this->obligationsCsvImport->setDelimiter($delimiter);
203  $this->obligationsCsvImport->setEnclosure($enclosure);
204 
205  return array(true, $this->obligationsCsvImport->handleFile($uploadedFile->getRealPath(), $uploadedFile->getClientOriginalExtension()), 200);
206  }
207 }
208 
209 register_plugin(new AdminObligationFromCSV());
Helper class for Obligation CSV Import.
Contains the constants and helpers for authentication of user.
Definition: Auth.php:24
Exception when Guzzle client response is not as expected.
render($templateName, $vars=null, $headers=null)
static processHttpResponse($response)
Definition: HttpUtils.php:89
static getGuzzleClient(array $SysConf, string $baseUri, string $token="")
Definition: HttpUtils.php:25
static checkLicenseDBHealth(string $getHealth, $guzzleClient)
Definition: HttpUtils.php:62
Upload a file from the users computer using the UI.
handleFileUpload($uploadedFile, $delimiter=',', $enclosure='"', $fromRest = false)
char * trim(char *ptext)
Trimming whitespace.
Definition: fossconfig.c:690
fo_conf * sysconfig