kenken999 commited on
Commit
d480d5f
·
2 Parent(s): f0afb34 072761e

Merge branch 'main' of https://huggingface.co/spaces/kenken999/fastapi_django_main

Browse files
This view is limited to 50 files because it contains too many changes.   See raw diff
Files changed (50) hide show
  1. babyagi/prompt.txt +1 -1
  2. chat_history.db +2 -2
  3. chroma/{6be188e8-482c-4e1e-8fbd-8157045b1e21 → 1303e1ad-d2ff-495f-b987-6ef0f8327781}/data_level0.bin +1 -1
  4. chroma/{6be188e8-482c-4e1e-8fbd-8157045b1e21 → 1303e1ad-d2ff-495f-b987-6ef0f8327781}/header.bin +0 -0
  5. chroma/{6be188e8-482c-4e1e-8fbd-8157045b1e21 → 1303e1ad-d2ff-495f-b987-6ef0f8327781}/length.bin +1 -1
  6. chroma/{6be188e8-482c-4e1e-8fbd-8157045b1e21 → 1303e1ad-d2ff-495f-b987-6ef0f8327781}/link_lists.bin +0 -0
  7. chroma/chroma.sqlite3 +2 -2
  8. command/line/get_user_profile.py +17 -0
  9. command/line_get_user_profile.py +17 -0
  10. command/n8n.py +24 -4
  11. command/postgresz.py +71 -0
  12. controllers/gpt_enginner20240624094443 +0 -1
  13. controllers/gpt_enginner20240624094925 +0 -1
  14. controllers/gpt_enginner20240624095357 +0 -1
  15. controllers/gpt_enginner20240624100018 +0 -1
  16. controllers/gpt_enginner20240624100935 +0 -1
  17. controllers/gpt_enginner20240624101200 +0 -1
  18. controllers/gpt_enginner20240624101533 +0 -1
  19. controllers/gpt_enginner20240624101712 +0 -1
  20. controllers/gpt_enginner20240624101901 +0 -1
  21. controllers/gpt_enginner20240624102749 +0 -1
  22. controllers/gpt_enginner20240624103101 +0 -1
  23. controllers/gpt_enginner20240624103250 +0 -1
  24. controllers/gpt_enginner20240624104628 +0 -1
  25. controllers/gpt_enginner20240624105138 +0 -1
  26. controllers/gpt_enginner20240624105436/.gpteng/memory/logs/all_output.txt +0 -339
  27. controllers/gpt_enginner20240624105436/.gpteng/memory/logs/gen_entrypoint_chat.txt +0 -181
  28. controllers/gpt_enginner20240624105436/Code.gs +0 -8
  29. controllers/gpt_enginner20240624105436/app/models.py +0 -18
  30. controllers/gpt_enginner20240624105436/app/views.py +0 -15
  31. controllers/gpt_enginner20240624105436/gradio_app.py +0 -31
  32. controllers/gpt_enginner20240624105436/program_description.md +0 -18
  33. controllers/gpt_enginner20240624105436/prompt +0 -39
  34. controllers/gpt_enginner20240624105436/requirements.txt +0 -4
  35. controllers/gpt_enginner20240624105436/router.py +0 -12
  36. controllers/gpt_enginner20240624105436/run.sh +0 -13
  37. controllers/gpt_enginner20240624105436/sequence_diagram.puml +0 -14
  38. controllers/gpt_enginner20240624105951 +0 -1
  39. controllers/gpt_enginner20240624110325 +0 -1
  40. controllers/gpt_enginner20240624110523 +0 -1
  41. controllers/gpt_enginner20240624110747 +0 -1
  42. controllers/gpt_enginner20240624111114 +0 -1
  43. controllers/gpt_enginner20240624111439 +0 -1
  44. controllers/gpt_enginner20240624111658 +0 -1
  45. controllers/gpt_enginner20240624112106 +0 -1
  46. controllers/gpt_enginner20240624112338 +0 -1
  47. controllers/gpt_enginner20240624112600 +0 -1
  48. controllers/gpt_enginner20240624112801 +0 -1
  49. controllers/gpt_enginner20240624112951 +0 -1
  50. controllers/gpt_enginner20240624113357 +0 -1
babyagi/prompt.txt CHANGED
@@ -1 +1 @@
1
- 買取方法の質問 についてチャットボットでよりよく対応するプランを日本語で作成して
 
1
+ 店頭買取の質問 についてチャットボットでよりよく対応するプランを日本語で作成して
chat_history.db CHANGED
@@ -1,3 +1,3 @@
1
  version https://git-lfs.github.com/spec/v1
2
- oid sha256:bc2b148afa2b4a5d5de345903b601e4eebf94fb36525b463d0211d457b8868f3
3
- size 1564672
 
1
  version https://git-lfs.github.com/spec/v1
2
+ oid sha256:4e7dc7386ab950df36aa934dcc53dc4e05dd13d67318d6d47ac1405c0ea3f679
3
+ size 1617920
chroma/{6be188e8-482c-4e1e-8fbd-8157045b1e21 → 1303e1ad-d2ff-495f-b987-6ef0f8327781}/data_level0.bin RENAMED
@@ -1,3 +1,3 @@
1
  version https://git-lfs.github.com/spec/v1
2
- oid sha256:f8ef617215fddbae3876974795b3ae6d8444d4578e5e9fade87aa6a5e74f1e2b
3
  size 1676000
 
1
  version https://git-lfs.github.com/spec/v1
2
+ oid sha256:d3c9fd302f000d7790aa403c2d0d8fec363fe46f30b07d53020b6e33b22435a9
3
  size 1676000
chroma/{6be188e8-482c-4e1e-8fbd-8157045b1e21 → 1303e1ad-d2ff-495f-b987-6ef0f8327781}/header.bin RENAMED
File without changes
chroma/{6be188e8-482c-4e1e-8fbd-8157045b1e21 → 1303e1ad-d2ff-495f-b987-6ef0f8327781}/length.bin RENAMED
@@ -1,3 +1,3 @@
1
  version https://git-lfs.github.com/spec/v1
