Class Reference
IRIS for UNIX 2024.1.2
InterSystems: The power behind what matters   
Documentation  Search
  [USER] >  [%IPM] >  [Storage] >  [Module]
Private  Storage   

persistent class %IPM.Storage.Module extends %Persistent, %IPM.General.ModuleInfo, %IPM.Utils.ComparisonAdaptor

SQL Table Name: ModuleItem

Inventory

Parameters Properties Methods Queries Indices ForeignKeys Triggers
2 27 29 1 1


Summary

Properties
AfterInstallMessage AllVersions Author AvailabilityClass
CalculatedResources Defaults Dependencies Deployed
Description DeveloperMode DisplayName ExternalName
GlobalScope Hash InstallerClass Invokes
Keywords LastModifiedTimestamp Lifecycle LifecycleClass
Mappings Name Origin OverrideLifecycleClass
Packaging PlatformVersion Repository Resources
Root SourcesRoot SystemRequirements Version
VersionString

Methods
%%CLASSNAMELogicalToStorage %%CLASSNAMEStorageToLogical %AddToSaveSet %AddToSyncSet
%BMEBuilt %BuildIndicesAsync %BuildIndicesAsyncResponse %CheckConstraints
%CheckConstraintsForExtent %ClassIsLatestVersion %ClassName %CompareTo
%Compile %ComposeOid %ConstructClone %Delete
%DeleteExtent %DeleteId %DispatchClassMethod %DispatchGetModified
%DispatchGetProperty %DispatchMethod %DispatchSetModified %DispatchSetMultidimProperty
%DispatchSetProperty %Exists %ExistsId %Extends
%GUID %GUIDSet %GetLock %GetParameter
%GetSwizzleObject %Id %InsertBatch %IsA
%IsModified %IsNull %JSONExport %JSONExportToStream
%JSONExportToString %JSONImport %JSONNew %KillExtent
%KillExtentData %LoadFromMemory %LockExtent %LockId
%New %NormalizeObject %ObjectIsNull %ObjectModified
%Oid %OnBeforeAddToSync %OnDeleteFinally %OnDetermineClass
%OnOpenFinally %OnSaveFinally %Open %OpenId
%OriginalNamespace %PackageName %PhysicalAddress %PurgeIndices
%Reload %RemoveFromSaveSet %ResolveConcurrencyConflict %RollBack
%Save %SaveDirect %SaveIndices %SerializeObject
%SetModified %SortBegin %SortEnd %SyncObjectIn
%SyncTransport %UnlockExtent %UnlockId %ValidateIndices
%ValidateObject %ValidateTable BuildDependencyGraph CalculatedResourcesGet
CheckSystemRequirements CompareToSkipCondition CompareWithRelationships DisplayNameSet
ExecutePhases FindAllSuperClasses GetDefaultParameters GetKnownDependencies
GetNamespaceConfig GetResolvedReferences GetStudioProject HaveToDeploy
IgnoreKeywordList IsLocked LifecycleGet LoadDependencies
Lock NameSet OverrideLifecycleClassSet Uninstall
ValidateStream VersionStringGet VersionStringSet WriteAfterInstallMessage
XMLDTD XMLExport XMLExportToStream XMLExportToString
XMLNew XMLSchema XMLSchemaNamespace XMLSchemaType

Subclasses
%IPM.Storage.ModuleTemplate

Parameters

• parameter DEFAULTGLOBAL = "^IPM.Storage.Module";

If a persistent class uses %Storage.Persistent then the DEFAULTGLOBAL parameter is used as the default global root for the values of the storage keywords COUNTERLOCATION, DATALOCATION, IDLOCATION, INDEXLOCATION and STREAMLOCATION in the active storage definition. DEFAULTGLOBAL is only used to generate location keyword values that are not already defined. The location value is constructed by adding a location type to the end of DEFAULTGLOBAL. For example, if DEFAULTGLOBAL = "^GL.Account" the compiler will generate DATALOCATION = ^GL.AccountD.

If USEEXTENTSET is true, then DEFAULTGLOBAL is used as the default extent location.


The location types are:
LocationType
COUNTERLOCATIONC
DATALOCATIOND
IDLOCATIOND
INDEXLOCATIONI
STREAMLOCATIONS
• parameter DOMAIN = "ZPM";

Properties

