From 4869ad9d440687e3bde4bb09e782f0b9fbc4eb11 Mon Sep 17 00:00:00 2001 From: HuangHai <10402852@qq.com> Date: Wed, 3 Sep 2025 16:43:07 +0800 Subject: [PATCH] 'commit' --- .../Liblib/{LiblibUtil.py => LibLibUtil.py} | 38 +++++++++++++-- ...ntrolNetGenerator.py => PuLIDGenerator.py} | 46 +++++++++++++++--- dsLightRag/Liblib/T1.py | 4 +- dsLightRag/Liblib/T2.py | 30 +++--------- dsLightRag/Liblib/T3.py | 14 +++--- .../__pycache__/LiblibUtil.cpython-310.pyc | Bin 4823 -> 0 bytes 6 files changed, 89 insertions(+), 43 deletions(-) rename dsLightRag/Liblib/{LiblibUtil.py => LibLibUtil.py} (76%) rename dsLightRag/Liblib/{ControlNetGenerator.py => PuLIDGenerator.py} (54%) delete mode 100644 dsLightRag/Liblib/__pycache__/LiblibUtil.cpython-310.pyc diff --git a/dsLightRag/Liblib/LiblibUtil.py b/dsLightRag/Liblib/LibLibUtil.py similarity index 76% rename from dsLightRag/Liblib/LiblibUtil.py rename to dsLightRag/Liblib/LibLibUtil.py index 34c5aea1..9f8fe6b8 100644 --- a/dsLightRag/Liblib/LiblibUtil.py +++ b/dsLightRag/Liblib/LibLibUtil.py @@ -1,4 +1,5 @@ import hmac +import json import os import tempfile from hashlib import sha1 @@ -10,7 +11,7 @@ import Config.Config from Util.ObsUtil import ObsUploader -class LiblibUtil: +class LibLibUtil: def __init__(self): self.base_url = Config.Config.LIBLIB_URL self.access_key = Config.Config.LIBLIB_ACCESSKEY @@ -50,7 +51,6 @@ class LiblibUtil: print(f"处理异常: {str(e)}") return None - # ===== 从T1_VersionGet.py迁移的方法 ===== def get_model_version_info(self, version_uuid): """获取模型版本信息""" uri = "/api/model/version/get" @@ -75,7 +75,6 @@ class LiblibUtil: } return self.post_request(uri, payload) - # ===== 从T2.py迁移的方法 ===== def get_generation_status(self, generate_uuid): """查询生图任务状态和结果""" uri = "/api/generate/webui/status" @@ -115,7 +114,6 @@ class LiblibUtil: print(f"生图任务超时({max_wait_time}秒)") return None - @staticmethod def download_and_upload_to_obs(image_url, generate_uuid): """下载图片并上传到OBS""" try: @@ -155,3 +153,35 @@ class LiblibUtil: except Exception as e: print(f"处理图片时发生错误: {str(e)}") return None + + def process_generation_task(self, generate_uuid, interval=2): + """ + 完整处理生成任务: 轮询状态 → 下载图片 → 上传OBS → 清理临时文件 + :param generate_uuid: 生成任务UUID + :param interval: 轮询间隔(秒) + :return: OBS路径或None + """ + try: + print(f"开始监控生成任务 {generate_uuid},每{interval}秒检查一次...") + + # 轮询等待生成完成 + status_data = self.wait_for_generation_completion(generate_uuid, interval) + print(f"生图状态: {json.dumps(status_data, ensure_ascii=False, indent=2)}") + + # 检查生成状态是否为5(完成) + if status_data and status_data.get('generateStatus') == 5: + # 提取图片URL + if status_data.get('images') and len(status_data['images']) > 0: + image_url = status_data['images'][0]['imageUrl'] + # 下载并上传到OBS + obs_path = self.download_and_upload_to_obs(image_url, generate_uuid) + return obs_path + else: + print("❌ 未找到图片数据") + return None + else: + print(f"❌ 生图未完成或失败,状态码: {status_data.get('generateStatus')}") + return None + except Exception as e: + print(f"处理生成任务时发生异常: {str(e)}") + return None diff --git a/dsLightRag/Liblib/ControlNetGenerator.py b/dsLightRag/Liblib/PuLIDGenerator.py similarity index 54% rename from dsLightRag/Liblib/ControlNetGenerator.py rename to dsLightRag/Liblib/PuLIDGenerator.py index fa4d9315..a49c6aa3 100644 --- a/dsLightRag/Liblib/ControlNetGenerator.py +++ b/dsLightRag/Liblib/PuLIDGenerator.py @@ -1,9 +1,9 @@ import json -from LiblibUtil import LiblibUtil +from LibLibUtil import LibLibUtil -class ControlNetImageGenerator: +class PuLIDGenerator: def __init__(self): - self.liblib_util = LiblibUtil() + self.liblib_util = LibLibUtil() # PuLID人像换脸参数示例 self.template_uuid = "6f7c4652458d4802969f8d089cf5b91f" self.default_params = { @@ -42,7 +42,7 @@ class ControlNetImageGenerator: }] def generate_image(self, prompt, reference_image_url, control_weight=1.0): - """根据提示词和参考图片生成图像""" + """根据提示词和参考图片生成图像,并自动处理后续流程""" # 构建生成参数 generate_params = { "templateUuid": self.template_uuid, @@ -63,10 +63,42 @@ class ControlNetImageGenerator: print(f"API响应: {json.dumps(response, ensure_ascii=False, indent=2)}") if response and "generateUuid" in response: + generate_uuid = response["generateUuid"] print("✅ 图像生成任务已成功提交!") - print(f"生成UUID: {response['generateUuid']}") - print("提示: 可使用T2.py中的get_generation_status方法查询生成进度") - return response + print(f"生成UUID: {generate_uuid}") + print("开始轮询生成状态...") + + # 每2秒探测一次生成状态,直到完成 + status_data = self.liblib_util.wait_for_generation_completion( + generate_uuid, interval=2 + ) + + # 检查生成状态 + if status_data and status_data.get("generateStatus") == 5: + print("🎉 图像生成完成!开始处理文件...") + + # 提取图片URL + if status_data.get("images") and len(status_data["images"]) > 0: + image_url = status_data["images"][0]["imageUrl"] + + # 下载并上传到OBS + obs_url = self.liblib_util.download_and_upload_to_obs( + image_url, generate_uuid + ) + + if obs_url: + print(f"✅ 文件处理完成,OBS地址: {obs_url}") + return obs_url + else: + print("❌ 文件上传OBS失败") + return None + else: + print("❌ 未找到生成的图片数据") + return None + else: + error_msg = status_data.get('message', '未知错误') if status_data else '生成状态查询失败' + print(f"❌ 图像生成失败: {error_msg}") + return None else: error_msg = response.get('message', '未知错误') if response else 'API无响应' print(f"❌ 图像生成失败: {error_msg}") diff --git a/dsLightRag/Liblib/T1.py b/dsLightRag/Liblib/T1.py index 8b34d5b8..f8783fdd 100644 --- a/dsLightRag/Liblib/T1.py +++ b/dsLightRag/Liblib/T1.py @@ -1,8 +1,8 @@ -from .LiblibUtil import LiblibUtil +from .LibLibUtil import LibLibUtil if __name__ == '__main__': - liblib = LiblibUtil() + liblib = LibLibUtil() # 测试获取模型版本信息 print("===== 测试获取模型版本信息 =====") diff --git a/dsLightRag/Liblib/T2.py b/dsLightRag/Liblib/T2.py index 9803ed41..c956cc94 100644 --- a/dsLightRag/Liblib/T2.py +++ b/dsLightRag/Liblib/T2.py @@ -1,30 +1,16 @@ -import json - -from LiblibUtil import LiblibUtil +from LibLibUtil import LibLibUtil if __name__ == '__main__': - liblib = LiblibUtil() - print("===== 测试查询生图结果并上传OBS =====") + liblib = LibLibUtil() + print("===== 测试生成任务处理流程 =====") test_generate_uuid = "df9bd6e03a204542b1daaba2f17c42e6" if test_generate_uuid: - # 等待任务完成 - status_data = liblib.wait_for_generation_completion(test_generate_uuid) - print(f"生图状态: {json.dumps(status_data, ensure_ascii=False, indent=2)}") - - # 检查生成状态是否为5(完成) - if status_data and status_data.get('generateStatus') == 5: - # 提取图片URL - if status_data.get('images') and len(status_data['images']) > 0: - image_url = status_data['images'][0]['imageUrl'] - # 下载并上传到OBS - # 使用实例调用而非类调用 - obs_path = liblib.download_and_upload_to_obs(image_url, test_generate_uuid) - if obs_path: - print(f"\n最终OBS路径: {obs_path}") - else: - print("❌ 未找到图片数据") + # 调用封装好的完整处理方法 + obs_url = liblib.process_generation_task(test_generate_uuid, interval=2) + if obs_url: + print(f"\n✅ 处理完成,OBS地址: {obs_url}") else: - print(f"❌ 生图未完成或失败,状态码: {status_data.get('generateStatus')}") + print("\n❌ 任务处理失败") else: print("请先设置有效的生图任务UUID") \ No newline at end of file diff --git a/dsLightRag/Liblib/T3.py b/dsLightRag/Liblib/T3.py index f7ba6bda..8fe1a9ce 100644 --- a/dsLightRag/Liblib/T3.py +++ b/dsLightRag/Liblib/T3.py @@ -1,17 +1,15 @@ -import json -from LiblibUtil import LiblibUtil -from ControlNetGenerator import ControlNetImageGenerator +from PuLIDGenerator import PuLIDGenerator if __name__ == "__main__": # 创建生成器实例 - generator = ControlNetImageGenerator() - + generator = PuLIDGenerator() # 可选:修改默认参数 generator.set_default_params(steps=25, width=800, height=1000) - # 生成图像 - generator.generate_image( + obs_url = generator.generate_image( prompt="filmfotos, Asian portrait,A young woman wearing a green baseball cap,covering one eye with her hand", reference_image_url="https://dsideal.obs.cn-north-1.myhuaweicloud.com/HuangHai/Backup/HuangWanQiao.jpg", control_weight=0.8 - ) \ No newline at end of file + ) + if obs_url: + print(f"最终OBS地址: {obs_url}") diff --git a/dsLightRag/Liblib/__pycache__/LiblibUtil.cpython-310.pyc b/dsLightRag/Liblib/__pycache__/LiblibUtil.cpython-310.pyc deleted file mode 100644 index 116420cf50ca3aeec6270072ebfbfa443bf9a8b6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4823 zcma)A{c{{;9p7hnZ*On!CD$|*s8v%HuZgul^b?MK4oG5ov{G?rkoqM%bR7FkKuMHa0|y2STnUFLmE zkMUm772d~n^@oBbS@IFVl4nIdVX;vm7h3^OVI;>w*_$%&%hPP_XI1t-tlEOkEI}77 zW{F1x$m84~FJ>v2$E>)eqF1bhrJ;{oNh^h3wKiHAtM3TY6Sih$tqn(nS*9nge#jpP zwLQ*w(HYLJV2Kr({3s0Y(tDq@&z^FY z;W^jY-G3)D?#N|B$@AS%a>{-vlj=e_2plVnQM)aa3l*mv%2OpXA4+9=+9e%?ie1iE zEZe2m4He6ov^_sm$b1iO3pc=mo;hI~;}33&=t9MX45tcGo1V+XU5cwv3S1{lkWkMz zOVzN?b0*8CAGo$ru9Wk37|&PAzFqd+JBeJTZEnn{Nzr1WWFE8)+S!1qM{5IOie=dr zaR8>O4XiQKDrugAr}rV#(s8(*QqW3mPhDsVb=G1Bq=wXx8*t+So5RW+EQhg(9#%pt z)n&ADJvJwt*BT0io5LD$UnWOz$KDQ`15&8+;kMX`lJo%HfyyK07)Vxl;T1`;lG;;a#=lqdR$Y zK4Z`9s3q?n?OBl~V?FEcsAX^LjF5SE)KbU-WZ!$oW~z2AYgVg8CvW;rr952lD&?F6 z|3e?fr)(4M=D7)+C6u}Ek^6?SW%_177Q{JL&i#7%(xvT#VH^(SnUnTNkiky(#MfSF zFDz^yf$MUyS=V%spC&4<0eAHS z&;16`N|Ux9#;Ps_kY*ps+f_Qh7iRZGJa+e%+$@nNR_D1Sj{=u6Vi>QQGsTK&xnIM~ z{VFwsw2lxdx_8kCXY#6GZ0qUX$e_0mnY}(HQgmpe`wm~i!#qoiVwT;*RD^|!Hp5bE zKvY;iz8R(-&UAb6i`wmLLS`+eo3a~aHc}XmnkO-^kj)Sk4E~P-fcQa#w8Vy7m))(% zUX1b-@8xcf?8WB_Vjw;*!&g;gu0(JLm@S{a(mwM>=bcvjt=E=bJ>HrBSbC}}$Ds7cP3PW+ZC&HMP%PjcnMv?Y~@KTe01_aB=z4Z=fNl zXYuOQ_KDWgiOZeCFSlPmxpejCoww#|n{TDCC{yUE-W!v$+=svqKF4cdy0^2=qtoIG? zoNV>i6%;s`xPxlri-NneE};P4ki>EW!8dWJrT1QKe{!_zpnp0ESkwN?<>gP$wddaI z%pYF5dOWhmSU|RlvPaiGZ-21-(Z$cNom@F~YWdPH78l+d8X5{$-F1{_ay?r`T0kM% zRe?|2zHPZwUREqL0VV(T@$>E9zt%qaMl|E)1FZP0bNcm_UtQ?U+E+fL%ys#AKxS!k z>Cup%I;TXOIeUUnD-t#2iSDClf;5`W{2!JsT#U|t&vljy`mh+i`|_uA?Z5u+^J{O` zq@nvKIQ3nF^}&c1%Q?w?f_Uwwh8RNNBQ(C3ntn84%q!Y%eyr>hi?`T%Imdr$h<{Lh1;FSb-xw;5zZlofHBE?)0bF6T*+;K#OuyC2WpB zxw|eG5)B3DO_PysW+f(+)%yhRp=s>W_j%&SfcGd6qA=5Dg+|;;akQB}F9A8m3(2}# zSFFq_@qpM!G&GL>Q8y7b33n3D_wf)?IeMh<(t6xTGRKXXnUg?&NsbwrwZZSJC)Z&{ zt&w~wNz@h}O*5ds{(#`a;=*goAAcOx1%%z=!imLeO+dhBA0MrWKN$>gH5NJxM+s7$ zJ-zhik%$sky6uBwxP~b}P_|imvL+8z%ab{gt^pKe*a#*joI{Q<2tQ?^mY)jB2Z7~l zKyFwPx)QH^7#(2w*q;{{KI;7Pa_5a>i&rmiAFO4c3e584Q>HT!i9 zY*nVqbZWyaTU}mMzro7`xkoTdlr-SbjHI$GVm*bp-}0}FtVk*30E&9;3r(TIrmzf< zYDSEZDiG>jYa;)@%fbInq7;~-dps%AFhb2BEEd2aj4)*wF9c>W+HooKMi&8&`nJ>b zVQP5(d