audio.py 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. # -*- coding:utf-8 -*-
  2. import logging
  3. from flask import request
  4. from core.model_runtime.errors.invoke import InvokeError
  5. from libs.login import login_required
  6. from werkzeug.exceptions import InternalServerError
  7. import services
  8. from controllers.console import api
  9. from controllers.console.app import _get_app
  10. from controllers.console.app.error import AppUnavailableError, \
  11. ProviderNotInitializeError, CompletionRequestError, ProviderQuotaExceededError, \
  12. ProviderModelCurrentlyNotSupportError, NoAudioUploadedError, AudioTooLargeError, \
  13. UnsupportedAudioTypeError, ProviderNotSupportSpeechToTextError
  14. from controllers.console.setup import setup_required
  15. from controllers.console.wraps import account_initialization_required
  16. from core.errors.error import 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 InvokeError as e:
  53. raise CompletionRequestError(str(e))
  54. except ValueError as e:
  55. raise e
  56. except Exception as e:
  57. logging.exception("internal server error.")
  58. raise InternalServerError()
  59. api.add_resource(ChatMessageAudioApi, '/apps/<uuid:app_id>/audio-to-text')