Open julien-nc opened 3 months ago
@julien-nc we have a bit of a problem here.
We need OCS APIs as our mobile and desktop clients are calling it, and they should "respond" with it and not be delegated to a background job (No one will wait 5 minutes on the translation of a chat message).
Can be done in a background job, should be fine (we do that now as well as far as I know)
Also the API endpoints in https://github.com/nextcloud/server/blob/bc5c0262af3cd375620d6534353a3842149ad6ab/core/Controller/TranslationApiController.php are not marked as @deprecated
No one will wait 5 minutes on the translation of a chat message
If the provider is an exApp, it will process tasks ASAP, no delay. If the provider is a Php app and occ background-job:worker "OC\TaskProcessing\SynchronousBackgroundJob"
is running, no delay either.
Once the task is scheduled, the clients can poll it with ocs/v2.php/taskprocessing/task/TASK_ID
. That's what the assistant does in the frontend. No more blocking request as it could be too long and be killed but also it blocks a Php runner while waiting.
So instead of getting a string returned the clients shall DOS the server. The feature still breaks for existing clients.
We can also keep the providers for the old APIs in integration_openai and the features in Talk are not broken.
I will check with Andy next week what to do.
Two things should make it more convenient:
FreePromptTaskType
, HeadlineTaskType
, SummaryTaskType
and TopicsTaskType
because they have exact matches in the new API) and the SpeechToText API. This means you will benefit from new providers while using the old APIs.runTask
method to run a task synchronously. This should make the migration easier.All this is in stable30 already.
The providers for the Translate API and the TaskProcessing API are implemented in different apps so you can keep using the Translate API as long as you want.
Translation and SpeechToText backend APIs are deprecated. Those features are now included in the task processing API (since 30).
The old APIs will stay a few more NC major version. The old SpeechToText API can now use the new providers (for TaskProcessing) so there is no rush to migrate.
The providers for the Translate API and the translation providers for the TaskProcessing API can be installed side by side so there is no rush to migrate there either.
Translation
You can use the assistant's UI to run translation tasks in the UI. If the assistant app is enabled, the
OCA.Assistant.openAssistantForm
function should be available.The promise will resolve if the task succeeds, fails or is scheduled for later by the user. The promise result is the task object. The
closeOnResult
parameter ofOCA.Assistant.openAssistantForm
decides if the assistant is closed when the task succeeds of fails. It can be false to stay close to the current behaviour of the translate modal in Talk. The user sees the result in the assistant and there is a "copy" button. The user can then close the assistant modal.SpeechToText
Transcription can be done with the
core:audio2text
task type of the taskProcessing API. More details on how to run such task in the backend in theTranscribe
section of https://github.com/nextcloud/assistant/issues/114