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

Filter Reservations based on time and resource usage

Solved1.29K views1st June 2022Bookings Reservations SRM
2
Timothy Van Poucke [SLC] [DevOps Enabler]1.16K 31st January 2022 0 Comments

Hi Dojo,

I'm trying to select all reservations in an automation script as indicated in the image marked in green containing a specific resource. This is the algorithm that I'm using but I'm not getting any results. We are unsure about the formatting, could anyone help us out? (We already tried using a NOT(expression) but this gives compile errors)

var filter = ReservationInstanceExposers.ResourceIDsInReservationInstance
.Contains(neededResource.ID)
.AND(ReservationInstanceExposers.Status.NotEqual((int)ReservationStatus.Canceled))
.AND(ReservationInstanceExposers.Status.NotEqual((int)ReservationStatus.Ended))
.AND(ReservationInstanceExposers.Start.GreaterThanOrEqual(start).OR(ReservationInstanceExposers.End.GreaterThanOrEqual(start)))
.AND(ReservationInstanceExposers.Start.LessThanOrEqual(stop).OR(ReservationInstanceExposers.End.LessThanOrEqual(stop)));

var instances = SrmManagers.ResourceManager.GetReservationInstances(filter);

Michiel Clepkens [SLC] [DevOps Advocate] Answered question 1st June 2022

2 Answers

  • Active
  • Voted
  • Newest
  • Oldest
4
Sebastiaan Dumoulein [SLC] [DevOps Enabler]12.71K Posted 1st February 2022 1 Comment

I'm guessing from your image you want to retrieve all bookings that have overlap with a certain time range. For that, I believe you can simplify your query to use 2 conditions:

ReservationInstanceExposers.Start.LessThanOrEqual(stop).AND(ReservationInstanceExposers.End.GreaterThanOrEqual(start))

A more detailed answer on StackOverflow.

The rest of your query looks good though.

Timothy Van Poucke [SLC] [DevOps Enabler] Selected answer as best 1st February 2022
Timothy Van Poucke [SLC] [DevOps Enabler] commented 1st February 2022

Thanks Sebastiaan, This works but only if I convert my datetimes to ToUniversalTime

1
Michiel Clepkens [SLC] [DevOps Advocate]1.25K Posted 1st June 2022 0 Comments

Hi Timothy. In addition to Sebastiaan's answer, here's a function which should return the names of the planned reservations that have overlap with a defined time range.

/// <summary>
/// Gets the names of all planned reservations that have overlap with the time range defined by the begin and end arguments. In case no reservations are planned during the time range, an empty array will be returned.
/// </summary>
/// <param name="begin">The begin of the time range.</param>
/// <param name="end">The end of the time range.</param>
/// <returns>A string array that contains the names of the planned reservations.</returns>
public static string[] GetPlannedReservationNames(DateTime begin, DateTime end)
{
DateTime start = begin.ToUniversalTime();
DateTime stop = end.ToUniversalTime();

FilterElement<ReservationInstance> filter = ReservationInstanceExposers.Start.LessThanOrEqual(stop).AND(ReservationInstanceExposers.End.GreaterThanOrEqual(start));

ReservationInstance[] reservations = SrmManagers.ResourceManager.GetReservationInstances(filter);

return reservations.Select(reservation => reservation.Name).ToArray();
}

Kind regards

Michiel Clepkens [SLC] [DevOps Advocate] Edited answer 1st June 2022
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

Alarm Dashboard PDF/CSV Export 0 Answers | 0 Votes
Is the Microsoft SharePoint Connector Still Usable 0 Answers | 0 Votes
Is the Microsoft SharePoint Connector Still Usable 0 Answers | 0 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 (108) Correlation (68) Cube (150) Dashboard (194) Dashboards (188) database (83) DataMiner Cube (57) DIS (81) DMS (71) DOM (139) driver (65) DVE (55) Elastic (83) Elasticsearch (115) elements (80) Failover (104) GQI (159) HTTP (76) IDP (74) LCA (151) low code app (166) low code apps (93) lowcodeapps (75) MySQL (53) protocol (203) QAction (83) security (88) services (51) 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