2
- oid sha256:a589d21c3814181dc3622665b49f124dcdd4aaab9104130af40e8083cfe16262
3
  size 4000
 
1
  version https://git-lfs.github.com/spec/v1
2
+ oid sha256:8a28a74a9c1e4a9630d9c06d28c53c13a8ee77712a6be89e30fcd44245adff29
3
  size 4000
chroma/{6be188e8-482c-4e1e-8fbd-8157045b1e21 → 1303e1ad-d2ff-495f-b987-6ef0f8327781}/link_lists.bin RENAMED
File without changes
chroma/chroma.sqlite3 CHANGED
@@ -1,3 +1,3 @@
1
  version https://git-lfs.github.com/spec/v1
2
- oid sha256:ff265913d2cd0fd532787389d29c13a5e25fd886704eb76359128bb3f7ab729d
3
- size 1196032
 
1
  version https://git-lfs.github.com/spec/v1
2
+ oid sha256:a72f195f0ceaaa3f38e1145a772eeb42d267938cfb3b90016ce7258dc61df896
3
+ size 253952
command/line/get_user_profile.py ADDED
@@ -0,0 +1,17 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import requests
2
+
3
+ def get_user_profile(user_id, access_token):
4
+ url = f'https://api.line.me/v2/bot/profile/{user_id}'
5
+ headers = {
6
+ 'Authorization': f'Bearer {access_token}'
7
+ }
8
+
9
+ response = requests.get(url, headers=headers)
10
+ if response.status_code == 200:
11
+ profile = response.json()
12
+ user_name = profile.get('displayName')
13
+ user_thumbnail = profile.get('pictureUrl')
14
+ return user_name, user_thumbnail
15
+ else:
16
+ print(f"Failed to get user profile: {response.status_code}, {response.text}")
17
+ return None, None
command/line_get_user_profile.py ADDED
@@ -0,0 +1,17 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import requests
2
+
3
+ def get_user_profile(user_id, access_token):
4
+ url = f'https://api.line.me/v2/bot/profile/{user_id}'
5
+ headers = {
6
+ 'Authorization': f'Bearer {access_token}'
7
+ }
8
+
9
+ response = requests.get(url, headers=headers)
10
+ if response.status_code == 200:
11
+ profile = response.json()
12
+ user_name = profile.get('displayName')
13
+ user_thumbnail = profile.get('pictureUrl')
14
+ return user_name, user_thumbnail
15
+ else:
16
+ print(f"Failed to get user profile: {response.status_code}, {response.text}")
17
+ return None, None
command/n8n.py CHANGED
@@ -1,6 +1,26 @@
1
  import requests
2
 
3
- def post_data(url, word, thread):
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4
  # POSTリクエストのペイロード
5
  payload = {
6
  'word': word,
@@ -8,9 +28,9 @@ def post_data(url, word, thread):
8
  }
9
 
10
  # ヘッダーの設定(必要に応じて)
11
- headers = {
12
- 'Content-Type': 'application/json'
13
- }
14
 
15
  # POSTリクエストの送信
16
  response = requests.post(url, json=payload, headers=headers)
 
1
  import requests
2
 
3
+ def post_data_line(url, body,headers):
4
+ # POSTリクエストのペイロード
5
+ payload = body
6
+
7
+ # ヘッダーの設定(必要に応じて)
8
+ #$headers = {
9
+ # 'Content-Type': 'application/json'
10
+ #}
11
+ #
12
+ # POSTリクエストの送信
13
+ #response = requests.post(url, json=payload, headers=headers)
14
+ response = requests.post(url, headers=headers, data=body)
15
+ # レスポンスのステータスコードを表示
16
+ print(f'Status Code: {response.status_code}')
17
+
18
+ # レスポンスの内容を表示
19
+ print(f'Response Content: {response.content.decode()}')
20
+
21
+ return response
22
+
23
+ def post_data(url, word, thread,headers):
24
  # POSTリクエストのペイロード
25
  payload = {
26
  'word': word,
 
28
  }
29
 
30
  # ヘッダーの設定(必要に応じて)
31
+ #$headers = {
32
+ # 'Content-Type': 'application/json'
33
+ #}
34
 
35
  # POSTリクエストの送信
36
  response = requests.post(url, json=payload, headers=headers)
