После еще одного исследования я нашел решение:
Использование функции CallByName:
Ссылка MSDN
Это позволило мне иметь одну функцию, которая фактически выполняла 12 отдельных функций, и позволило мне иметь централизованную систему обработки ошибок:
Private Function RunRemoteRequest(ByVal functionName As String, ByVal service_url As String, ByVal args() As Object) As Object
Dim retnVal As Object
Dim success As Boolean = False
While success = False And Me._connAttemptCount < MAX_ATTEMPTS
Try
retnVal = CallByName(remProxy, functionName, Method, args)
success = True
Me._connAttemptCount = 0
Catch ex As Exception
Me._connAttemptCount += 1
If ex.Message = "Error I am looking for" Then
Me.Login()
Else
log.Error("Error in RunRemoteRequest(" & functionName & ").", ex)
End If
End Try
End While
RunRemoteRequest = retnVal
End Function
Обратите внимание, что вам необходимо иметь команду Imports Microsoft.VisualBasic.CallType в модуле / классе, над которым вы работаете.