diff --git a/models/cloudbrain.go b/models/cloudbrain.go
index af5e9f169..a106d7433 100755
--- a/models/cloudbrain.go
+++ b/models/cloudbrain.go
@@ -353,6 +353,7 @@ type FlavorInfos struct {
type FlavorInfo struct {
Id int `json:"id"`
Value string `json:"value"`
+ Desc string `json:"desc"`
}
type PoolInfos struct {
diff --git a/modules/auth/modelarts.go b/modules/auth/modelarts.go
index f2e5aeed5..e9e101523 100755
--- a/modules/auth/modelarts.go
+++ b/modules/auth/modelarts.go
@@ -19,6 +19,7 @@ type CreateModelArtsNotebookForm struct {
JobName string `form:"job_name" binding:"Required"`
Attachment string `form:"attachment"`
Description string `form:"description"`
+ Flavor string `form:"flavor"`
}
func (f *CreateModelArtsNotebookForm) Validate(ctx *macaron.Context, errs binding.Errors) binding.Errors {
diff --git a/modules/modelarts/modelarts.go b/modules/modelarts/modelarts.go
index e1dbe9f5a..3153fbc52 100755
--- a/modules/modelarts/modelarts.go
+++ b/modules/modelarts/modelarts.go
@@ -99,7 +99,7 @@ type ResourcePool struct {
} `json:"resource_pool"`
}
-func GenerateTask(ctx *context.Context, jobName, uuid, description string) error {
+func GenerateTask(ctx *context.Context, jobName, uuid, description, flavor string) error {
var dataActualPath string
if uuid != "" {
dataActualPath = setting.Bucket + "/" + setting.BasePath + path.Join(uuid[0:1], uuid[1:2]) + "/" + uuid + "/"
@@ -128,7 +128,7 @@ func GenerateTask(ctx *context.Context, jobName, uuid, description string) error
JobName: jobName,
Description: description,
ProfileID: setting.ProfileID,
- Flavor: setting.Flavor,
+ Flavor: flavor,
Pool: models.Pool{
ID: poolInfos.PoolInfo[0].PoolId,
Name: poolInfos.PoolInfo[0].PoolName,
diff --git a/routers/repo/cloudbrain.go b/routers/repo/cloudbrain.go
index 03fba6cd1..529d576bc 100755
--- a/routers/repo/cloudbrain.go
+++ b/routers/repo/cloudbrain.go
@@ -204,7 +204,7 @@ func CloudBrainCreate(ctx *context.Context, form auth.CreateCloudBrainForm) {
resourceSpecId := form.ResourceSpecId
if !jobNamePattern.MatchString(jobName) {
- ctx.RenderWithErr(ctx.Tr("repo.cloudbrain_jobname_err"), tplModelArtsNew, &form)
+ ctx.RenderWithErr(ctx.Tr("repo.cloudbrain_jobname_err"), tplCloudBrainNew, &form)
return
}
diff --git a/routers/repo/modelarts.go b/routers/repo/modelarts.go
index f33d345cd..aec6a024f 100755
--- a/routers/repo/modelarts.go
+++ b/routers/repo/modelarts.go
@@ -27,15 +27,10 @@ import (
)
const (
- // tplModelArtsNotebookIndex base.TplName = "repo/modelarts/notebook/index"
tplModelArtsNotebookIndex base.TplName = "repo/modelarts/notebook/index"
tplModelArtsNotebookNew base.TplName = "repo/modelarts/notebook/new"
tplModelArtsNotebookShow base.TplName = "repo/modelarts/notebook/show"
- tplModelArtsIndex base.TplName = "repo/modelarts/index"
- tplModelArtsNew base.TplName = "repo/modelarts/new"
- tplModelArtsShow base.TplName = "repo/modelarts/show"
-
tplModelArtsTrainJobIndex base.TplName = "repo/modelarts/trainjob/index"
tplModelArtsTrainJobNew base.TplName = "repo/modelarts/trainjob/new"
tplModelArtsTrainJobShow base.TplName = "repo/modelarts/trainjob/show"
@@ -50,229 +45,6 @@ func MustEnableModelArts(ctx *context.Context) {
}
}
-func ModelArtsIndex(ctx *context.Context) {
- MustEnableModelArts(ctx)
- repo := ctx.Repo.Repository
- page := ctx.QueryInt("page")
- if page <= 0 {
- page = 1
- }
-
- ciTasks, count, err := models.Cloudbrains(&models.CloudbrainsOptions{
- ListOptions: models.ListOptions{
- Page: page,
- PageSize: setting.UI.IssuePagingNum,
- },
- RepoID: repo.ID,
- Type: models.TypeCloudBrainTwo,
- })
- if err != nil {
- ctx.ServerError("Cloudbrain", err)
- return
- }
-
- for i, task := range ciTasks {
- if task.Status == string(models.JobRunning) {
- ciTasks[i].CanDebug = true
- } else {
- ciTasks[i].CanDebug = false
- }
-
- ciTasks[i].CanDel = models.CanDelJob(ctx.IsSigned, ctx.User, task)
- }
-
- pager := context.NewPagination(int(count), setting.UI.IssuePagingNum, page, 5)
- pager.SetDefaultParams(ctx)
- ctx.Data["Page"] = pager
-
- ctx.Data["PageIsCloudBrain"] = true
- ctx.Data["Tasks"] = ciTasks
- ctx.HTML(200, tplModelArtsIndex)
-}
-
-func ModelArtsNew(ctx *context.Context) {
- ctx.Data["PageIsCloudBrain"] = true
-
- t := time.Now()
- var jobName = jobNamePrefixValid(cutString(ctx.User.Name, 5)) + t.Format("2006010215") + strconv.Itoa(int(t.Unix()))[5:]
- ctx.Data["job_name"] = jobName
-
- attachs, err := models.GetModelArtsUserAttachments(ctx.User.ID)
- if err != nil {
- ctx.ServerError("GetAllUserAttachments failed:", err)
- return
- }
-
- ctx.Data["attachments"] = attachs
- ctx.Data["dataset_path"] = modelarts.DataSetMountPath
- ctx.Data["env"] = modelarts.NotebookEnv
- ctx.Data["notebook_type"] = modelarts.NotebookType
- if modelarts.FlavorInfos == nil {
- json.Unmarshal([]byte(setting.FlavorInfos), &modelarts.FlavorInfos)
- }
- ctx.Data["flavors"] = modelarts.FlavorInfos.FlavorInfo
- ctx.HTML(200, tplModelArtsNew)
-}
-
-func ModelArtsCreate(ctx *context.Context, form auth.CreateModelArtsForm) {
- ctx.Data["PageIsCloudBrain"] = true
- jobName := form.JobName
- uuid := form.Attachment
- description := form.Description
- //repo := ctx.Repo.Repository
- if !jobNamePattern.MatchString(jobName) {
- ctx.RenderWithErr(ctx.Tr("repo.cloudbrain_jobname_err"), tplModelArtsNew, &form)
- return
- }
- err := modelarts.GenerateTask(ctx, jobName, uuid, description)
- if err != nil {
- ctx.RenderWithErr(err.Error(), tplModelArtsNew, &form)
- return
- }
-
- ctx.Redirect(setting.AppSubURL + ctx.Repo.RepoLink + "/modelarts")
-}
-
-func ModelArtsShow(ctx *context.Context) {
- ctx.Data["PageIsCloudBrain"] = true
-
- var jobID = ctx.Params(":jobid")
- task, err := models.GetCloudbrainByJobID(jobID)
- if err != nil {
- ctx.Data["error"] = err.Error()
- ctx.RenderWithErr(err.Error(), tplModelArtsIndex, nil)
- return
- }
-
- result, err := modelarts.GetJob(jobID)
- if err != nil {
- ctx.Data["error"] = err.Error()
- ctx.RenderWithErr(err.Error(), tplModelArtsIndex, nil)
- return
- }
-
- if result != nil {
- task.Status = result.Status
- err = models.UpdateJob(task)
- if err != nil {
- ctx.Data["error"] = err.Error()
- ctx.RenderWithErr(err.Error(), tplModelArtsIndex, nil)
- return
- }
-
- createTime, _ := com.StrTo(result.CreationTimestamp).Int64()
- result.CreateTime = time.Unix(int64(createTime/1000), 0).Format("2006-01-02 15:04:05")
- endTime, _ := com.StrTo(result.LatestUpdateTimestamp).Int64()
- result.LatestUpdateTime = time.Unix(int64(endTime/1000), 0).Format("2006-01-02 15:04:05")
- result.QueuingInfo.BeginTime = time.Unix(int64(result.QueuingInfo.BeginTimestamp/1000), 0).Format("2006-01-02 15:04:05")
- result.QueuingInfo.EndTime = time.Unix(int64(result.QueuingInfo.EndTimestamp/1000), 0).Format("2006-01-02 15:04:05")
- }
-
- ctx.Data["task"] = task
- ctx.Data["jobID"] = jobID
- ctx.Data["result"] = result
- ctx.HTML(200, tplModelArtsShow)
-}
-
-func ModelArtsDebug(ctx *context.Context) {
- var jobID = ctx.Params(":jobid")
- _, err := models.GetCloudbrainByJobID(jobID)
- if err != nil {
- ctx.ServerError("GetCloudbrainByJobID failed", err)
- return
- }
-
- result, err := modelarts.GetJob(jobID)
- if err != nil {
- ctx.RenderWithErr(err.Error(), tplModelArtsIndex, nil)
- return
- }
-
- res, err := modelarts.GetJobToken(jobID)
- if err != nil {
- ctx.RenderWithErr(err.Error(), tplModelArtsIndex, nil)
- return
- }
-
- urls := strings.Split(result.Spec.Annotations.Url, "/")
- urlPrefix := result.Spec.Annotations.TargetDomain
- for i, url := range urls {
- if i > 2 {
- urlPrefix += "/" + url
- }
- }
-
- //urlPrefix := result.Spec.Annotations.TargetDomain + "/modelarts/internal/hub/notebook/user/" + task.JobID
- log.Info(urlPrefix)
- debugUrl := urlPrefix + "?token=" + res.Token
- ctx.Redirect(debugUrl)
-}
-
-func ModelArtsStop(ctx *context.Context) {
- var jobID = ctx.Params(":jobid")
- log.Info(jobID)
- task, err := models.GetCloudbrainByJobID(jobID)
- if err != nil {
- ctx.ServerError("GetCloudbrainByJobID failed", err)
- return
- }
-
- if task.Status != string(models.JobRunning) {
- log.Error("the job(%s) is not running", task.JobName)
- ctx.ServerError("the job is not running", errors.New("the job is not running"))
- return
- }
-
- param := models.NotebookAction{
- Action: models.ActionStop,
- }
- res, err := modelarts.StopJob(jobID, param)
- if err != nil {
- log.Error("StopJob(%s) failed:%v", task.JobName, err.Error())
- ctx.ServerError("StopJob failed", err)
- return
- }
-
- task.Status = res.CurrentStatus
- err = models.UpdateJob(task)
- if err != nil {
- ctx.ServerError("UpdateJob failed", err)
- return
- }
-
- ctx.Redirect(setting.AppSubURL + ctx.Repo.RepoLink + "/modelarts")
-}
-
-func ModelArtsDel(ctx *context.Context) {
- var jobID = ctx.Params(":jobid")
- task, err := models.GetCloudbrainByJobID(jobID)
- if err != nil {
- ctx.ServerError("GetCloudbrainByJobID failed", err)
- return
- }
-
- if task.Status != string(models.ModelArtsCreateFailed) && task.Status != string(models.ModelArtsStartFailed) && task.Status != string(models.ModelArtsStopped) {
- log.Error("the job(%s) has not been stopped", task.JobName)
- ctx.ServerError("the job has not been stopped", errors.New("the job has not been stopped"))
- return
- }
-
- _, err = modelarts.DelJob(jobID)
- if err != nil {
- log.Error("DelJob(%s) failed:%v", task.JobName, err.Error())
- ctx.ServerError("DelJob failed", err)
- return
- }
-
- err = models.DeleteJob(task)
- if err != nil {
- ctx.ServerError("DeleteJob failed", err)
- return
- }
-
- ctx.Redirect(setting.AppSubURL + ctx.Repo.RepoLink + "/modelarts")
-}
-
func NotebookIndex(ctx *context.Context) {
MustEnableModelArts(ctx)
repo := ctx.Repo.Repository
@@ -342,8 +114,9 @@ func NotebookCreate(ctx *context.Context, form auth.CreateModelArtsNotebookForm)
jobName := form.JobName
uuid := form.Attachment
description := form.Description
+ flavor := form.Flavor
- err := modelarts.GenerateTask(ctx, jobName, uuid, description)
+ err := modelarts.GenerateTask(ctx, jobName, uuid, description, flavor)
if err != nil {
ctx.RenderWithErr(err.Error(), tplModelArtsNotebookNew, &form)
return
diff --git a/templates/repo/modelarts/new.tmpl b/templates/repo/modelarts/new.tmpl
index 79a31286f..7ee499d91 100755
--- a/templates/repo/modelarts/new.tmpl
+++ b/templates/repo/modelarts/new.tmpl
@@ -138,7 +138,7 @@
diff --git a/templates/repo/modelarts/notebook/new.tmpl b/templates/repo/modelarts/notebook/new.tmpl
index 8cfa680f7..284d6d6c7 100755
--- a/templates/repo/modelarts/notebook/new.tmpl
+++ b/templates/repo/modelarts/notebook/new.tmpl
@@ -138,7 +138,7 @@