commune-ai commited on
Commit
23f3a1c
1 Parent(s): aa48fa5

Create app.py

Browse files
Files changed (1) hide show
  1. app.py +220 -0
app.py ADDED
@@ -0,0 +1,220 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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 = "artificialguybr"
21
+ name = "nebul.redmond"
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/RekGnfLBwXkQjkgIk7mqxsn41IRtzyV25iZuxQF1k7FYvFPSA/out-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, input9,input10, input11):
140
+ global cancel_url
141
+ cancel_url = ''
142
+ url = 'https://replicate.com/api/predictions'
143
+
144
+ body = {
145
+ "version": version,
146
+ "input": {
147
+ "prompt": input1,
148
+ "negative_prompt": input2,
149
+ "width": input3,
150
+ "height": input4,
151
+ "num_outputs": input5,
152
+ "scheduler": input6,
153
+ "num_inference_steps": input7,
154
+ "guidance_scale": input8,
155
+ "seed": input9,
156
+ "apply_watermark": input10
157
+ }
158
+ }
159
+
160
+ response = requests.post(url, headers=headers, json=body)
161
+ print(response.status_code)
162
+ if response.status_code == 201:
163
+ response_data = response.json()
164
+ get_url = response_data.get('urls','').get('get','')
165
+ identifier = 'https://replicate.com/api/predictions/'+get_url.split("/")[-1]
166
+
167
+ print(identifier,'')
168
+ print(identifier)
169
+ time.sleep(3)
170
+ output =verify_image(identifier)
171
+ print(output,'333')
172
+ if output:
173
+ if len(output) == 1:
174
+ return gr.Image(value=output[0]), gr.Image(),gr.Image(),gr.Image()
175
+ elif len(output) == 2:
176
+ return gr.Image(value=output[0]), gr.Image(value=output[1],visible= True),gr.Image(),gr.Image()
177
+ elif len(output) == 3:
178
+ return gr.Image(value=output[0]), gr.Image(value=output[1],visible= True),gr.Image(value=output[2],visible= True),gr.Image()
179
+ elif len(output) == 3:
180
+ 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)
181
+
182
+ return gr.Image(),gr.Image(visible=False),gr.Image(visible=False),gr.Image(visible=False)
183
+
184
+ def cancel_process(input1,input2,input3,input4,input5,input6,input7, input8, input9,input10, input11):
185
+ global cancel_url
186
+ cancel_url ="123"
187
+ return gr.Image(value='https://replicate.delivery/pbxt/RekGnfLBwXkQjkgIk7mqxsn41IRtzyV25iZuxQF1k7FYvFPSA/out-0.png'), gr.Image(visible=False),gr.Image(visible=False),gr.Image(visible=False)
188
+
189
+ def verify_image(get_url):
190
+ res = requests.get(get_url)
191
+ if res.status_code == 200:
192
+ res_data = res.json()
193
+ if res_data.get('error',''):
194
+ return
195
+ else:
196
+ if cancel_url:
197
+ return
198
+ else:
199
+ output = res_data.get('output', [])
200
+ print(output,'111')
201
+ if output:
202
+ print(output,'222')
203
+ return output
204
+
205
+ else:
206
+ time.sleep(1)
207
+ val = verify_image(get_url)
208
+ return val
209
+ else:
210
+ return []
211
+
212
+ run_btn.click(run_process, inputs=inputs, outputs=outputs, api_name="run")
213
+ cancel_btn.click(cancel_process, inputs=inputs, outputs=outputs, api_name="cancel")
214
+
215
+ demo.launch()
216
+
217
+
218
+
219
+
220
+