• property AfterInstallMessage as %String(MAXLEN="",XMLPROJECTION="Element");
• property Author as %IPM.Storage.ModuleAuthorInfo;
• property AvailabilityClass as %Dictionary.Classname;
Defined class which can report that a module is not available for this instance/namespace
• property CalculatedResources as list of %IPM.Storage.ResourceReference(XMLIO="OUT",XMLITEMNAME="Resource",XMLNAME="Resources",XMLPROJECTION="WRAPPED",XMLREFERENCE="COMPLETE") [ Calculated ];
Calculated property used for XML output of Resources relationship (in a reasonable order: packages, classes, includes, globals, routines, CSP resources, then in alphabetical order within those categories).
• property Defaults as list of %IPM.Storage.ModuleSetting(CLASSNAME=1,STORAGEDEFAULT="array",XMLNAME="Defaults",XMLPROJECTION="WRAPPED",XMLREFERENCE="COMPLETE",XMLTYPECONSTRAINT="SUBSTITUTIONGROUP");
Default settings - there may be serveral types of these (subclasses of ModuleSetting).
• property Dependencies as list of %IPM.Storage.ModuleReference(STORAGEDEFAULT="array");
• property Deployed as %Boolean(XMLPROJECTION="Element");
• property Description as %String(MAXLEN="");
• property DeveloperMode as %Boolean(ForceCodeGenerate=0,XMLPROJECTION="NONE");
Set to 1 if this module is in development mode, 0 if it is not.
• property ExternalName as %String(MAXLEN=255);
• property GlobalScope as %Boolean;
• property Hash as %Binary(ForceCodeGenerate=0,XMLPROJECTION="NONE");
• property InstallerClass as %Dictionary.Classname;
• relationship Invokes as %IPM.Storage.InvokeReference(XMLITEMNAME="Invoke",XMLPROJECTION="WRAPPED",XMLREFERENCE="COMPLETE") [ Inverse = Module,Cardinality = children ];
• property Keywords as %String(MAXLEN="");
• property LastModifiedTimestamp as %TimeStamp(ForceCodeGenerate=0,XMLPROJECTION="NONE") [ InitialExpression = $ZDateTime($Horolog,3) ];
• property Lifecycle as %IPM.Lifecycle.Base(XMLPROJECTION="NONE") [ Transient ];
• property LifecycleClass as %Dictionary.Classname [ InitialExpression = "%IPM.Lifecycle.Module" ];
Lifecycle class used by default for this module
• relationship Mappings as %IPM.Storage.MappingReference(XMLITEMNAME="Mapping",XMLPROJECTION="WRAPPED",XMLREFERENCE="COMPLETE") [ Inverse = Module,Cardinality = children ];
• property OverrideLifecycleClass as %Dictionary.Classname [ Transient ];
Lifecycle class to use for a specific command (may be overridden from command line)
• property Packaging as %String [ Required ];
Typically "module" or "application", but intentionally not enforced with VALUELIST.
• relationship Resources as %IPM.Storage.ResourceReference(XMLIO="IN",XMLITEMNAME="Resource",XMLPROJECTION="WRAPPED",XMLREFERENCE="COMPLETE") [ Inverse = Module,Cardinality = children ];
• property Root as %String(ForceCodeGenerate=0,MAXLEN="",XMLPROJECTION="NONE");
Root directory on the filesystem from which this module was loaded.
• property SourcesRoot as %String(MAXLEN=20);
Sources root, where placed any source code
• property SystemRequirements as %IPM.Storage.SystemRequirements(ForceCodeGenerate=0);
• property Version as %IPM.General.SemanticVersion(ForceCodeGenerate=0,XMLPROJECTION="NONE") [ Required ];
Does not need comparison method to be code generated because that comparing VersionString is good enough.
• property VersionString as %String(MAXLEN=100,XMLNAME="Version") [ InitialExpression = "0.0.1+snapshot",Required ];

Methods

