relatorioClient = $relatorioClient; $this->logger = $logger; $this->url = $parameterBag->get('chill_doc_generator')['driver']['relatorio']['url']; } public function generateFromResource($template, string $resourceType, array $data, ?string $templateName = null) { $formFields = [ 'variables' => json_encode($data), 'template' => new DataPart($template, $templateName ?? uniqid('template_'), $resourceType), ]; $form = new FormDataPart($formFields); dump(json_encode($data)); try { $response = $this->relatorioClient->request('POST', $this->url, [ 'headers' => $form->getPreparedHeaders()->toArray(), 'body' => $form->bodyToIterable(), ]); return $response->toStream(); } catch (HttpExceptionInterface $e) { $content = $e->getResponse()->getContent(false); if (400 === $e->getResponse()->getStatusCode()) { $content = json_decode($content, true); $this->logger->error('relatorio: template error', [ 'error' => $content['message'] ?? '_not defined', ]); throw new TemplateException([$content['message']]); } $this->logger->error('relatorio: error while generating document', [ 'msg' => $e->getMessage(), 'response' => $e->getResponse()->getStatusCode(), 'content' => $content, ]); throw $e; } catch (TransportExceptionInterface $e) { $this->logger->error('relatorio: transport exception', [ 'msg' => $e->getMessage(), 'e' => $e->getTraceAsString(), ]); throw $e; } catch (DecodingExceptionInterface $e) { $this->logger->error('relatorio: could not decode response', [ 'msg' => $e->getMessage(), 'e' => $e->getTraceAsString(), ]); throw $e; } } }