main.py 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. import os
  2. import openai
  3. from flask import Flask, request, jsonify, send_from_directory, url_for
  4. import json
  5. app = Flask(__name__)
  6. ssl = None
  7. # ssl =('/etc/ssl/sample.crt', '/etc/ssl/sample.pem')
  8. openai_key = os.environ.get("OPENAI_KEY", "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")
  9. openai.api_key = openai_key
  10. app.chat_messages = [
  11. {"role": "system",
  12. "content": "Please respond professionally and in a friendly manner, using the same language as the original request."}
  13. ]
  14. app.translate_messages = [
  15. {"role": "system",
  16. "content": "Please translate using the requested language."}
  17. ]
  18. app.suggest_messages = [
  19. {"role": "system",
  20. "content": "Please suggest reply messages based on the previous conversations and the user's request."}
  21. ]
  22. app.recommend_messages = [
  23. {"role": "system",
  24. "content": "Give normalized total weight of each category in json based on headlines"
  25. }
  26. ]
  27. UPLOAD_FOLDER = 'files'
  28. app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER
  29. @app.route('/files/<name>')
  30. def download_file(name):
  31. return send_from_directory(app.config["UPLOAD_FOLDER"], name)
  32. @app.route('/', methods=['GET', 'POST'])
  33. def test():
  34. return jsonify({"status": "0"})
  35. def recommend(headlines, category):
  36. chat_messages = app.recommend_messages.copy()
  37. try:
  38. json_payload = {
  39. "role": "user",
  40. "content": f"""{headlines}
  41. Berikan nilai berat masing-masing kategori, jumlahkan dan normalisasikan:
  42. {category}
  43. Berikan dalam bentuk json
  44. """
  45. }
  46. chat_messages.append(json_payload)
  47. print(chat_messages)
  48. json_response = openai.ChatCompletion.create(model="gpt-3.5-turbo-1106",
  49. messages=chat_messages,
  50. response_format={ "type": "json_object" }
  51. )
  52. print(json_response.choices[0]["message"]["content"])
  53. return json.loads(json_response.choices[0]["message"]["content"])
  54. except Exception as error_print:
  55. app.logger.error(error_print)
  56. result = {}, 405
  57. def vision(message, image_url=None, image_b64=None):
  58. chat_messages = app.chat_messages.copy()
  59. url = ""
  60. if image_url:
  61. url = f"{image_url}"
  62. elif image_b64:
  63. url = f"data:image/jpeg;base64,{image_b64}"
  64. try:
  65. json_payload = {
  66. "role": "user",
  67. "content": [
  68. {"type": "text", "text": message},
  69. {
  70. "type": "image_url",
  71. "image_url": {
  72. "url": url,
  73. },
  74. },
  75. ],
  76. }
  77. chat_messages.append(json_payload)
  78. print(chat_messages)
  79. json_response = openai.ChatCompletion.create(
  80. model="gpt-4-vision-preview",
  81. messages=chat_messages,
  82. max_tokens=300
  83. )
  84. return json_response.choices[0]["message"]
  85. except Exception as error_print:
  86. app.logger.error(error_print)
  87. result = {}, 405
  88. @app.route('/gpt', methods=['POST'])
  89. def gpt():
  90. chat_messages = app.chat_messages.copy()
  91. use_video = False
  92. suggest = False
  93. category = []
  94. headlines = []
  95. image_url = ""
  96. num_choices = 1
  97. json_payload = request.get_json()
  98. if not json_payload:
  99. json_payload = []
  100. has_named_params = False
  101. if isinstance(json_payload, dict):
  102. has_named_params = 'payload' in json_payload
  103. if 'payload' in json_payload:
  104. if 'num_choices' in json_payload:
  105. num_choices = 5 if json_payload['num_choices'] > 5 else json_payload['num_choices']
  106. if 'use_video' in json_payload:
  107. use_video = json_payload['use_video'] == "1"
  108. if 'translate' in json_payload:
  109. chat_messages = app.translate_messages.copy()
  110. json_payload['payload'][-1]['content'] = json_payload['payload'][-1]['content'] + f" (Translate to {json_payload['translate']})"
  111. elif 'suggest' in json_payload:
  112. suggest = json_payload['suggest'] == "1"
  113. if suggest:
  114. chat_messages = app.suggest_messages.copy()
  115. else:
  116. chat_messages = app.chat_messages.copy()
  117. json_payload['payload'][-1]['content'] = json_payload['payload'][-1]['content'] + f" What can I say to him/her?"
  118. else:
  119. chat_messages = app.chat_messages.copy()
  120. json_payload = json_payload['payload']
  121. if isinstance(json_payload, dict):
  122. json_payload = [json_payload]
  123. elif 'greeting' in json_payload:
  124. chat_messages = app.chat_messages.copy()
  125. company_name = json_payload['greeting']['company_name']
  126. timestamp = json_payload['greeting']['timestamp']
  127. islamic_message = f"Apakah Nama '{company_name}' terdapat unsur islami? Jawab dengan 'Ya' atau 'Tidak'"
  128. islam_messages = app.chat_messages.copy()
  129. islam_messages.append({
  130. "role": "user",
  131. "content": islamic_message
  132. })
  133. islamic_response = openai.ChatCompletion.create(model="gpt-3.5-turbo", # GPT-3.5 Turbo engine
  134. messages=islam_messages,
  135. max_tokens=2, temperature=0.5)
  136. if 'Ya' in islamic_response.choices[0].message['content']:
  137. greeting_message = f"Buatkan respons chatbot berupa greeting dari chat perusahaan bernama {company_name} pada jam {timestamp}, tidak perlu mention waktu, dan jawab dengan 'Assalamu'alaikum...' terlebih dahulu"
  138. else:
  139. greeting_message = f"Buatkan respons chatbot berupa greeting dari chat perusahaan bernama {company_name} pada jam {timestamp}, tidak perlu mention waktu"
  140. json_payload = [
  141. {
  142. "role": "user",
  143. "content": greeting_message
  144. }
  145. ]
  146. elif 'recommend' in json_payload:
  147. headlines = json_payload['recommend']['headlines']
  148. category = json_payload['recommend']['category']
  149. return recommend(headlines, category)
  150. elif 'image_url' in json_payload:
  151. image = json_payload['image_url']
  152. message = json_payload["message"] if 'message' in json_payload else "Ini gambar apa?"
  153. return vision(message,image_url=image)
  154. elif 'image_b64' in json_payload:
  155. image = json_payload['image_b64']
  156. message = json_payload["message"] if 'message' in json_payload else "Ini gambar apa?"
  157. return vision(message,image_b64=image_url)
  158. else:
  159. chat_messages = app.chat_messages.copy()
  160. json_payload = [json_payload]
  161. json_payload = json_payload[-7:]
  162. for message in json_payload:
  163. content = message['content']
  164. content_arr = content.split(" ")
  165. new_content_arr = content[:300].split(" ")
  166. new_content_len = len(new_content_arr)
  167. arr = []
  168. for i in range(new_content_len):
  169. arr.append(content_arr[i])
  170. message['content'] = " ".join(arr)
  171. chat_messages.append(message)
  172. app.logger.info(chat_messages)
  173. result = {}
  174. try:
  175. n = num_choices
  176. json_response = openai.ChatCompletion.create(model="gpt-3.5-turbo", # GPT-3.5 Turbo engine
  177. messages=chat_messages,
  178. max_tokens=600, temperature=0.7, n = n)
  179. app.logger.info(json_response.choices[0].message)
  180. if has_named_params:
  181. if suggest:
  182. choices = json_response.choices
  183. messages = [i.message for i in choices]
  184. result = {"url": "", "message": messages}
  185. elif use_video:
  186. # TODO: to be implemented
  187. result = {"url": url_for('download_file', name="test.mp4", _external=True), "message": json_response.choices[0].message}
  188. else:
  189. result = {"url": "", "message": json_response.choices[0].message}
  190. else:
  191. result = json_response.choices[0].message
  192. except Exception as error_print:
  193. app.logger.error(error_print)
  194. result = {}, 405
  195. return result
  196. # Press the green button in the gutter to run the script.
  197. if __name__ == '__main__':
  198. app.run(host='0.0.0.0', port=8348, debug=True, ssl_context=ssl)
  199. # See PyCharm help at https://www.jetbrains.com/help/pycharm/