Gets the list of calc script objects that are accessible to a user. The progammer needs to use EsbGetNextItem() to access the list of available scripts.
Syntax
EsbGetCalcList (hCtx, UserName, AppName, DbName, isAllCalcs, pItems) ByVal hCtx As Long ByVal UserName As String ByVal AppName As String ByVal DbName As String isAllCalcs As Integer pItems As Integer
| Parameter | Description |
|---|---|
hCtx | VB API context handle. |
UserName | User name. |
AppName | Application name. |
DbName | Database name. If an empty string, uses Application sub-directory |
isAllCalcs | Integer that contains the AllowAllCalcs flag. If AllowAllCalcs is set to ESB_FALSE, the user can access all calc script objects. Otherwise, the user can only access those script objects specified in the CalcList argument. |
pItems | Integer that contains the count of available calc script objects. |
Notes
In order to access any calc script objects, the specified user must have at least calculate access to the appropriate database.
If the value returned in pAllCalcs is TRUE, then the value returned in pItems is zero.
Return Value
If successful, returns sts=0 and returns the user's AllowAllCalcs setting in pAllCalcs. If isAllCalcs is equal to ESB_FALSE, pItems contains the count of the available calc script objects. Access the list of calc script object names with EsbGetNextItem().
If isAllCalcs is equal to ESB_TRUE, then pItems will return 0 and the programmer will need to call a combination fo EsbListObjects() (using type ESB_OBJTYPE_CALCSCRIPT) and EsbGetObjectInfo() for each returned object.
Access
This function requires callers to have Database Design privilege (ESB_PRIV_DBDESIGN) for the specified database, unless they are getting their own calc list.
Example
Declare Function EsbGetCalcList Lib "ESBAPIN" (ByVal hCtx As Long, ByVal User As String, ByVal AppName As String, ByVal DbName As String, AllCalcs As Integer, Items As Integer) As Long
Sub ESB_GetCalcList()
Dim Items As Integer
Dim AppName As String
Dim DbName As String
Dim User As String
Dim AllCalcs As Integer
Dim ObjName As String * ESB_OBJNAMELEN
Dim sts As Long
Dim ObjType As Long
Dim ObjectInfo As ESB_OBJINFO_T ObjType = ESB_OBJTYPE_CALCSCRIPT AppName = "Sample"
DbName = "Basic"
User = "test_user" ' Has 'calculate' access to Sample->Basic ' If user passed in has access to everything,
' then Items will ALWAYS be set to '0'!
' In that case, use EsbListObjects()
' (of type ESB_OBJTYPE_CALCSCRIPT, and
' then EsbGetObjectInfo()!
sts = EsbGetCalcList(hCtx, User, AppName, DbName, AllCalcs, Items)
If AllCalcs = ESB_NO Then
frmMain.lstInfo.AddItem "Number of calc script items returned: " & Items
frmMain.lstInfo.AddItem "--------------------------------------------------"
For n = 1 To Items
sts = EsbGetNextItem(hCtx, ESB_OBJNAME_TYPE, ByVal ObjName)
If sts <> 0 Then MsgBox "Failure in EsbGetNextItem(): " & sts: Exit Sub
sts = EsbGetObjectInfo(hCtx, ObjType, AppName, DbName, ObjName, ObjectInfo)
If sts <> 0 Then MsgBox "Failure in EsbGetObjectInfo(): " & sts: Exit Sub
frmMain.lstInfo.AddItem ObjectInfo.Name
frmMain.lstInfo.AddItem ObjectInfo.Type
frmMain.lstInfo.AddItem "----------"
Next
Else
frmMain.lstInfo.AddItem "You need to call EsbListObjects of type ESB_OBJTYPE_CALCSTRIPT"
End If
End SubSee Also