commune-ai commited on
Commit
105f643
1 Parent(s): 1dcd50c

Create app.py

Browse files
Files changed (1) hide show
  1. app.py +279 -0
app.py ADDED
@@ -0,0 +1,279 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import gradio as gr
2
+ from requests.exceptions import ConnectTimeout
3
+ import time
4
+ import requests
5
+ import base64
6
+
7
+ global headers
8
+ global cancel_url
9
+ global path
10
+ path = ''
11
+ cancel_url =''
12
+ headers = {
13
+ 'Content-Type': 'application/json',
14
+ 'Authorization': 'Token r8_ZGZlzThfRkPZVDMygVclY1XZ9AuxmIQ2qwwPP',
15
+ "Access-Control-Allow-Headers": "Content-Type",
16
+ "Access-Control-Allow-Origin": '**',
17
+ "Access-Control-Allow-Methods": "OPTIONS,POST,GET,PATCH"}
18
+
19
+ with gr.Blocks() as demo:
20
+ owner = "adirik"
21
+ name = "kosmos-g"
22
+ max_retries = 3
23
+ retry_delay = 2
24
+ for retry in range(max_retries):
25
+ try:
26
+ url = f'https://api.replicate.com/v1/models/{owner}/{name}'
27
+ response = requests.get(url, headers=headers, timeout=10)
28
+ # Process the response
29
+ break # Break out of the loop if the request is successful
30
+ except ConnectTimeout:
31
+ if retry < max_retries - 1:
32
+ print(f"Connection timed out. Retrying in {retry_delay} seconds...")
33
+ time.sleep(retry_delay)
34
+ else:
35
+ print("Max retries exceeded. Unable to establish connection.")
36
+
37
+ data = response.json()
38
+ description =data.get("description", '')
39
+ title = data.get("default_example",'').get("model",'')
40
+ version = data.get("default_example",'').get("version",'')
41
+
42
+ gr.Markdown(
43
+ f"""
44
+ # {title}
45
+ {description}
46
+ """)
47
+
48
+ with gr.Row():
49
+ with gr.Column():
50
+ inputs =[]
51
+ schema = data.get("latest_version", {}).get("openapi_schema", {}).get("components", {}).get("schemas", {})
52
+ ordered_properties = sorted(schema.get("Input", {}).get("properties", {}).items(), key=lambda x: x[1].get("x-order", 0))
53
+ required = schema.get("Input", '').get('required', [])
54
+ print(required,"required")
55
+ for property_name, property_info in ordered_properties :
56
+ if required:
57
+ for item in required:
58
+ if item == property_name:
59
+ label = "*"+ property_info.get('title', '')
60
+ description = property_info.get('description','')
61
+ break
62
+ else:
63
+ label = property_info.get('title', '')
64
+ description = property_info.get('description','')
65
+ else:
66
+ label = property_info.get('title', '')
67
+ description = property_info.get('description','')
68
+
69
+ if "x-order" in property_info:
70
+ order = int(property_info.get('x-order',''))
71
+ if property_info.get("type", {}) == "integer":
72
+ value= data.get('default_example', '').get('input','').get(property_name,0)
73
+ if "minimum" and "maximum" in property_info:
74
+ if value == 0:
75
+ inputs.insert(order, gr.Slider(label=label, info= description, value=property_info.get('default', value), minimum=property_info.get('minimum', ''), maximum=property_info.get('maximum', ''), step=1))
76
+ else:
77
+ inputs.insert(order, gr.Slider(label=label, info= description, value=value, minimum=property_info.get('minimum', ''), maximum=property_info.get('maximum', ''), step=1))
78
+ else:
79
+ if value == 0:
80
+ inputs.insert(order, gr.Number(label=label, info= description, value=property_info.get('default', value)))
81
+ else:
82
+ inputs.insert(order, gr.Number(label=label, info= description, value=value))
83
+
84
+ elif property_info.get("type", {}) == "string":
85
+ value= data.get('default_example', '').get('input','').get(property_name,'')
86
+ if property_info.get('format','') == 'uri':
87
+
88
+ if value :
89
+ inputs.insert(order, gr.Image(label=label, value=value, type="filepath"))
90
+ else :
91
+ inputs.insert(order, gr.Image(label=label, type="filepath"))
92
+
93
+ else:
94
+ if value == '':
95
+ inputs.insert(order, gr.Textbox(label=label,info= description, value=property_info.get('default', value)))
96
+ else:
97
+ inputs.insert(order, gr.Textbox(label=label,info= description, value=value))
98
+
99
+ elif property_info.get("type", {}) == "number":
100
+ value= data.get('default_example', '').get('input','').get(property_name, 0)
101
+ if "minimum" and "maximum" in property_info:
102
+ if value == 0:
103
+ inputs.insert(order, gr.Slider(label=label,info= description, value=property_info.get('default', value), minimum=property_info.get('minimum', ''), maximum=property_info.get('maximum', '')))
104
+ else:
105
+ inputs.insert(order, gr.Slider(label=label,info= description, value=value, minimum=property_info.get('minimum', ''), maximum=property_info.get('maximum', '')))
106
+ else:
107
+ if value == 0:
108
+ inputs.insert(order, gr.Number(label=label,info= description, value=property_info.get('default', value)))
109
+ else:
110
+ inputs.insert(order, gr.Number(label=label,info= description, value=value))
111
+ elif property_info.get("type", {}) == "boolean":
112
+ value= data.get('default_example', '').get('input','').get(property_name,'')
113
+ if value == '':
114
+ inputs.insert(order, gr.Checkbox(label=label,info= description, value=property_info.get('default', value)))
115
+ else:
116
+ inputs.insert(order, gr.Checkbox(label=label,info= description, value=value))
117
+ else:
118
+ value= data.get('default_example', '').get('input','').get(property_name,'')
119
+ options=schema.get(property_name,'').get('enum',[])
120
+ if value == '':
121
+ inputs.insert(order, gr.Dropdown(label=property_name,info= description,choices=options, value=property_info.get("default", value)))
122
+ else:
123
+ inputs.insert(order, gr.Dropdown(label=property_name,info= description,choices=options, value=value))
124
+
125
+ with gr.Row():
126
+ cancel_btn = gr.Button("Cancel")
127
+ run_btn = gr.Button("Run")
128
+
129
+ with gr.Column():
130
+
131
+ outputs = []
132
+ outputs.append(gr.Image(value='https://replicate.delivery/pbxt/aYXKkkuCWM6WN96DfeKBlVFTle875XmLLmMkJFp7rkNryqfHB/0.png'))
133
+ outputs.append(gr.Image(visible=False))
134
+ outputs.append(gr.Image(visible=False))
135
+ outputs.append(gr.Image(visible=False))
136
+
137
+
138
+
139
+ def run_process(input1,input2,input3,input4,input5,input6,input7,input8):
140
+ global cancel_url
141
+ cancel_url=''
142
+ url = 'https://replicate.com/api/predictions'
143
+ if input1:
144
+ with open(input1, "rb") as file:
145
+ data = file.read()
146
+
147
+ base64_data = base64.b64encode(data).decode("utf-8")
148
+ mimetype = "image/jpg"
149
+ data_uri_image = f"data:{mimetype};base64,{base64_data}"
150
+ else:
151
+ data_uri_image=None
152
+
153
+ if input2:
154
+ with open(input2, "rb") as file:
155
+ data = file.read()
156
+
157
+ base64_data = base64.b64encode(data).decode("utf-8")
158
+ mimetype = "image/jpg"
159
+ data_uri_mask = f"data:{mimetype};base64,{base64_data}"
160
+ else:
161
+ data_uri_mask=None
162
+
163
+ if input1:
164
+ if input2:
165
+ body = {
166
+ "version": version,
167
+ "input": {
168
+ "image1": data_uri_image,
169
+ "image2": data_uri_mask,
170
+ "prompt": input3,
171
+ "negative_prompt": input4,
172
+ "text_guidance_scale": input5,
173
+ "num_inference_steps": input6,
174
+ "num_images": input7,
175
+ "seed": input8
176
+ }
177
+ }
178
+ else:
179
+ body = {
180
+ "version": version,
181
+ "input": {
182
+ "image1": data_uri_image,
183
+ "prompt": input3,
184
+ "negative_prompt": input4,
185
+ "text_guidance_scale": input5,
186
+ "num_inference_steps": input6,
187
+ "num_images": input7,
188
+ "seed": input8
189
+ }
190
+
191
+ }
192
+
193
+ else:
194
+ if input2:
195
+ body = {
196
+ "version": version,
197
+ "input": {
198
+ "image2": data_uri_mask,
199
+ "prompt": input3,
200
+ "negative_prompt": input4,
201
+ "text_guidance_scale": input5,
202
+ "num_inference_steps": input6,
203
+ "num_images": input7,
204
+ "seed": input8
205
+ }
206
+ }
207
+ else:
208
+ body = {
209
+ "version": version,
210
+ "input": {
211
+ "prompt": input3,
212
+ "negative_prompt": input4,
213
+ "text_guidance_scale": input5,
214
+ "num_inference_steps": input6,
215
+ "num_images": input7,
216
+ "seed": input8
217
+ }
218
+ }
219
+
220
+
221
+
222
+ response = requests.post(url, json=body)
223
+ print(response.status_code)
224
+ if response.status_code == 201:
225
+ response_data = response.json()
226
+ get_url = response_data.get('urls','').get('get','')
227
+ identifier = 'https://replicate.com/api/predictions/'+get_url.split("/")[-1]
228
+
229
+ print(identifier,'')
230
+ time.sleep(3)
231
+ output =verify_image(identifier)
232
+ print(output,'333')
233
+ if output:
234
+ if len(output) == 1:
235
+ return gr.Image(value=output[0]), gr.Image(),gr.Image(),gr.Image()
236
+ elif len(output) == 2:
237
+ return gr.Image(value=output[0]), gr.Image(value=output[1],visible= True),gr.Image(),gr.Image()
238
+ elif len(output) == 3:
239
+ return gr.Image(value=output[0]), gr.Image(value=output[1],visible= True),gr.Image(value=output[2],visible= True),gr.Image()
240
+ elif len(output) == 3:
241
+ return gr.Image(value=output[0]), gr.Image(value=output[1],visible= True),gr.Image(value=output[2],visible= True),gr.Image(value=output[2],visible= True)
242
+
243
+ return gr.Image(),gr.Image(visible=False),gr.Image(visible=False),gr.Image(visible=False)
244
+
245
+ def cancel_process(input1,input2,input3,input4,input5,input6,input7,input8):
246
+ global cancel_url
247
+ cancel_url = '123'
248
+ return gr.Image(value='https://replicate.delivery/pbxt/aYXKkkuCWM6WN96DfeKBlVFTle875XmLLmMkJFp7rkNryqfHB/0.png'), gr.Image(visible=False),gr.Image(visible=False),gr.Image(visible=False)
249
+
250
+ def verify_image(get_url):
251
+ res = requests.get(get_url)
252
+ if res.status_code == 200:
253
+ res_data = res.json()
254
+ if res_data.get('error',''):
255
+ return
256
+ else:
257
+ if cancel_url:
258
+ return
259
+ else:
260
+ output = res_data.get('output', [])
261
+ print(output,'111')
262
+ if output:
263
+ print(output,'222')
264
+ return output
265
+
266
+ else:
267
+ time.sleep(1)
268
+ val = verify_image(get_url)
269
+ return val
270
+ else:
271
+ return []
272
+
273
+ run_btn.click(run_process, inputs=inputs, outputs=outputs, api_name="run")
274
+ cancel_btn.click(cancel_process, inputs=inputs, outputs=outputs, api_name="cancel")
275
+
276
+ demo.launch()
277
+
278
+
279
+