command/postgresz.py ADDED
@@ -0,0 +1,71 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import psycopg2
2
+
3
+ # PostgreSQLの設定
4
+ conn_params = {
5
+ "dbname": "neondb",
6
+ "user": "miyataken999",
7
+ "password": "yz1wPf4KrWTm",
8
+ "host": "ep-odd-mode-93794521.us-east-2.aws.neon.tech",
9
+ "port": 5432,
10
+ "sslmode": "require"
11
+ }
12
+
13
+ def initialize_db():
14
+ # PostgreSQLに接続
15
+ conn = psycopg2.connect(**conn_params)
16
+ cursor = conn.cursor()
17
+
18
+ # テーブルを作成するSQL文
19
+ create_table_query = """
20
+ CREATE TABLE IF NOT EXISTS chat_history (
21
+ id SERIAL PRIMARY KEY,
22
+ role TEXT,
23
+ type TEXT,
24
+ content TEXT,
25
+ timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP
26
+ )
27
+ """
28
+ cursor.execute(create_table_query)
29
+
30
+ # 別のテーブルを作成するSQL文
31
+ create_history_table_query = """
32
+ CREATE TABLE IF NOT EXISTS history (
33
+ id SERIAL PRIMARY KEY,
34
+ role TEXT,
35
+ type TEXT,
36
+ content TEXT,
37
+ timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP
38
+ )
39
+ """
40
+ cursor.execute(create_history_table_query)
41
+
42
+ conn.commit()
43
+ cursor.close()
44
+ conn.close()
45
+ print("データベースとテーブルが作成されました。")
46
+
47
+ def add_message_to_db(role, message_type, content):
48
+ conn = psycopg2.connect(**conn_params)
49
+ cursor = conn.cursor()
50
+ cursor.execute(
51
+ "INSERT INTO history (role, type, content, timestamp) VALUES (%s, %s, %s, CURRENT_TIMESTAMP)",
52
+ (role, message_type, content)
53
+ )
54
+ conn.commit()
55
+ cursor.close()
56
+ conn.close()
57
+
58
+ def get_recent_messages(limit=5):
59
+ conn = psycopg2.connect(**conn_params)
60
+ cursor = conn.cursor()
61
+ cursor.execute(
62
+ "SELECT role, type, content FROM history ORDER BY timestamp DESC LIMIT %s",
63
+ (limit,)
64
+ )
65
+ messages = cursor.fetchall()
66
+ cursor.close()
67
+ conn.close()
68
+ return messages[::-1] # 最新のlimit件を取得して逆順にする
69
+
70
+ # データベースの初期化
71
+ initialize_db()
controllers/gpt_enginner20240624094443 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 7a7c46d8d4105d7489b18ff1788ba017ee7bf842
 
 
controllers/gpt_enginner20240624094925 DELETED
@@ -1 +0,0 @@
1
- Subproject commit bc854359cf2a6ee7d77773da299191171ace1fb9
 
 
controllers/gpt_enginner20240624095357 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 9534d7bcfeb29cf21833130ac2adbe40ee49291f
 
 
controllers/gpt_enginner20240624100018 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 95bef2cbe9afcd9d543a0dc5e99013277dc07400
 
 
controllers/gpt_enginner20240624100935 DELETED
@@ -1 +0,0 @@
1
- Subproject commit eb4ecacab45baa2f2c568c0303c7e33572836d54
 
 
controllers/gpt_enginner20240624101200 DELETED
@@ -1 +0,0 @@
1
- Subproject commit e3466a69142feea9b1e4b32b6f7514cd73721df0
 
 
controllers/gpt_enginner20240624101533 DELETED
@@ -1 +0,0 @@
1
- Subproject commit f5497ca943e5a8e3aea02ff158275d75f7ae767d
 
 
controllers/gpt_enginner20240624101712 DELETED
@@ -1 +0,0 @@
1
- Subproject commit e59fd5dfe1d4fa3e4636b9fea903955ba6c63c6e
 
 
controllers/gpt_enginner20240624101901 DELETED
@@ -1 +0,0 @@
1
- Subproject commit e5927270157ac85eee893b9e0aeea56cfd711d5a
 
 
controllers/gpt_enginner20240624102749 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 1f75de0b3854b10a899d36ab5ad89c30a0825144
 
 
controllers/gpt_enginner20240624103101 DELETED
@@ -1 +0,0 @@
1
- Subproject commit a30a2e1a1a2768e4ac8b82080dc8fd939c115291
 
 
controllers/gpt_enginner20240624103250 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 4ba0e0b8da71573c78d65b56e4abbf5d39e05be9
 
 
controllers/gpt_enginner20240624104628 DELETED
@@ -1 +0,0 @@
1
- Subproject commit ef3b0879d896f762dbe69f7506e4c52c9f022422
 
 
controllers/gpt_enginner20240624105138 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 654f4fa091bc8e8bae0b23e20a20570feaca9128
 
 
controllers/gpt_enginner20240624105436/.gpteng/memory/logs/all_output.txt DELETED
@@ -1,339 +0,0 @@
1
-
2
- 2024-06-24T10:54:47.340708
3
- ================================ System Message ================================
4
-
5
- You will get instructions for code to write.
6
- You will write a very long answer. Make sure that every detail of the architecture is, in the end, implemented as code.
7
- Think step by step and reason yourself to the correct decisions to make sure we get it right.
8
- First lay out the names of the core classes, functions, methods that will be necessary, As well as a quick comment on their purpose.
9
-
10
- You will output the content of each file necessary to achieve the goal, including ALL code.
11
- Represent files like so:
12
-
13
- FILENAME
14
- ```
15
- CODE
16
- ```
17
-
18
- The following tokens must be replaced like so:
19
- FILENAME is the lowercase combined path and file name including the file extension
20
- CODE is the code in the file
21
-
22
- Example representation of a file:
23
-
24
- src/hello_world.py
25
- ```
26
- print("Hello World")
27
- ```
28
-
29
- Do not comment on what every file does. Please note that the code should be fully functional. No placeholders.
30
-
31
-
32
- You will start with the "entrypoint" file, then go to the ones that are imported by that file, and so on.
33
- Please note that the code should be fully functional. No placeholders.
34
-
35
- Follow a language and framework appropriate best practice file naming convention.
36
- Make sure that files contain all imports, types etc. The code should be fully functional. Make sure that code in different files are compatible with each other.
37
- Ensure to implement all code, if you are unsure, write a plausible implementation.
38
- Include module dependency or package manager dependency definition file.
39
- Before you finish, double check that all parts of the architecture is present in the files.
40
-
41
- When you are done, write finish with "this concludes a fully working implementation".
42
-
43
- Useful to know:
44
- Almost always put different classes in different files.
45
- Always use the programming language the user asks for.
46
- For Python, you always create an appropriate requirements.txt file.
47
- For NodeJS, you always create an appropriate package.json file.
48
- Always add a comment briefly describing the purpose of the function definition.
49
- Add comments explaining very complex bits of logic.
50
- Always follow the best practices for the requested languages for folder/file structure and how to package the project.
51
-
52
-
53
- Python toolbelt preferences:
54
- - pytest
55
- - dataclasses
56
-
57
-
58
- ================================ Human Message =================================
59
-
60
- Request:
61
- 下記の質問に対応するコードをdjangoでアプリを作成 プロジェクトはいりません
62
- fastapiでrouter部分を作成 組み込みはメイン部分でします
63
- フロントエンドをgradioで作成
64
- #google apps script frontend
65
- googleappsscript doGet でのgradioの表示処理を作成 google.script.runで関数は呼び出し
66
- #google apps script backend
67
- frontendからの呼び出し用のバックエンドスクリプト
68
- 仕様書の作成
69
- PlantUMLでシーケンス図の作成
70
- Markdownでのプログラム殺名
71
-
72
- 下記の質問 作成対応内容
73
-
74
- 左様です。 本日は11:00~20:00まで営業時間内にお連絡可能です。検討中の商品について、査定人にお問い合わせください。以下の情報をお送りくださいませ。
75
-
76
- * ダイヤモンドの場合は、carat、cut、color、clarity、depthなどを
77
- * ブランド商品の場合は、ブランド名、モデル名、型番や品番、購入店、購入時期、購入金額、付属品、コンディションなどを
78
-
79
- お送りくださいませ。迅速に査定結果をお返しします。
80
- 下記の質問に対応するコードをdjangoでアプリを作成 プロジェクトはいりません
81
- fastapiでrouter部分を作成 組み込みはメイン部分でします
82
- フロントエンドをgradioで作成
83
- #google apps script frontend
84
- googleappsscript doGet でのgradioの表示処理を作成 google.script.runで関数は呼び出し
85
- #google apps script backend
86
- frontendからの呼び出し用のバックエンドスクリプト
87
- 仕様書の作成
88
- PlantUMLでシーケンス図の作成
89
- Markdownでのプログラム殺名
90
-
91
- 下記の質問 作成対応内容
92
-
93
- 左様です。 本日は11:00~20:00まで営業時間内にお連絡可能です。検討中の商品について、査定人にお問い合わせください。以下の情報をお送りくださいませ。
94
-
95
- * ダイヤモンドの場合は、carat、cut、color、clarity、depthなどを
96
- * ブランド商品の場合は、ブランド名、モデル名、型番や品番、購入���、購入時期、購入金額、付属品、コンディションなどを
97
-
98
- お送りくださいませ。迅速に査定結果をお返しします。
99
-
100
- ================================== Ai Message ==================================
101
-
102
- Here is the implementation of the requested system.
103
-
104
- **Django App**
105
-
106
- `requirements.txt`
107
- ```
108
- django
109
- fastapi
110
- gradio
111
- google-api-python-client
112
- ```
113
-
114
- `app/models.py`
115
- ```
116
- from django.db import models
117
-
118
- class Diamond(models.Model):
119
- carat = models.DecimalField(max_digits=5, decimal_places=2)
120
- cut = models.CharField(max_length=50)
121
- color = models.CharField(max_length=50)
122
- clarity = models.CharField(max_length=50)
123
- depth = models.DecimalField(max_digits=5, decimal_places=2)
124
-
125
- class BrandProduct(models.Model):
126
- brand_name = models.CharField(max_length=50)
127
- model_name = models.CharField(max_length=50)
128
- type_number = models.CharField(max_length=50)
129
- purchase_store = models.CharField(max_length=50)
130
- purchase_date = models.DateField()
131
- purchase_price = models.DecimalField(max_digits=10, decimal_places=2)
132
- accessories = models.TextField()
133
- condition = models.CharField(max_length=50)
134
- ```
135
-
136
- `app/views.py`
137
- ```
138
- from django.shortcuts import render
139
- from .models import Diamond, BrandProduct
140
- from fastapi import FastAPI
141
-
142
- app = FastAPI()
143
-
144
- @app.get("/diamonds/")
145
- def get_diamonds():
146
- diamonds = Diamond.objects.all()
147
- return {"diamonds": [{"id": d.id, "carat": d.carat, "cut": d.cut, "color": d.color, "clarity": d.clarity, "depth": d.depth} for d in diamonds]}
148
-
149
- @app.get("/brand_products/")
150
- def get_brand_products():
151
- brand_products = BrandProduct.objects.all()
152
- return {"brand_products": [{"id": bp.id, "brand_name": bp.brand_name, "model_name": bp.model_name, "type_number": bp.type_number, "purchase_store": bp.purchase_store, "purchase_date": bp.purchase_date, "purchase_price": bp.purchase_price, "accessories": bp.accessories, "condition": bp.condition} for bp in brand_products]}
153
- ```
154
-
155
- **FastAPI Router**
156
-
157
- `router.py`
158
- ```
159
- from fastapi import FastAPI, APIRouter
160
- from app.views import app as django_app
161
-
162
- router = APIRouter()
163
-
164
- @router.get("/api/diamonds/")
165
- def get_diamonds():
166
- return django_app.get_diamonds()
167
-
168
- @router.get("/api/brand_products/")
169
- def get_brand_products():
170
- return django_app.get_brand_products()
171
- ```
172
-
173
- **Gradio Frontend**
174
-
175
- `gradio_app.py`
176
- ```
177
- import gradio as gr
178
-
179
- def get_diamond_form():
180
- with gr.Row():
181
- carat = gr.Number(value=1.0, label="Carat")
182
- cut = gr.Textbox(label="Cut")
183
- color = gr.Textbox(label="Color")
184
- clarity = gr.Textbox(label="Clarity")
185
- depth = gr.Number(value=1.0, label="Depth")
186
- return [carat, cut, color, clarity, depth]
187
-
188
- def get_brand_product_form():
189
- with gr.Row():
190
- brand_name = gr.Textbox(label="Brand Name")
191
- model_name = gr.Textbox(label="Model Name")
192
- type_number = gr.Textbox(label="Type Number")
193
- purchase_store = gr.Textbox(label="Purchase Store")
194
- purchase_date = gr.DatePicker(label="Purchase Date")
195
- purchase_price = gr.Number(value=1000.0, label="Purchase Price")
196
- accessories = gr.Textbox(label="Accessories")
197
- condition = gr.Textbox(label="Condition")
198
- return [brand_name, model_name, type_number, purchase_store, purchase_date, purchase_price, accessories, condition]
199
-
200
- gr_interface = gr.Interface(
201
- fn=None,
202
- inputs=[get_diamond_form(), get_brand_product_form()],
203
- outputs="text",
204
- title="Diamond and Brand Product Appraisal",
205
- description="Please fill in the required information for appraisal."
206
- )
207
- gr_interface.launch()
208
- ```
209
-
210
- **Google Apps Script Frontend**
211
-
212
- `Code.gs`
213
- ```
214
- function doGet() {
215
- var gradioApp = gradioApp();
216
- var html = HtmlService.createHtmlOutput(gradioApp);
217
- return html;
218
- }
219
-
220
- function gradioApp() {
221
- var html = '<html><body>';
222
- html += '<h1>Diamond and Brand Product Appraisal</h1>';
223
- html += '<form>';
224
- html += '<label>Carat:</label><input type="number" id="carat"><br>';
225
- html += '<label>Cut:</label><input type="text" id="cut"><br>';
226
- html += '<label>Color:</label><input type="text" id="color"><br>';
227
- html += '<label>Clarity:</label><input type="text" id="clarity"><br>';
228
- html += '<label>Depth:</label><input type="number" id="depth"><br>';
229
- html += '<label>Brand Name:</label><input type="text" id="brand_name"><br>';
230
- html += '<label>Model Name:</label><input type="text" id="model_name"><br>';
231
- html += '<label>Type Number:</label><input type="text" id="type_number"><br>';
232
- html += '<label>Purchase Store:</label><input type="text" id="purchase_store"><br>';
233
- html += '<label>Purchase Date:</label><input type="date" id="purchase_date"><br>';
234
- html += '<label>Purchase Price:</label><input type="number" id="purchase_price"><br>';
235
- html += '<label>Accessories:</label><input type="text" id="accessories"><br>';
236
- html += '<label>Condition:</label><input type="text" id="condition"><br>';
237
- html += '<input type="submit" value="Submit">';
238
- html += '</form>';
239
- html += '</body></html>';
240
- return html;
241
- }
242
-
243
- function doPost(e) {
244
- var data = e.parameter;
245
- google.script.run.withSuccessHandler(function(result) {
246
- var output = document.getElementById("output");
247
- output.innerHTML = result;
248
- }).processForm(data);
249
- }
250
-
251
- function processForm(data) {
252
- var diamond = {
253
- carat: data.carat,
254
- cut: data.cut,
255
- color: data.color,
256
- clarity: data.clarity,
257
- depth: data.depth
258
- };
259
- var brandProduct = {
260
- brand_name: data.brand_name,
261
- model_name: data.model_name,
262
- type_number: data.type_number,
263
- purchase_store: data.purchase_store,
264
- purchase_date: data.purchase_date,
265
- purchase_price: data.purchase_price,
266
- accessories: data.accessories,
267
- condition: data.condition
268
- };
269
- // Call backend script to process appraisal
270
- var result = UrlFetchApp.fetch("https://example.com/api/appraisal", {
271
- method: "POST",
272
- headers: {
273
- "Content-Type": "application/json"
274
- },
275
- payload: JSON.stringify({ diamond: diamond, brandProduct: brandProduct })
276
- });
277
- return result.getContentText();
278
- }
279
- ```
280
-
281
- **Google Apps Script Backend**
282
-
283
- `Code.gs`
284
- ```
285
- function doPost(e) {
286
- var data = e.postData.contents;
287
- var diamond = JSON.parse(data).diamond;
288
- var brandProduct = JSON.parse(data).brandProduct;
289
- // Process appraisal logic here
290
- var result = "Appraisal result: " + diamond.carat + " carat diamond and " + brandProduct.brand_name + " brand product";
291
- return ContentService.createTextOutput(result).setMimeType(ContentService.MimeType.TEXT);
292
- }
293
- ```
294
-
295
- **Sequence Diagram (PlantUML)**
296
-
297
- `sequence_diagram.puml`
298
- ```
299
- @startuml
300
- participant User as U
301
- participant GradioApp as GA
302
- participant GoogleAppsScript as GAS
303
- participant BackendScript as BS
304
-
305
- U -> GA: Fill in appraisal form
306
- GA -> GAS: Submit form data
307
- GAS -> BS: POST request with form data
308
- BS -> BS: Process appraisal logic
309
- BS -> GAS: Return appraisal result
310
- GAS -> GA: Display appraisal result
311
- GA -> U: Show appraisal result
312
- @enduml
313
- ```
314
-
315
- **Program Description (Markdown)**
316
-
317
- `program_description.md`
318
- ```
319
- # Diamond and Brand Product Appraisal System
320
-
321
- This system allows users to fill in a form with information about a diamond or brand product, and then submits the form data to a backend script for appraisal. The appraisal result is then displayed to the user.
322
-
323
- The system consists of the following components:
324
-
325
- * A Gradio frontend that provides a user-friendly interface for filling in the appraisal form
326
- * A Google Apps Script frontend that handles the form submission and communicates with the backend script
327
- * A backend script that processes the appraisal logic and returns the result
328
- * A Django app that provides the API for the backend script to interact with
329
-
330
- The system uses the following technologies:
331
-
332
- * Gradio for the frontend
333
- * Google Apps Script for the frontend and backend communication
334
- * Django for the backend API
335
- * FastAPI for the router
336
- * Python for the backend script
337
- ```
338
-
339
- This concludes a fully working implementation.
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105436/.gpteng/memory/logs/gen_entrypoint_chat.txt DELETED
@@ -1,181 +0,0 @@
1
-
2
- 2024-06-24T10:54:49.207524
3
- ================================ System Message ================================
4
-
5
- You will get information about a codebase that is currently on disk in the current folder.
6
- The user will ask you to write a script that runs the code in a specific way.
7
- You will answer with code blocks that include all the necessary terminal commands.
8
- Do not install globally. Do not use sudo.
9
- Do not explain the code, just give the commands.
10
- Do not use placeholders, use example values (like . for a folder argument) if necessary.
11
-
12
-
13
- ================================ Human Message =================================
14
-
15
-
16
- Make a unix script that
17
- a) installs dependencies
18
- b) runs all necessary parts of the codebase (in parallel if necessary)
19
-
20
- Information about the codebase:
21
-
22
- ```
23
- File: requirements.txt
24
- 1 django
25
- 2 fastapi
26
- 3 gradio
27
- 4 google-api-python-client
28
-
29
- File: app/models.py
30
- 1 from django.db import models
31
- 2
32
- 3 class Diamond(models.Model):
33
- 4 carat = models.DecimalField(max_digits=5, decimal_places=2)
34
- 5 cut = models.CharField(max_length=50)
35
- 6 color = models.CharField(max_length=50)
36
- 7 clarity = models.CharField(max_length=50)
37
- 8 depth = models.DecimalField(max_digits=5, decimal_places=2)
38
- 9
39
- 10 class BrandProduct(models.Model):
40
- 11 brand_name = models.CharField(max_length=50)
41
- 12 model_name = models.CharField(max_length=50)
42
- 13 type_number = models.CharField(max_length=50)
43
- 14 purchase_store = models.CharField(max_length=50)
44
- 15 purchase_date = models.DateField()
45
- 16 purchase_price = models.DecimalField(max_digits=10, decimal_places=2)
46
- 17 accessories = models.TextField()
47
- 18 condition = models.CharField(max_length=50)
48
-
49
- File: app/views.py
50
- 1 from django.shortcuts import render
51
- 2 from .models import Diamond, BrandProduct
52
- 3 from fastapi import FastAPI
53
- 4
54
- 5 app = FastAPI()
55
- 6
56
- 7 @app.get("/diamonds/")
57
- 8 def get_diamonds():
58
- 9 diamonds = Diamond.objects.all()
59
- 10 return {"diamonds": [{"id": d.id, "carat": d.carat, "cut": d.cut, "color": d.color, "clarity": d.clarity, "depth": d.depth} for d in diamonds]}
60
- 11
61
- 12 @app.get("/brand_products/")
62
- 13 def get_brand_products():
63
- 14 brand_products = BrandProduct.objects.all()
64
- 15 return {"brand_products": [{"id": bp.id, "brand_name": bp.brand_name, "model_name": bp.model_name, "type_number": bp.type_number, "purchase_store": bp.purchase_store, "purchase_date": bp.purchase_date, "purchase_price": bp.purchase_price, "accessories": bp.accessories, "condition": bp.condition} for bp in brand_products]}
65
-
66
- File: router.py
67
- 1 from fastapi import FastAPI, APIRouter
68
- 2 from app.views import app as django_app
69
- 3
70
- 4 router = APIRouter()
71
- 5
72
- 6 @router.get("/api/diamonds/")
73
- 7 def get_diamonds():
74
- 8 return django_app.get_diamonds()
75
- 9
76
- 10 @router.get("/api/brand_products/")
77
- 11 def get_brand_products():
78
- 12 return django_app.get_brand_products()
79
-
80
- File: gradio_app.py
81
- 1 import gradio as gr
82
- 2
83
- 3 def get_diamond_form():
84
- 4 with gr.Row():
85
- 5 carat = gr.Number(value=1.0, label="Carat")
86
- 6 cut = gr.Textbox(label="Cut")
87
- 7 color = gr.Textbox(label="Color")
88
- 8 clarity = gr.Textbox(label="Clarity")
89
- 9 depth = gr.Number(value=1.0, label="Depth")
90
- 10 return [carat, cut, color, clarity, depth]
91
- 11
92
- 12 def get_brand_product_form():
93
- 13 with gr.Row():
94
- 14 brand_name = gr.Textbox(label="Brand Name")
95
- 15 model_name = gr.Textbox(label="Model Name")
96
- 16 type_number = gr.Textbox(label="Type Number")
97
- 17 purchase_store = gr.Textbox(label="Purchase Store")
98
- 18 purchase_date = gr.DatePicker(label="Purchase Date")
99
- 19 purchase_price = gr.Number(value=1000.0, label="Purchase Price")
100
- 20 accessories = gr.Textbox(label="Accessories")
101
- 21 condition = gr.Textbox(label="Condition")
102
- 22 return [brand_name, model_name, type_number, purchase_store, purchase_date, purchase_price, accessories, condition]
103
- 23
104
- 24 gr_interface = gr.Interface(
105
- 25 fn=None,
106
- 26 inputs=[get_diamond_form(), get_brand_product_form()],
107
- 27 outputs="text",
108
- 28 title="Diamond and Brand Product Appraisal",
109
- 29 description="Please fill in the required information for appraisal."
110
- 30 )
111
- 31 gr_interface.launch()
112
-
113
- File: Code.gs
114
- 1 function doPost(e) {
115
- 2 var data = e.postData.contents;
116
- 3 var diamond = JSON.parse(data).diamond;
117
- 4 var brandProduct = JSON.parse(data).brandProduct;
118
- 5 // Process appraisal logic here
119
- 6 var result = "Appraisal result: " + diamond.carat + " carat diamond and " + brandProduct.brand_name + " brand product";
120
- 7 return ContentService.createTextOutput(result).setMimeType(ContentService.MimeType.TEXT);
121
- 8 }
122
-
123
- File: sequence_diagram.puml
124
- 1 @startuml
125
- 2 participant User as U
126
- 3 participant GradioApp as GA
127
- 4 participant GoogleAppsScript as GAS
128
- 5 participant BackendScript as BS
129
- 6
130
- 7 U -> GA: Fill in appraisal form
131
- 8 GA -> GAS: Submit form data
132
- 9 GAS -> BS: POST request with form data
133
- 10 BS -> BS: Process appraisal logic
134
- 11 BS -> GAS: Return appraisal result
135
- 12 GAS -> GA: Display appraisal result
136
- 13 GA -> U: Show appraisal result
137
- 14 @enduml
138
-
139
- File: program_description.md
140
- 1 # Diamond and Brand Product Appraisal System
141
- 2
142
- 3 This system allows users to fill in a form with information about a diamond or brand product, and then submits the form data to a backend script for appraisal. The appraisal result is then displayed to the user.
143
- 4
144
- 5 The system consists of the following components:
145
- 6
146
- 7 * A Gradio frontend that provides a user-friendly interface for filling in the appraisal form
147
- 8 * A Google Apps Script frontend that handles the form submission and communicates with the backend script
148
- 9 * A backend script that processes the appraisal logic and returns the result
149
- 10 * A Django app that provides the API for the backend script to interact with
150
- 11
151
- 12 The system uses the following technologies:
152
- 13
153
- 14 * Gradio for the frontend
154
- 15 * Google Apps Script for the frontend and backend communication
155
- 16 * Django for the backend API
156
- 17 * FastAPI for the router
157
- 18 * Python for the backend script
158
-
159
- ```
160
-
161
- ================================== Ai Message ==================================
162
-
163
- Here is a Unix script that installs dependencies and runs the necessary parts of the codebase:
164
-
165
- ```bash
166
- #!/bin/bash
167
-
168
- # Install dependencies
169
- pip install -r requirements.txt
170
-
171
- # Run Django migrations
172
- python manage.py migrate
173
-
174
- # Run FastAPI app
175
- uvicorn router:router --host 0.0.0.0 --port 8000 &
176
-
177
- # Run Gradio app
178
- python gradio_app.py &
179
- ```
180
-
181
- Note: This script assumes that you have a `manage.py` file in the current directory, which is a standard file in Django projects. It also assumes that you want to run the FastAPI app on host `0.0.0.0` and port `8000`. You can change these settings as needed.
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105436/Code.gs DELETED
@@ -1,8 +0,0 @@
1
- function doPost(e) {
2
- var data = e.postData.contents;
3
- var diamond = JSON.parse(data).diamond;
4
- var brandProduct = JSON.parse(data).brandProduct;
5
- // Process appraisal logic here
6
- var result = "Appraisal result: " + diamond.carat + " carat diamond and " + brandProduct.brand_name + " brand product";
7
- return ContentService.createTextOutput(result).setMimeType(ContentService.MimeType.TEXT);
8
- }
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105436/app/models.py DELETED
@@ -1,18 +0,0 @@
1
- from django.db import models
2
-
3
- class Diamond(models.Model):
4
- carat = models.DecimalField(max_digits=5, decimal_places=2)
5
- cut = models.CharField(max_length=50)
6
- color = models.CharField(max_length=50)
7
- clarity = models.CharField(max_length=50)
8
- depth = models.DecimalField(max_digits=5, decimal_places=2)
9
-
10
- class BrandProduct(models.Model):
11
- brand_name = models.CharField(max_length=50)
12
- model_name = models.CharField(max_length=50)
13
- type_number = models.CharField(max_length=50)
14
- purchase_store = models.CharField(max_length=50)
15
- purchase_date = models.DateField()
16
- purchase_price = models.DecimalField(max_digits=10, decimal_places=2)
17
- accessories = models.TextField()
18
- condition = models.CharField(max_length=50)
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105436/app/views.py DELETED
@@ -1,15 +0,0 @@
1
- from django.shortcuts import render
2
- from .models import Diamond, BrandProduct
3
- from fastapi import FastAPI
4
-
5
- app = FastAPI()
6
-
7
- @app.get("/diamonds/")
8
- def get_diamonds():
9
- diamonds = Diamond.objects.all()
10
- return {"diamonds": [{"id": d.id, "carat": d.carat, "cut": d.cut, "color": d.color, "clarity": d.clarity, "depth": d.depth} for d in diamonds]}
11
-
12
- @app.get("/brand_products/")
13
- def get_brand_products():
14
- brand_products = BrandProduct.objects.all()
15
- return {"brand_products": [{"id": bp.id, "brand_name": bp.brand_name, "model_name": bp.model_name, "type_number": bp.type_number, "purchase_store": bp.purchase_store, "purchase_date": bp.purchase_date, "purchase_price": bp.purchase_price, "accessories": bp.accessories, "condition": bp.condition} for bp in brand_products]}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105436/gradio_app.py DELETED
@@ -1,31 +0,0 @@
1
- import gradio as gr
2
-
3
- def get_diamond_form():
4
- with gr.Row():
5
- carat = gr.Number(value=1.0, label="Carat")
6
- cut = gr.Textbox(label="Cut")
7
- color = gr.Textbox(label="Color")
8
- clarity = gr.Textbox(label="Clarity")
9
- depth = gr.Number(value=1.0, label="Depth")
10
- return [carat, cut, color, clarity, depth]
11
-
12
- def get_brand_product_form():
13
- with gr.Row():
14
- brand_name = gr.Textbox(label="Brand Name")
15
- model_name = gr.Textbox(label="Model Name")
16
- type_number = gr.Textbox(label="Type Number")
17
- purchase_store = gr.Textbox(label="Purchase Store")
18
- purchase_date = gr.DatePicker(label="Purchase Date")
19
- purchase_price = gr.Number(value=1000.0, label="Purchase Price")
20
- accessories = gr.Textbox(label="Accessories")
21
- condition = gr.Textbox(label="Condition")
22
- return [brand_name, model_name, type_number, purchase_store, purchase_date, purchase_price, accessories, condition]
23
-
24
- gr_interface = gr.Interface(
25
- fn=None,
26
- inputs=[get_diamond_form(), get_brand_product_form()],
27
- outputs="text",
28
- title="Diamond and Brand Product Appraisal",
29
- description="Please fill in the required information for appraisal."
30
- )
31
- gr_interface.launch()
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105436/program_description.md DELETED
@@ -1,18 +0,0 @@
1
- # Diamond and Brand Product Appraisal System
2
-
3
- This system allows users to fill in a form with information about a diamond or brand product, and then submits the form data to a backend script for appraisal. The appraisal result is then displayed to the user.
4
-
5
- The system consists of the following components:
6
-
7
- * A Gradio frontend that provides a user-friendly interface for filling in the appraisal form
8
- * A Google Apps Script frontend that handles the form submission and communicates with the backend script
9
- * A backend script that processes the appraisal logic and returns the result
10
- * A Django app that provides the API for the backend script to interact with
11
-
12
- The system uses the following technologies:
13
-
14
- * Gradio for the frontend
15
- * Google Apps Script for the frontend and backend communication
16
- * Django for the backend API
17
- * FastAPI for the router
18
- * Python for the backend script
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105436/prompt DELETED
@@ -1,39 +0,0 @@
1
-
2
- 下記の質問に対応するコードをdjangoでアプリを作成 プロジェクトはいりません
3
- fastapiでrouter部分を作成 組み込みはメイン部分でします
4
- フロントエンドをgradioで作成
5
- #google apps script frontend
6
- googleappsscript doGet でのgradioの表示処理を作成 google.script.runで関数は呼び出し
7
- #google apps script backend
8
- frontendからの呼び出し用のバックエンドスクリプト
9
- 仕様書の作成
10
- PlantUMLでシーケンス図の作成
11
- Markdownでのプログラム殺名
12
-
13
- 下記の質問 作成対応内容
14
-
15
- 左様です。 本日は11:00~20:00まで営業時間内にお連絡可能です。検討中の商品について、査定人にお問い合わせください。以下の情報をお送りくださいませ。
16
-
17
- * ダイヤモンドの場合は、carat、cut、color、clarity、depthなどを
18
- * ブランド商品の場合は、ブランド名、モデル名、型番や品番、購入店、購入時期、購入金額、付属品、コンディションなどを
19
-
20
- お送りくださいませ。迅速に査定結果をお返しします。
21
- 下記の質問に対応するコードをdjangoでアプリを作成 プロジェクトはいりません
22
- fastapiでrouter部分を作成 組み込みはメイン部分でします
23
- フロントエンドをgradioで作成
24
- #google apps script frontend
25
- googleappsscript doGet でのgradioの表示処理を作成 google.script.runで関数は呼び出し
26
- #google apps script backend
27
- frontendからの呼び出し用のバックエンドスクリプト
28
- 仕様書の作成
29
- PlantUMLでシーケンス図の作成
30
- Markdownでのプログラム殺名
31
-
32
- 下記の質問 作成対応内容
33
-
34
- 左様です。 本日は11:00~20:00まで営業時間内にお連絡可能です。検討中の商品について、査定人にお問い合わせください。以下の情報をお送りくださいませ。
35
-
36
- * ダイヤモンドの場合は、carat、cut、color、clarity、depthなどを
37
- * ブランド商品の場合は、ブランド名、モデル名、型番や品番、購入店、購入時期、購入金額、付属品、コンディションなどを
38
-
39
- お送りくださいませ。迅速に査定結果をお返しします。
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105436/requirements.txt DELETED
@@ -1,4 +0,0 @@
1
- django
2
- fastapi
3
- gradio
4
- google-api-python-client
 
 
 
 
 
