templateManager = $templateManager; } /** * List the available templates * * @return DataResponse, array{}> * * 200: Available templates returned */ #[NoAdminRequired] public function list(): DataResponse { return new DataResponse($this->templateManager->listTemplates()); } /** * Create a template * * @param string $filePath Path of the file * @param string $templatePath Name of the template * @param string $templateType Type of the template * @param FilesTemplateField[] $templateFields Fields of the template * * @return DataResponse * @throws OCSForbiddenException Creating template is not allowed * * 200: Template created successfully */ #[NoAdminRequired] public function create( string $filePath, string $templatePath = '', string $templateType = 'user', array $templateFields = [] ): DataResponse { try { return new DataResponse($this->templateManager->createFromTemplate( $filePath, $templatePath, $templateType, $templateFields)); } catch (GenericFileException $e) { throw new OCSForbiddenException($e->getMessage()); } } /** * Initialize the template directory * * @param string $templatePath Path of the template directory * @param bool $copySystemTemplates Whether to copy the system templates to the template directory * * @return DataResponse * @throws OCSForbiddenException Initializing the template directory is not allowed * * 200: Template directory initialized successfully */ #[NoAdminRequired] public function path(string $templatePath = '', bool $copySystemTemplates = false) { try { /** @var string $templatePath */ $templatePath = $this->templateManager->initializeTemplateDirectory($templatePath, null, $copySystemTemplates); return new DataResponse([ 'template_path' => $templatePath, 'templates' => array_map(fn (TemplateFileCreator $creator) => $creator->jsonSerialize(), $this->templateManager->listCreators()), ]); } catch (\Exception $e) { throw new OCSForbiddenException($e->getMessage()); } } }