mirror of
				https://github.com/Icinga/icinga2.git
				synced 2025-10-25 01:03:54 +02:00 
			
		
		
		
	
							parent
							
								
									237fd520db
								
							
						
					
					
						commit
						01fea22c77
					
				| @ -1385,6 +1385,7 @@ Configuration Attributes: | |||||||
|   fixed                     | Boolean               | **Optional.** Whether this is a fixed downtime. Defaults to `true`. |   fixed                     | Boolean               | **Optional.** Whether this is a fixed downtime. Defaults to `true`. | ||||||
|   duration                  | Duration              | **Optional.** How long the downtime lasts. Only has an effect for flexible (non-fixed) downtimes. |   duration                  | Duration              | **Optional.** How long the downtime lasts. Only has an effect for flexible (non-fixed) downtimes. | ||||||
|   ranges                    | Dictionary            | **Required.** A dictionary containing information which days and durations apply to this timeperiod. |   ranges                    | Dictionary            | **Required.** A dictionary containing information which days and durations apply to this timeperiod. | ||||||
|  |   child\_options            | String                | **Optional.** Schedule child downtimes. `DowntimeNoChildren` does not do anything, `DowntimeTriggeredChildren` schedules child downtimes triggered by this downtime, `DowntimeTriggeredChildren` schedules non-triggered downtimes. Defaults to `DowntimeNoChildren`. | ||||||
| 
 | 
 | ||||||
| ScheduledDowntime objects have composite names, i.e. their names are based | ScheduledDowntime objects have composite names, i.e. their names are based | ||||||
| on the `host_name` and `service_name` attributes and the | on the `host_name` and `service_name` attributes and the | ||||||
|  | |||||||
| @ -1117,7 +1117,7 @@ Send a `POST` request to the URL endpoint `/v1/actions/schedule-downtime`. | |||||||
|   fixed         | Boolean   | **Optional.** Defaults to `true`. If true, the downtime is `fixed` otherwise `flexible`. See [downtimes](08-advanced-topics.md#downtimes) for more information. |   fixed         | Boolean   | **Optional.** Defaults to `true`. If true, the downtime is `fixed` otherwise `flexible`. See [downtimes](08-advanced-topics.md#downtimes) for more information. | ||||||
|   duration      | Number    | **Required for flexible downtimes.** Duration of the downtime in seconds if `fixed` is set to false. |   duration      | Number    | **Required for flexible downtimes.** Duration of the downtime in seconds if `fixed` is set to false. | ||||||
|   trigger\_name | String    | **Optional.** Sets the trigger for a triggered downtime. See [downtimes](08-advanced-topics.md#downtimes) for more information on triggered downtimes. |   trigger\_name | String    | **Optional.** Sets the trigger for a triggered downtime. See [downtimes](08-advanced-topics.md#downtimes) for more information on triggered downtimes. | ||||||
|   child\_options | Number   | **Optional.** Schedule child downtimes. `0` does not do anything, `1` schedules child downtimes triggered by this downtime, `2` schedules non-triggered downtimes. Defaults to `0`. |   child\_options| String    | **Optional.** Schedule child downtimes. `DowntimeNoChildren` does not do anything, `DowntimeTriggeredChildren` schedules child downtimes triggered by this downtime, `DowntimeTriggeredChildren` schedules non-triggered downtimes. Defaults to `DowntimeNoChildren`. | ||||||
| 
 | 
 | ||||||
| In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters) must be provided. The valid types for this action are `Host` and `Service`. | In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters) must be provided. The valid types for this action are `Host` and `Service`. | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -366,30 +366,30 @@ Dictionary::Ptr ApiActions::ScheduleDowntime(const ConfigObject::Ptr& object, | |||||||
| 	}); | 	}); | ||||||
| 
 | 
 | ||||||