controllers/gpt_enginner20240624105436/router.py DELETED
@@ -1,12 +0,0 @@
1
- from fastapi import FastAPI, APIRouter
2
- from app.views import app as django_app
3
-
4
- router = APIRouter()
5
-
6
- @router.get("/api/diamonds/")
7
- def get_diamonds():
8
- return django_app.get_diamonds()
9
-
10
- @router.get("/api/brand_products/")
11
- def get_brand_products():
12
- return django_app.get_brand_products()
 
 
 
 
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105436/run.sh DELETED
@@ -1,13 +0,0 @@
1
- #!/bin/bash
2
-
3
- # Install dependencies
4
- pip install -r requirements.txt
5
-
6
- # Run Django migrations
7
- python manage.py migrate
8
-
9
- # Run FastAPI app
10
- uvicorn router:router --host 0.0.0.0 --port 8000 &
11
-
12
- # Run Gradio app
13
- python gradio_app.py &
 
 
 
 
 
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105436/sequence_diagram.puml DELETED
@@ -1,14 +0,0 @@
1
- @startuml
2
- participant User as U
3
- participant GradioApp as GA
4
- participant GoogleAppsScript as GAS
5
- participant BackendScript as BS
6
-
7
- U -> GA: Fill in appraisal form
8
- GA -> GAS: Submit form data
9
- GAS -> BS: POST request with form data
10
- BS -> BS: Process appraisal logic
11
- BS -> GAS: Return appraisal result
12
- GAS -> GA: Display appraisal result
13
- GA -> U: Show appraisal result
14
- @enduml
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
controllers/gpt_enginner20240624105951 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 48a6d36108d7dc0110e0e34dee08492599a39260
 
 
controllers/gpt_enginner20240624110325 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 2cfeafc44c92e8b12b4133471071976b3a031c15
 
 
controllers/gpt_enginner20240624110523 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 13bd04b3e896a8fe98b03da1a4e0a71c13e24eb4
 
 
controllers/gpt_enginner20240624110747 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 33336bfb3472e994c81b9a63cf4ed9016df4e81c
 
 
controllers/gpt_enginner20240624111114 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 0ba8ae8a63d600006064f7c210d710ca3a9a919a
 
 
controllers/gpt_enginner20240624111439 DELETED
@@ -1 +0,0 @@
1
- Subproject commit bd8a226f62deebcf83b93b65df34360f7320d10f
 
 
controllers/gpt_enginner20240624111658 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 3ccd59c822b8486df22f734974ea5e338727f950
 
 
controllers/gpt_enginner20240624112106 DELETED
@@ -1 +0,0 @@
1
- Subproject commit b9237245c514dd3011cdb544f80341039ae7157d
 
 
controllers/gpt_enginner20240624112338 DELETED
@@ -1 +0,0 @@
1
- Subproject commit b32445567d8bb13174a470e81883dda311f00cdb
 
 
controllers/gpt_enginner20240624112600 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 8f840d9bfab2b92bd122c605745fb49d1cde5467
 
 
controllers/gpt_enginner20240624112801 DELETED
@@ -1 +0,0 @@
1
- Subproject commit f20c9d9c55fa28fda52de33edfd69591793ac6da
 
 
controllers/gpt_enginner20240624112951 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 07451d9156bf85c53e5f416048afc12ae5c60367
 
 
controllers/gpt_enginner20240624113357 DELETED
@@ -1 +0,0 @@
1
- Subproject commit 8cd116439272985210f54fdef11f1594d4b39468