diff --git a/CHANGELOG.md b/CHANGELOG.md index 4b36f587..f0021f78 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -19,6 +19,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - #678 Only update comment-flagged part of the language extension, allowing users to keep their custom code when upgrading - #680, #683 Always export static files (README.md, LICENSE, requirements.txt, CHANGELOG.md) if existent +### Security +- #697 When publishing modules, will get an status with error message (instead of just a boolean) in case of failures. + ## [0.9.1] - 2024-12-18 ### Added diff --git a/src/cls/IPM/Lifecycle/Base.cls b/src/cls/IPM/Lifecycle/Base.cls index 0f2e9c79..38df90f8 100644 --- a/src/cls/IPM/Lifecycle/Base.cls +++ b/src/cls/IPM/Lifecycle/Base.cls @@ -1403,7 +1403,7 @@ Method %Publish(ByRef pParams) As %Status } - Do tPublishClient.PublishModule(tModule) + $$$ThrowOnError(tPublishClient.PublishModule(tModule)) // May need to update the version of the currently-installed module. diff --git a/src/cls/IPM/Repo/IPublishService.cls b/src/cls/IPM/Repo/IPublishService.cls index e2e0a384..acd14e69 100644 --- a/src/cls/IPM/Repo/IPublishService.cls +++ b/src/cls/IPM/Repo/IPublishService.cls @@ -1,7 +1,7 @@ Class %IPM.Repo.IPublishService [ Abstract ] { -Method PublishModule(pModule As %IPM.Repo.Remote.ModuleInfo) As %Boolean [ Abstract ] +Method PublishModule(pModule As %IPM.Repo.Remote.ModuleInfo) As %Status [ Abstract ] { } diff --git a/src/cls/IPM/Repo/Remote/PublishService.cls b/src/cls/IPM/Repo/Remote/PublishService.cls index 7522ed2e..70375246 100644 --- a/src/cls/IPM/Repo/Remote/PublishService.cls +++ b/src/cls/IPM/Repo/Remote/PublishService.cls @@ -1,12 +1,17 @@ Class %IPM.Repo.Remote.PublishService Extends (%IPM.Repo.Remote.PackageService, %IPM.Repo.IPublishService) { -Method PublishModule(pModule As %IPM.Repo.Remote.ModuleInfo) As %Boolean +Method PublishModule(pModule As %IPM.Repo.Remote.ModuleInfo) As %Status { - Quit ..Publish(pModule) + Try { + Do ..Publish(pModule) + } Catch Ex { + Return Ex.AsStatus() + } + Return $$$OK } -Method Publish(pModule As %IPM.Repo.Remote.ModuleInfo) As %Boolean +Method Publish(pModule As %IPM.Repo.Remote.ModuleInfo) { If ((..Username="") || (..Password="")) && (..Token="") { $$$ThrowStatus($$$ERROR($$$GeneralError, "Publishing module, authorization required.")) @@ -28,7 +33,6 @@ Method Publish(pModule As %IPM.Repo.Remote.ModuleInfo) As %Boolean $$$ThrowStatus($$$ERROR($$$GeneralError, tMessage)) } } - Return 1 } Method CheckUnpublishEnabled(packageName As %String, packageVersion As %String) As %Boolean