| 	/* Schedule downtime for all child objects. */ | 	/* Schedule downtime for all child objects. */ | ||||||
| 	int childOptions = 0; | 	DowntimeChildOptions childOptions = DowntimeNoChildren; | ||||||
| 	if (params->Contains("child_options")) | 	if (params->Contains("child_options")) | ||||||
| 		childOptions = HttpUtility::GetLastParameter(params, "child_options"); | 		childOptions = Downtime::ChildOptionsFromValue(HttpUtility::GetLastParameter(params, "child_options")); | ||||||
| 
 | 
 | ||||||
| 	if (childOptions > 0) { | 	if (childOptions != DowntimeNoChildren) { | ||||||
| 		/* '1' schedules child downtimes triggered by the parent downtime.
 | 		/* 'DowntimeTriggeredChildren' schedules child downtimes triggered by the parent downtime.
 | ||||||
| 		 * '2' schedules non-triggered downtimes for all children. | 		 * 'DowntimeNonTriggeredChildren' schedules non-triggered downtimes for all children. | ||||||
| 		 */ | 		 */ | ||||||
| 		if (childOptions == 1) | 		if (childOptions == DowntimeTriggeredChildren) | ||||||
| 			triggerName = downtimeName; | 			triggerName = downtimeName; | ||||||
| 
 | 
 | ||||||
| 		Log(LogCritical, "ApiActions") | 		Log(LogNotice, "ApiActions") | ||||||
| 			<< "Processing child options " << childOptions << " for downtime " << downtimeName; | 			<< "Processing child options " << childOptions << " for downtime " << downtimeName; | ||||||
| 
 | 
 | ||||||
| 		ArrayData childDowntimes; | 		ArrayData childDowntimes; | ||||||
| 
 | 
 | ||||||
| 		for (const Checkable::Ptr& child : checkable->GetAllChildren()) { | 		for (const Checkable::Ptr& child : checkable->GetAllChildren()) { | ||||||
| 			Log(LogCritical, "ApiActions") | 			Log(LogNotice, "ApiActions") | ||||||
| 				<< "Scheduling downtime for child object " << child->GetName(); | 				<< "Scheduling downtime for child object " << child->GetName(); | ||||||
| 
 | 
 | ||||||
| 			String childDowntimeName = Downtime::AddDowntime(child, author, comment, startTime, endTime, | 			String childDowntimeName = Downtime::AddDowntime(child, author, comment, startTime, endTime, | ||||||
| 				fixed, triggerName, duration); | 				fixed, triggerName, duration); | ||||||
| 
 | 
 | ||||||
| 			Log(LogCritical, "ApiActions") | 			Log(LogNotice, "ApiActions") | ||||||
| 				<< "Add child downtime '" << childDowntimeName << "'."; | 				<< "Add child downtime '" << childDowntimeName << "'."; | ||||||
| 
 | 
 | ||||||
| 			Downtime::Ptr childDowntime = Downtime::GetByName(childDowntimeName); | 			Downtime::Ptr childDowntime = Downtime::GetByName(childDowntimeName); | ||||||
|  | |||||||
| @ -42,6 +42,15 @@ boost::signals2::signal<void (const Downtime::Ptr&)> Downtime::OnDowntimeTrigger | |||||||
| 
 | 
 | ||||||
| REGISTER_TYPE(Downtime); | REGISTER_TYPE(Downtime); | ||||||
| 
 | 
 | ||||||
|  | INITIALIZE_ONCE(&Downtime::StaticInitialize); | ||||||
|  | 
 | ||||||
|  | void Downtime::StaticInitialize() | ||||||
|  | { | ||||||
|  | 	ScriptGlobal::Set("DowntimeNoChildren", "DowntimeNoChildren"); | ||||||
|  | 	ScriptGlobal::Set("DowntimeTriggeredChildren", "DowntimeTriggeredChildren"); | ||||||
|  | 	ScriptGlobal::Set("DowntimeNonTriggeredChildren", "DowntimeNonTriggeredChildren"); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| String DowntimeNameComposer::MakeName(const String& shortName, const Object::Ptr& context) const | String DowntimeNameComposer::MakeName(const String& shortName, const Object::Ptr& context) const | ||||||
| { | { | ||||||
| 	Downtime::Ptr downtime = dynamic_pointer_cast<Downtime>(context); | 	Downtime::Ptr downtime = dynamic_pointer_cast<Downtime>(context); | ||||||
| @ -420,3 +429,20 @@ void Downtime::ValidateEndTime(const Lazy<Timestamp>& lvalue, const ValidationUt | |||||||
| 	if (lvalue() <= 0) | 	if (lvalue() <= 0) | ||||||
| 		BOOST_THROW_EXCEPTION(ValidationError(this, { "end_time" }, "End time must be greater than 0.")); | 		BOOST_THROW_EXCEPTION(ValidationError(this, { "end_time" }, "End time must be greater than 0.")); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | DowntimeChildOptions Downtime::ChildOptionsFromValue(const Value& options) | ||||||
|  | { | ||||||
|  | 	if (options == "DowntimeNoChildren") | ||||||
|  | 		return DowntimeNoChildren; | ||||||
|  | 	else if (options == "DowntimeTriggeredChildren") | ||||||
|  | 		return DowntimeTriggeredChildren; | ||||||
|  | 	else if (options == "DowntimeNonTriggeredChildren") | ||||||
|  | 		return DowntimeNonTriggeredChildren; | ||||||
|  | 	else if (options.IsNumber()) { | ||||||
|  | 		int number = options; | ||||||
|  | 		if (number >= 0 && number <= 2) | ||||||
|  | 			return static_cast<DowntimeChildOptions>(number); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	BOOST_THROW_EXCEPTION(std::invalid_argument("Invalid child option specified")); | ||||||
|  | } | ||||||
|  | |||||||
| @ -28,6 +28,13 @@ | |||||||
| namespace icinga | namespace icinga | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
|  | enum DowntimeChildOptions | ||||||
|  | { | ||||||
|  | 	DowntimeNoChildren, | ||||||
|  | 	DowntimeTriggeredChildren, | ||||||
|  | 	DowntimeNonTriggeredChildren | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| /**
 | /**
 | ||||||
|  * A downtime. |  * A downtime. | ||||||
|  * |  * | ||||||
| @ -51,6 +58,8 @@ public: | |||||||
| 	bool IsExpired() const; | 	bool IsExpired() const; | ||||||
| 	bool HasValidConfigOwner() const; | 	bool HasValidConfigOwner() const; | ||||||
| 
 | 
 | ||||||
|  | 	static void StaticInitialize(); | ||||||
|  | 
 | ||||||
| 	static int GetNextDowntimeID(); | 	static int GetNextDowntimeID(); | ||||||
| 
 | 
 | ||||||
| 	static String AddDowntime(const intrusive_ptr<Checkable>& checkable, const String& author, | 	static String AddDowntime(const intrusive_ptr<Checkable>& checkable, const String& author, | ||||||
| @ -65,6 +74,8 @@ public: | |||||||
| 
 | 
 | ||||||
| 	static String GetDowntimeIDFromLegacyID(int id); | 	static String GetDowntimeIDFromLegacyID(int id); | ||||||
| 
 | 
 | ||||||
|  | 	static DowntimeChildOptions ChildOptionsFromValue(const Value& options); | ||||||
|  | 
 | ||||||
| protected: | protected: | ||||||
| 	void OnAllConfigLoaded() override; | 	void OnAllConfigLoaded() override; | ||||||
| 	void Start(bool runtimeCreated) override; | 	void Start(bool runtimeCreated) override; | ||||||
|  | |||||||
| @ -191,9 +191,35 @@ void ScheduledDowntime::CreateNextDowntime() | |||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	Downtime::AddDowntime(GetCheckable(), GetAuthor(), GetComment(), | 	String downtimeName = Downtime::AddDowntime(GetCheckable(), GetAuthor(), GetComment(), | ||||||
| 		segment.first, segment.second, | 		segment.first, segment.second, | ||||||
| 		GetFixed(), String(), GetDuration(), GetName(), GetName()); | 		GetFixed(), String(), GetDuration(), GetName(), GetName()); | ||||||
|  | 
 | ||||||
|  | 	Downtime::Ptr downtime = Downtime::GetByName(downtimeName); | ||||||
|  | 
 | ||||||
|  | 	int childOptions = Downtime::ChildOptionsFromValue(GetChildOptions()); | ||||||
|  | 	if (childOptions > 0) { | ||||||
|  | 		/* 'DowntimeTriggeredChildren' schedules child downtimes triggered by the parent downtime.
 | ||||||
|  | 		 * 'DowntimeNonTriggeredChildren' schedules non-triggered downtimes for all children. | ||||||
|  | 		 */ | ||||||
|  | 		String triggerName; | ||||||
|  | 		if (childOptions == 1) | ||||||
|  | 			triggerName = downtimeName; | ||||||
|  | 
 | ||||||
|  | 		Log(LogNotice, "ScheduledDowntime") | ||||||
|  | 				<< "Processing child options " << childOptions << " for downtime " << downtimeName; | ||||||
|  | 
 | ||||||
|  | 		for (const Checkable::Ptr& child : GetCheckable()->GetAllChildren()) { | ||||||
|  | 			Log(LogNotice, "ScheduledDowntime") | ||||||
|  | 				<< "Scheduling downtime for child object " << child->GetName(); | ||||||
|  | 
 | ||||||
|  | 			String childDowntimeName = Downtime::AddDowntime(child, GetAuthor(), GetComment(), | ||||||
|  | 				segment.first, segment.second, GetFixed(), triggerName, GetDuration(), GetName(), GetName()); | ||||||
|  | 
 | ||||||
|  | 			Log(LogNotice, "ScheduledDowntime") | ||||||
|  | 				<< "Add child downtime '" << childDowntimeName << "'."; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ScheduledDowntime::ValidateRanges(const Lazy<Dictionary::Ptr>& lvalue, const ValidationUtils& utils) | void ScheduledDowntime::ValidateRanges(const Lazy<Dictionary::Ptr>& lvalue, const ValidationUtils& utils) | ||||||
| @ -226,3 +252,13 @@ void ScheduledDowntime::ValidateRanges(const Lazy<Dictionary::Ptr>& lvalue, cons | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void ScheduledDowntime::ValidateChildOptions(const Lazy<Value>& lvalue, const ValidationUtils& utils) | ||||||
|  | { | ||||||
|  | 	ObjectImpl<ScheduledDowntime>::ValidateChildOptions(lvalue, utils); | ||||||
|  | 
 | ||||||
|  | 	try { | ||||||
|  | 		Downtime::ChildOptionsFromValue(lvalue()); | ||||||
|  | 	} catch (const std::exception&) { | ||||||
|  | 		BOOST_THROW_EXCEPTION(ValidationError(this, { "child_options" }, "Invalid child_options specified")); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @ -49,6 +49,7 @@ public: | |||||||
| 	static void EvaluateApplyRules(const intrusive_ptr<Service>& service); | 	static void EvaluateApplyRules(const intrusive_ptr<Service>& service); | ||||||
| 
 | 
 | ||||||
| 	void ValidateRanges(const Lazy<Dictionary::Ptr>& lvalue, const ValidationUtils& utils) override; | 	void ValidateRanges(const Lazy<Dictionary::Ptr>& lvalue, const ValidationUtils& utils) override; | ||||||
|  | 	void ValidateChildOptions(const Lazy<Value>& lvalue, const ValidationUtils& utils) override; | ||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
| 	void OnAllConfigLoaded() override; | 	void OnAllConfigLoaded() override; | ||||||
|  | |||||||
| @ -77,6 +77,10 @@ class ScheduledDowntime : CustomVarObject < ScheduledDowntimeNameComposer | |||||||
| 		default {{{ return true; }}} | 		default {{{ return true; }}} | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
|  | 	[config] Value child_options { | ||||||
|  | 	    default {{{ return "DowntimeNoChildren"; }}} | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
| 	[config, required] Dictionary::Ptr ranges; | 	[config, required] Dictionary::Ptr ranges; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user