Operator Logs to SQL

Has Citect (PlantSCADA) setup anyway to have defauts to log operator actions robustly and completely? 

Most mainstreams SCADA;s now have this capability, however with CitectSCADA/PlantSCADA you can build up your own SuperGenies hence it seems the only way is to build this in is as you build each SuperGenie.  Whilst this is flexibible, it is also problematic as it has to be tested to every action...... 

Is it possible to log all data written to tags by reading a queue or something??  Even  if you could would the logging necessarily make sense?

My experience is this is not possible, but want to check with the wider community.

Anyone got any great examples of operator action logs, ie who did what and when... 

Regards,

Mike

  • There is no open-box log device in type of SQL but it is possible for you to set it up yourself.

    You could refer to the following KB article for how-to set up a device of SQL-DEV type.

    https://softwaresupportsp.aveva.com/#/knowledgebase/details/000029969?lang=en_us

    Write a your own Cicode function to decide what needs to be logged.

    Then in configuration of the security roles, call your function in Entry Command and Exit Command for capturing user sign in/out activities. 

    Similarly, you can log other messages into this log device, such as tag write operations. For example, use cicode function TagSubscribe with a callback function. When the value of the subscribed tag changes, the callback function will be fired. Then you get the value and log it along with other info into the device.

    Hope this would help.

  • Hi Mike,

    PlantSCADA has the Tag Write Event queue which can intercept all writes to IO devices, and you can take the context and add to some record.  See here for details: TagWriteEventQue | Tag Functions | Cicode (aveva.com)

    Also, I recommend logging to the SOE table as this allows you to place the logs in line with other significant events.  See here for details: SOEEventAdd | Sequence of Events Functions | Cicode (aveva.com).   Note that for SOEEventAdd to work, the event needs to be associated with an alarm.  There was some talk about removing this restriction, but it seems they might not have gotten around to it yet.  So an easy way to work around this is to have a dummy alarm in each piece of equipment with a consistent name which tag write events are logged against.  I have used this mechanism successfully on several projects.

    Hope this helps

    Stuart

  • Although you can use SOEEventAdd with alarms, you don't have to. Here's a Cicode function I used in the past to log user logins to SOE. You just leave the alarm tag argument blank.


    // FUNCTION LoginToSummary
    // This function displays a message on the summary page when the login is changed.

    FUNCTION
    LoginToSummary(INT bLogin);
    STRING sCurrentUser;
    STRING sNewUser;
    STRING sMessage;

    sCurrentUser = UserInfo(2);
    IF bLogin = TRUE THEN
    IF LoginForm() = 0 THEN
    sNewUser = UserInfo(2);
    IF sCurrentUser = "" THEN
    sMessage = sNewUser + " Logged In";
    ELSE
    sMessage = sCurrentUser + " Logged Out, " + sNewUser + " Logged In";
    END
    ELSE
    sMessage = "Failed to Log In";
    END
    ELSE //Log out
    IF Logout() = 0 THEN
    sMessage = sCurrentUser + " Logged Out";
    ELSE
    sMessage = "Failed to Log Out " + sCurrentUser;
    END
    END

    SOEEventAdd(TimestampCurrent(), sMessage, "");
    END
  • That's interesting Eric.  We also found that we couldn't use the SOEEventAdd function unless we specified an alarm tag (that was tested using 2018 R2, but I don't know if that's changed since then).

    Note that the SOE logs will obviously get archived at some point (along with the rest of the alarms), so people need to keep that in mind.

  • Thanks Eric, quite correct, if you don't specify an alarm, an entry is still created, but it has no equipment context.  If that isn't a requirement then that's fine, but I think in modern control systems, this would be missing an important feature!