You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

cloudrbanin.js 11 kB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  1. export default async function initCloudrain() {
  2. let debug_button = $('.cloudbrain_debug').data('debug')
  3. let debug_again_button = $('.cloudbrain_debug').data('debug-again')
  4. let timeid = window.setInterval(loadJobStatus, 15000);
  5. $(document).ready(loadJobStatus);
  6. function loadJobStatus() {
  7. $(".job-status").each((index, job) => {
  8. const ID = job.dataset.jobid;
  9. const repoPath = job.dataset.repopath;
  10. // const computeResource = job.dataset.resource
  11. const versionname = job.dataset.version
  12. const status_text = $(`#${ID}-text`).text()
  13. const finalState = ['STOPPED','CREATE_FAILED','UNAVAILABLE','DELETED','RESIZE_FAILED','SUCCEEDED','IMAGE_FAILED','SUBMIT_FAILED','DELETE_FAILED','KILLED','COMPLETED','FAILED','CANCELED','LOST','START_FAILED','SUBMIT_MODEL_FAILED','DEPLOY_SERVICE_FAILED','CHECK_FAILED']
  14. if (finalState.includes(status_text)) {
  15. return
  16. }
  17. // const diffResource = computeResource == "NPU" ? 'modelarts/notebook' : 'cloudbrain'
  18. $.get(`/api/v1/repos/${repoPath}/${ID}?version_name=${versionname}`, (data) => {
  19. const ID = data.ID || data.JobID
  20. const status = data.JobStatus
  21. const duration = data.JobDuration
  22. $('#duration-'+ID).text(duration)
  23. if (status != status_text) {
  24. $('#' + ID+'-icon').removeClass().addClass(status)
  25. $('#' + ID+ '-text').text(status)
  26. finalState.includes(status) && $('#' + ID + '-stop').removeClass('blue').addClass('disabled')
  27. }
  28. if(status==="RUNNING"){
  29. $('#ai-debug-'+ID).removeClass('disabled').addClass('blue').text(debug_button).css("margin","0 1rem")
  30. $('#model-image-'+ID).removeClass('disabled').addClass('blue')
  31. }
  32. if(status!=="RUNNING"){
  33. // $('#model-debug-'+ID).removeClass('blue')
  34. // $('#model-debug-'+ID).addClass('disabled')
  35. $('#model-image-'+ID).removeClass('blue').addClass('disabled')
  36. }
  37. if(["CREATING","STOPPING","WAITING","STARTING"].includes(status)){
  38. $('#ai-debug-'+ID).removeClass('blue').addClass('disabled')
  39. }
  40. if(['STOPPED','FAILED','START_FAILED','CREATE_FAILED','SUCCEEDED'].includes(status)){
  41. $('#ai-debug-'+ID).removeClass('disabled').addClass('blue').text(debug_again_button).css("margin","0")
  42. }
  43. if(["RUNNING","WAITING"].includes(status)){
  44. $('#ai-stop-'+ID).removeClass('disabled').addClass('blue')
  45. }
  46. if(["CREATING","STOPPING","STARTING","STOPPED","FAILED","START_FAILED","SUCCEEDED","COMPLETED"].includes(status)){
  47. $('#ai-stop-'+ID).removeClass('blue').addClass('disabled')
  48. }
  49. if(["STOPPED","FAILED","START_FAILED","KILLED","COMPLETED","SUCCEEDED"].includes(status)){
  50. $('#ai-delete-'+ID).removeClass('disabled').addClass('blue')
  51. }else{
  52. $('#ai-delete-'+ID).removeClass('blue').addClass('disabled')
  53. }
  54. }).fail(function(err) {
  55. console.log(err);
  56. });
  57. });
  58. };
  59. function assertDelete(obj,versionName,repoPath) {
  60. if (obj.style.color == "rgb(204, 204, 204)") {
  61. return
  62. } else {
  63. const delId = obj.parentNode.id
  64. let flag = 1;
  65. $('.ui.basic.modal')
  66. .modal({
  67. onDeny: function() {
  68. flag = false
  69. },
  70. onApprove: function() {
  71. if(!versionName){
  72. document.getElementById(delId).submit()
  73. }
  74. else{
  75. deleteVersion(versionName,repoPath)
  76. }
  77. flag = true
  78. },
  79. onHidden: function() {
  80. if (flag == false) {
  81. $('.alert').html('您已取消操作').removeClass('alert-success').addClass('alert-danger').show().delay(1500).fadeOut();
  82. }
  83. }
  84. })
  85. .modal('show')
  86. }
  87. }
  88. function deleteVersion(versionName,repoPath){
  89. const url = `/api/v1/repos/${repoPath}`
  90. $.post(url,{version_name:versionName},(data)=>{
  91. if(data.StatusOK===0){
  92. location.reload()
  93. }
  94. }).fail(function(err) {
  95. console.log(err);
  96. });
  97. }
  98. $('.ui.basic.ai_delete').click(function() {
  99. const repoPath = this.dataset.repopath
  100. const versionName = this.dataset.version
  101. if(repoPath && versionName){
  102. assertDelete(this,versionName,repoPath)
  103. }
  104. else{
  105. assertDelete(this)
  106. }
  107. })
  108. function stopDebug(ID,stopUrl){
  109. $.ajax({
  110. type:"POST",
  111. url:stopUrl,
  112. data:$('#stopForm-'+ID).serialize(),
  113. success:function(res){
  114. if(res.result_code==="0"){
  115. $('#' + ID+'-icon').removeClass().addClass(res.status)
  116. $('#' + ID+ '-text').text(res.status)
  117. if(res.status==="STOPPED"){
  118. $('#ai-debug-'+ID).removeClass('disabled').addClass('blue').text(debug_again_button).css("margin","0")
  119. $('#ai-image-'+ID).removeClass('blue').addClass('disabled')
  120. $('#ai-model-debug-'+ID).removeClass('blue').addClass('disabled')
  121. $('#ai-delete-'+ID).removeClass('disabled').addClass('blue')
  122. $('#ai-stop-'+ID).removeClass('blue').addClass('disabled')
  123. }
  124. else{
  125. $('#ai-debug-'+ID).removeClass('blue').addClass('disabled')
  126. $('#ai-stop-'+ID).removeClass('blue').addClass('disabled')
  127. }
  128. }else{
  129. $('.alert').html(res.error_msg).removeClass('alert-success').addClass('alert-danger').show().delay(2000).fadeOut();
  130. }
  131. },
  132. error :function(res){
  133. console.log(res)
  134. }
  135. })
  136. }
  137. $('.ui.basic.ai_stop').click(function() {
  138. const ID = this.dataset.jobid
  139. const repoPath = this.dataset.repopath
  140. stopDebug(ID,repoPath)
  141. })
  142. function stopVersion(version_name,ID,repoPath){
  143. const url = `/api/v1/repos/${repoPath}/${ID}/stop_version`
  144. $.post(url,{version_name:version_name},(data)=>{
  145. if(data.StatusOK===0){
  146. $('#ai-stop-'+ID).removeClass('blue')
  147. $('#ai-stop-'+ID).addClass('disabled')
  148. refreshStatus(version_name,ID,repoPath)
  149. }
  150. }).fail(function(err) {
  151. console.log(err);
  152. });
  153. }
  154. function refreshStatus(version_name,ID,repoPath){
  155. const url = `/api/v1/repos/${repoPath}/${ID}/?version_name${version_name}`
  156. $.get(url,(data)=>{
  157. $(`#${ID}-icon`).attr("class",data.JobStatus)
  158. // detail status and duration
  159. $(`#${ID}-text`).text(data.JobStatus)
  160. }).fail(function(err) {
  161. console.log(err);
  162. });
  163. }
  164. $('.ui.basic.ai_stop_version').click(function() {
  165. const ID = this.dataset.jobid
  166. const repoPath = this.dataset.repopath
  167. const versionName = this.dataset.version
  168. stopVersion(versionName,ID,repoPath)
  169. })
  170. function getModelInfo(repoPath,modelName,versionName,jobName){
  171. $.get(`${repoPath}/modelmanage/show_model_info_api?name=${modelName}`,(data)=>{
  172. if(data.length===0){
  173. $(`#${jobName}`).popup('toggle')
  174. }else{
  175. let versionData = data.filter((item)=>{
  176. return item.Version === versionName
  177. })
  178. if(versionData.length==0){
  179. $(`#${jobName}`).popup('toggle')
  180. }
  181. else{
  182. location.href = `${repoPath}/modelmanage/show_model_info?name=${modelName}`
  183. }
  184. }
  185. })
  186. }
  187. $('.goto_modelmanage').click(function() {
  188. const repoPath = this.dataset.repopath
  189. const modelName = this.dataset.modelname
  190. const versionName = this.dataset.version
  191. const jobName = this.dataset.jobname
  192. getModelInfo(repoPath,modelName,versionName,jobName)
  193. })
  194. function debugAgain(ID,debugUrl,redirect_to){
  195. if($('#' + ID+ '-text').text()==="RUNNING"){
  196. window.open(debugUrl+'debug')
  197. }else{
  198. $.ajax({
  199. type:"POST",
  200. url:debugUrl+'restart?redirect_to='+redirect_to,
  201. data:$('#debugAgainForm-'+ID).serialize(),
  202. success:function(res){
  203. if(res['WechatRedirectUrl']){
  204. window.location.href=res['WechatRedirectUrl']
  205. }
  206. else if(res.result_code==="0"){
  207. if(res.id!==ID){
  208. location.reload()
  209. }else{
  210. $('#' + ID+'-icon').removeClass().addClass(res.status)
  211. $('#' + ID+ '-text').text(res.status)
  212. $('#ai-debug-'+ID).removeClass('blue').addClass('disabled')
  213. $('#ai-delete-'+ID).removeClass('blue').addClass('disabled')
  214. $('#ai-debug-'+ID).text(debug_button).css("margin","0 1rem")
  215. }
  216. }else{
  217. $('.alert').html(res.error_msg).removeClass('alert-success').addClass('alert-danger').show().delay(2000).fadeOut();
  218. }
  219. },
  220. error :function(res){
  221. console.log(res)
  222. }
  223. })
  224. }
  225. }
  226. $('.ui.basic.ai_debug').click(function() {
  227. const ID = this.dataset.jobid
  228. const repoPath = this.dataset.repopath
  229. const redirect_to = this.dataset.linkpath
  230. debugAgain(ID,repoPath,redirect_to)
  231. })
  232. }