Skip to content
DataMiner DoJo

More results...

Generic selectors
Exact matches only
Search in title
Search in content
Post Type Selectors
Search in posts
Search in pages
Search in posts
Search in pages
Log in
Menu
  • Blog
  • Questions
  • Learning
    • E-learning Courses
    • Open Classroom Training
    • Certification
      • DataMiner Fundamentals
      • DataMiner Configurator
      • DataMiner Automation
      • Scripts & Connectors Developer: HTTP Basics
      • Scripts & Connectors Developer: SNMP Basics
      • Visual Overview – Level 1
      • Verify a certificate
    • Tutorials
    • Video Library
    • Books We Like
    • >> Go to DataMiner Docs
  • Expert Center
    • Solutions & Use Cases
      • Solutions
      • Use Case Library
    • Markets & Industries
      • Media production
      • Government & defense
      • Content distribution
      • Service providers
      • Partners
      • OSS/BSS
    • DataMiner Insights
      • Security
      • Integration Studio
      • System Architecture
      • DataMiner Releases & Updates
      • DataMiner Apps
    • Agile
      • Agile Webspace
      • Everything Agile
        • The Agile Manifesto
        • Best Practices
        • Retro Recipes
      • Methodologies
        • The Scrum Framework
        • Kanban
        • Extreme Programming
      • Roles
        • The Product Owner
        • The Agile Coach
        • The Quality & UX Coach (QX)
    • DataMiner DevOps Professional Program
  • Downloads
  • More
    • Feature Suggestions
    • Climb the leaderboard!
    • Swag Shop
    • Contact
      • General Inquiries
      • DataMiner DevOps Support
      • Commercial Requests
    • Global Feedback Survey
  • PARTNERS
    • All Partners
    • Technology Partners
    • Strategic Partner Program
    • Deal Registration
  • >> Go to dataminer.services

Is it possible to log data using the IDms Object?

Solved1.45K views25th January 2023DmsMonitors IDms log
6
Reza Biglari [DevOps Advocate]652 24th January 2023 3 Comments

With the protocol object, it is possible to log out runtime data using the protocol.Log() method. However, when using DMS Monitors, use of SLProtocol is strictly prohibited which raises the question whether it is possible to log data using the IDms object?

Reza Biglari [DevOps Advocate] Selected answer as best 25th January 2023
Reza Biglari [DevOps Advocate] commented 24th January 2023

Checking the IDmsElement, this also doesn’t appear to have logging capabilities?

Joey Vanhalst [SLC] [DevOps Advocate] commented 25th January 2023

Could you share the code/method where you would like to include logging? It’s not fully clear to me what/when you would like to log.

Reza Biglari [DevOps Advocate] commented 25th January 2023

var dms = protocol.GetDms();
var remoteElement = dms.GetElement(new DmsElementId(elementId));
remoteElement.GetStandaloneParameter(12000).StartValueMonitor(protocol, change =>
{
var changeValue = change.Value;
//Log changeValue here.
};

2 Answers

  • Active
  • Voted
  • Newest
  • Oldest
4
Avatar photo
Jan Staelens [SLC] [DevOps Advocate]889 Posted 25th January 2023 1 Comment

We've made some progress to allow SLProtocol to be used after you've finished the Run method. (so during the Monitor Handler for example). This in ongoing efforts to allow more communication directly from QActions.

An initial release of these change is present since DataMiner:

Release Note

Main Release Version

10.3.0

Feature Release Version

10.2.9

So theoretically since those versions you should be able to use SLProtocol within the handlers of the Monitors. You'd need to remove the 'static' from the QAction, turning it into an instanced QAction and then make a private SLProtocol protocol variable and make sure you always update that variable every time the Run begins.

IMPORTANT: This is still in an 'alpha' version and there are some known race conditions on element stop or multithreaded timers that can cause a SLScripting crash.

But in most cases this will now actually work just fine. You could mitigate the race conditions by implementing the IDisposable on the QAction (also supported since the above mentioned DataMiner versions) and then making the protocol variable null and making sure to always check for null before running the handler code.

If you'd prefer to use it later, when we've worked our the corner cases and bugs and its more stable then currently I would recommend installed something like the SeriLog NuGet and logging directly to your own file.

Any internal logging mechanisms have not been made public for use right now.

Reza Biglari [DevOps Advocate] Posted new comment 26th January 2023
Reza Biglari [DevOps Advocate] commented 26th January 2023

Thanks Jan, this is good news, I’ll be following this development with keen interest. I might also try some prototypes with the suggestions you’ve made in the meantime.

You are viewing 1 out of 2 answers, click here to view all answers.
Please login to be able to comment or post an answer.

My DevOps rank

DevOps Members get more insights on their profile page.

My user earnings

0 Dojo credits

Spend your credits in our swag shop.

0 Reputation points

Boost your reputation, climb the leaderboard.

Promo banner DataMiner DevOps Professiona Program
DataMiner Integration Studio (DIS)
Empower Katas

Recent questions

Correlation Engine: “Test rule” doesn’t result in a hit, despite functional rule 1 Answer | 3 Votes
When using the Setter = true attribute, will the copy action always be executed first? 1 Answer | 3 Votes
Multiple Set on Table parameters for DVE’s 1 Answer | 2 Votes

Question Tags

adl2099 (115) alarm (62) Alarm Console (82) alarms (100) alarm template (83) Automation (223) automation scipt (111) Automation script (167) backup (71) Cassandra (180) Connector (109) Correlation (69) Correlation rule (52) Cube (150) Dashboard (194) Dashboards (188) database (83) DataMiner Cube (57) DIS (81) DMS (71) DOM (140) driver (65) DVE (56) Elastic (83) Elasticsearch (115) elements (80) Failover (104) GQI (159) HTTP (76) IDP (74) LCA (152) low code app (166) low code apps (93) lowcodeapps (75) MySQL (53) protocol (203) QAction (83) security (88) SNMP (86) SRM (337) table (54) trending (87) upgrade (62) Visio (539) Visual Overview (345)
Privacy Policy • Terms & Conditions • Contact

© 2025 Skyline Communications. All rights reserved.

DOJO Q&A widget

Can't find what you need?

? Explore the Q&A DataMiner Docs

[ Placeholder content for popup link ] WordPress Download Manager - Best Download Management Plugin