Fundamentals COM

Basics for working with COM / ActiveX on Windows

Product line

Standard

|

Expert

Operating mode

CLOUD ABO

|

ON-PREMISES

Modules

Services & CRM

Budget & Phases

Purchases

Resource Planning

Business Intelligence

Created: 26.06.2003
Machine translated
Updated: 28.12.2023 | Introduction supplemented and rewritten.

COM (Component Object Model) is a technology developed by Microsoft for interprocess communication under Windows (Source ). The Vertec desktop and cloud apps can be accessed via a COM interface (or ActiveX interface) and thus remotely controlled by other software running under Windows (especially all locally installed Microsoft Office apps). The apps serve as “out-of-process” COM servers for the respective applications.

In principle, all entries in Vertec can also be entered from an external program and imported into Vertec via the COM interface. See Import and export examples Examples for some Excel examples for handling the Vertec COM interface.

For a description of the available interfaces, see Com interfaces .

Vertec Type Library

Both Vertec.Desktop.exe and Vertec.Cloud.exe contain the Vertec Type Library, which can be included in the external application to gain access to the object catalog, code completion, and compile-time type checking.

The difference between desktop app and cloud app is that the cloud app offers a COM server locally, even though there is no business logic at all. This is simulated by a proxy to the actual COM server running on the server in the Vertec session. The traffic runs over the normal data line (and is therefore not suitable for data migrations or larger amounts of data).

For the use of the COM interface, the integration of the Type Library is not necessary or, in the case of the cloud app, also not possible, because there is no business logic and the connection to the COM server is made with a proxy.

The desktop app can also be accessed without a connection to the Type Library.

We always recommend the use without Type Library, as this application can be used with the desktop app and the cloud app or on Windows both in the cloud suite and on-premises.

This means that there is no direct reference to the types such as e.g. IVtcObject, App etc. can be accessed, since the system does not know them without a Type Library. The declaration of objects, object lists, session etc. therefore takes place on Object. Instead of:

Dim Projektbearbeiter as IVtcObject

So you write:

Dim Projektbearbeiter as Object

The corresponding Com interfaces are available during operation as soon as the object is loaded.

Different interface names in desktop app and cloud app

Since the COM server is available directly in the desktop app and via proxy in the cloud app, different interface names result. However, the usage is identical.

Desktop App Cloud App
app ComCoClass
IVtcObject VtcObjectProxy
IVtcObjectList VtcObjectListProxy
ITimEditor TimEditorProxy
...  

For a detailed description, see Com interfaces .

Transfer of variants to the com proxy

In features that accept Vertec objects as parameters, no Variant declared objects are passed, otherwise the message Invalid procedure call or invalid argument appears .

Are the Vertec objects as Object declared, everything works smoothly.