Skip to content

Commit

Permalink
Move PATCH /mlflow/model-versions/update endpoint. (#98)
Browse files Browse the repository at this point in the history
Signed-off-by: Software Developer <[email protected]>
  • Loading branch information
dsuhinin authored Dec 16, 2024
1 parent ab5854f commit 813c4fc
Show file tree
Hide file tree
Showing 8 changed files with 64 additions and 1 deletion.
2 changes: 1 addition & 1 deletion magefiles/generate/endpoints.go
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ var ServiceInfoMap = map[string]ServiceGenerationInfo{
// "searchRegisteredModels",
"getLatestVersions",
// "createModelVersion",
// "updateModelVersion",
"updateModelVersion",
// "transitionModelVersionStage",
"deleteModelVersion",
// "getModelVersion",
Expand Down
5 changes: 5 additions & 0 deletions mlflow_go/store/model_registry.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
GetLatestVersions,
GetRegisteredModel,
RenameRegisteredModel,
UpdateModelVersion,
UpdateRegisteredModel,
)

Expand Down Expand Up @@ -84,6 +85,10 @@ def delete_model_version(self, name, version):
request = DeleteModelVersion(name=name, version=str(version))
self.service.call_endpoint(get_lib().ModelRegistryServiceDeleteModelVersion, request)

def update_model_version(self, name, version, description=None):
request = UpdateModelVersion(name=name, version=str(version), description=description)
self.service.call_endpoint(get_lib().ModelRegistryServiceUpdateModelVersion, request)


def ModelRegistryStore(cls):
return type(cls.__name__, (_ModelRegistryStore, cls), {})
Expand Down
1 change: 1 addition & 0 deletions pkg/contract/service/model_registry.g.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 8 additions & 0 deletions pkg/lib/model_registry.g.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

13 changes: 13 additions & 0 deletions pkg/model_registry/service/model_versions.go
Original file line number Diff line number Diff line change
Expand Up @@ -86,3 +86,16 @@ func (m *ModelRegistryService) DeleteModelVersion(

return &protos.DeleteModelVersion_Response{}, nil
}

func (m *ModelRegistryService) UpdateModelVersion(
ctx context.Context, input *protos.UpdateModelVersion,
) (*protos.UpdateModelVersion_Response, *contract.Error) {
modelVersion, err := m.store.UpdateModelVersion(ctx, input.GetName(), input.GetVersion(), input.GetDescription())
if err != nil {
return nil, err
}

return &protos.UpdateModelVersion_Response{
ModelVersion: modelVersion.ToProto(),
}, nil
}
24 changes: 24 additions & 0 deletions pkg/model_registry/store/sql/model_versions.go
Original file line number Diff line number Diff line change
Expand Up @@ -353,3 +353,27 @@ func (m *ModelRegistrySQLStore) DeleteModelVersion(ctx context.Context, name, ve

return nil
}

func (m *ModelRegistrySQLStore) UpdateModelVersion(
ctx context.Context, name, version, description string,
) (*entities.ModelVersion, *contract.Error) {
modelVersion, err := m.GetModelVersion(ctx, name, version)
if err != nil {
return nil, err
}

if err := m.db.WithContext(ctx).Model(
&models.ModelVersion{},
).Where(
"name = ?", modelVersion.Name,
).Where(
"version = ?", modelVersion.Version,
).Updates(&models.ModelVersion{
Description: sql.NullString{String: description, Valid: description != ""},
LastUpdatedTime: time.Now().UnixMilli(),
}).Error; err != nil {
return nil, contract.NewErrorWith(protos.ErrorCode_INTERNAL_ERROR, "error updating model version", err)
}

return modelVersion, nil
}
1 change: 1 addition & 0 deletions pkg/model_registry/store/store.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,5 @@ type ModelRegistryStore interface {
RenameRegisteredModel(ctx context.Context, name, newName string) (*entities.RegisteredModel, *contract.Error)
DeleteRegisteredModel(ctx context.Context, name string) *contract.Error
DeleteModelVersion(ctx context.Context, name, version string) *contract.Error
UpdateModelVersion(ctx context.Context, name, version, description string) (*entities.ModelVersion, *contract.Error)
}
11 changes: 11 additions & 0 deletions pkg/server/routes/model_registry.g.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit 813c4fc

Please sign in to comment.