• method %Compile(ByRef qstruct As %String) as %Status
• method BuildDependencyGraph(ByRef pDependencyGraph, pDepth As %Integer = 1, pForceSnapshotReload As %Boolean = 0, ByRef qstruct, pPhases As %String = "", ByRef pSubModules, pPass As %Integer = 1, pModulePath As %List = $ListBuild(..Name), pIgnoreInstalledModules As %Boolean = 0, pKnownDependencies As %List = ..GetKnownDependencies(..Name), pPermitDowngrade As %Boolean = 0, pCheckNestedScoped As %Boolean = 0, ByRef pSearchList, pIncludeDisplayName As %Boolean = 0) as %Status
• method CalculatedResourcesGet() as %Collection.AbstractListOfObj
This is a Get accessor method for the CalculatedResources property.
• classmethod CheckSystemRequirements(pModuleName As %String) as %Status
• method CompareWithRelationships(pModuleObj As %IPM.Storage.Module, pIgnorePropertyList As %Library.List = "", Output pDifferingPropertyArray As %Library.List) as %Boolean
Calls %CompareTo on this object and also calls it on any relationships in the class specifically Mappings and Resources.
• classmethod ExecutePhases(pModuleName As %String, pPhases As %List, pIsComplete As %Boolean = 0, ByRef pParams) as %Status
Execute multiple lifecycle phases in sequence. Execution is terminated if one fails. Example: $ListBuild("Clean","Test") or $ListBuild("Test","Install") @API.Method
• method GetDefaultParameters(Output pParams)
• classmethod GetKnownDependencies(pModuleName As %String) as %List
This method builds a list of any direct/indirect dependencies of the module named pModuleName in a breadth-first manner.
• method GetNamespaceConfig(ByRef pCheckedModules) as %IPM.Storage.ModuleSetting.NamespaceConfig
• method GetResolvedReferences(Output pReferenceArray, pLockedDependencies As %Boolean = 0, pPhases As %List = "", pSkipDependencies As %Boolean = 0, ByRef pDependencyGraph) as %Status
Builds a module's immediate dependency graph and array of resources.
Optionally loads uninstalled dependency modules and recurses over each module in the dependency graph.
@Argument pReferenceArray Array of all module's resources (including resources that compose a resource) that contain the appropriate phase scope.
@Argument pLockedDependencies Whether method should be recursively applied to the module's dependencies (true = yes).
@Argument pPhases List of IPM lifecycle phases to be applied to the current module.
@Argument pSkipDependencies Whether to skip loading uninstalled dependency modules.
@Argument pDependencyGraph Tree of module's dependencies.
• method GetStudioProject(Output pProject As %Studio.Project, pDeployedCode As %Boolean = "", pDefaultDeployedValue As %Boolean = "", pProjectSuffix As %String = "") as %Status
By default (first byref argument only), creates a Studio project containing all of the module's resources. If pDeployedCode is non-empty, only includes code that should be deployed (if true) or not deployed (if false). pDefaultDeployedValue specifies the default behavior for resources with the Deploy attribute left null. pProjectSuffix is appended to the project name (which defaults to the module name, with periods replaced by underscores). The project suffix may be used (for example) to distinguish between projects for deployed and undeployed code.
• method HaveToDeploy() as %Boolean
• method IsLocked() as %Boolean
• method LifecycleGet() as %IPM.Lifecycle.Base
This is a Get accessor method for the Lifecycle property.
• method LoadDependencies(pPhaseList As %List, ByRef pParams) as %Status
• method Lock() as %Status
• method OverrideLifecycleClassSet(pValue As %Dictionary.Classname) as %Status
This is a Set accessor method for the OverrideLifecycleClass property.
• classmethod Uninstall(pModuleName As %String, pForce As %Boolean = 0, pRecurse As %Boolean = 0, ByRef pParams) as %Status
Uninstalls a named module (pModuleName). May optionally force installation (uninstalling even if required by other modules) if pForce is 1. May optionally recurse to also uninstall dependencies that are not required by other modules if pRecurse is 1. If both pForce and pRecurse are 1, then dependencies will also be uninstalled forcibly. @API.Method
• classmethod ValidateStream(pManifest As %Stream.Object, pModuleReference As %IPM.Storage.QualifiedModuleInfo, Output pModule As %IPM.Storage.Module) as %Status
Validates the module manifest in pManifest - both that it can be interpreted properly as XML, and also that the module it contains (returned in pModule) has a name and version matching the supplied pModuleReference.
• method WriteAfterInstallMessage()
• classmethod XMLNew(document As %XML.Document, node As %Integer, containerOref As %RegisteredObject = "") as %RegisteredObject
Get an instance of an XML enabled class.

You may override this method to do custom processing (such as initializing the object instance) before returning an instance of this class. However, this method should not be called directly from user code.
Arguments:
document is the document with %XML.Node or macros in %xmlDOM.inc.
nodeId is a node id of the node which defines this object. An %XML.Node object may be obtained for this node using document.GetNode(nodeId)
containerOref is the containing object instance when called from XMLImport and is "" when called from %XML.Reader for Correlate'd objects.

Queries

• query VersionRequirements(pOfModuleName As %String, pExcludeModuleNames As %List = "")
SQL Query :
select distinct %exact Dependencies_VersionString As Version,%DLIST(ModuleItem->Name) As ModuleNames
from %IPM_Storage.ModuleItem_Dependencies
where Dependencies_Name = :pOfModuleName and
(:pExcludeModuleNames is null or ModuleItem->Name not %INLIST :pExcludeModuleNames)
group by Dependencies_VersionString

Indices

•index (Name on Name) [Unique];


Copyright (c) 2025 by InterSystems Corporation. Cambridge, Massachusetts, U.S.A. All rights reserved. Confidential property of InterSystems Corporation.