audio.py 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. # -*- coding:utf-8 -*-
  2. import logging
  3. from flask import request
  4. from libs.login import login_required
  5. from werkzeug.exceptions import InternalServerError
  6. import services
  7. from controllers.console import api
  8. from controllers.console.app import _get_app
  9. from controllers.console.app.error import AppUnavailableError, \
  10. ProviderNotInitializeError, CompletionRequestError, ProviderQuotaExceededError, \
  11. ProviderModelCurrentlyNotSupportError, NoAudioUploadedError, AudioTooLargeError, \
  12. UnsupportedAudioTypeError, ProviderNotSupportSpeechToTextError
  13. from controllers.console.setup import setup_required
  14. from controllers.console.wraps import account_initialization_required
  15. from core.model_providers.error import LLMBadRequestError, LLMAPIUnavailableError, LLMAuthorizationError, LLMAPIConnectionError, \
  16. LLMRateLimitError, ProviderTokenNotInitError, QuotaExceededError, ModelCurrentlyNotSupportError
  17. from flask_restful import Resource
  18. from services.audio_service import AudioService
  19. from services.errors.audio import NoAudioUploadedServiceError, AudioTooLargeServiceError, \
  20. UnsupportedAudioTypeServiceError, ProviderNotSupportSpeechToTextServiceError
  21. class ChatMessageAudioApi(Resource):
  22. @setup_required
  23. @login_required
  24. @account_initialization_required
  25. def post(self, app_id):
  26. app_id = str(app_id)
  27. app_model = _get_app(app_id, 'chat')
  28. file = request.files['file']
  29. try:
  30. response = AudioService.transcript(
  31. tenant_id=app_model.tenant_id,
  32. file=file,
  33. )
  34. return response
  35. except services.errors.app_model_config.AppModelConfigBrokenError:
  36. logging.exception("App model config broken.")
  37. raise AppUnavailableError()
  38. except NoAudioUploadedServiceError:
  39. raise NoAudioUploadedError()
  40. except AudioTooLargeServiceError as e:
  41. raise AudioTooLargeError(str(e))
  42. except UnsupportedAudioTypeServiceError:
  43. raise UnsupportedAudioTypeError()
  44. except ProviderNotSupportSpeechToTextServiceError:
  45. raise ProviderNotSupportSpeechToTextError()
  46. except ProviderTokenNotInitError as ex:
  47. raise ProviderNotInitializeError(ex.description)
  48. except QuotaExceededError:
  49. raise ProviderQuotaExceededError()
  50. except ModelCurrentlyNotSupportError:
  51. raise ProviderModelCurrentlyNotSupportError()
  52. except (LLMBadRequestError, LLMAPIConnectionError, LLMAPIUnavailableError,
  53. LLMRateLimitError, LLMAuthorizationError) as e:
  54. raise CompletionRequestError(str(e))
  55. except ValueError as e:
  56. raise e
  57. except Exception as e:
  58. logging.exception("internal server error.")
  59. raise InternalServerError()
  60. api.add_resource(ChatMessageAudioApi, '/apps/<uuid:app_id>/audio-to-text')