/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include namespace Aws { namespace Utils { namespace Json { class JsonValue; class JsonView; } // namespace Json } // namespace Utils namespace EMRServerless { namespace Model { /** *

The driver that the job runs on.

See Also:

AWS * API Reference

*/ class JobDriver { public: AWS_EMRSERVERLESS_API JobDriver(); AWS_EMRSERVERLESS_API JobDriver(Aws::Utils::Json::JsonView jsonValue); AWS_EMRSERVERLESS_API JobDriver& operator=(Aws::Utils::Json::JsonView jsonValue); AWS_EMRSERVERLESS_API Aws::Utils::Json::JsonValue Jsonize() const; /** *

The job driver parameters specified for Spark.

*/ inline const SparkSubmit& GetSparkSubmit() const{ return m_sparkSubmit; } /** *

The job driver parameters specified for Spark.

*/ inline bool SparkSubmitHasBeenSet() const { return m_sparkSubmitHasBeenSet; } /** *

The job driver parameters specified for Spark.

*/ inline void SetSparkSubmit(const SparkSubmit& value) { m_sparkSubmitHasBeenSet = true; m_sparkSubmit = value; } /** *

The job driver parameters specified for Spark.

*/ inline void SetSparkSubmit(SparkSubmit&& value) { m_sparkSubmitHasBeenSet = true; m_sparkSubmit = std::move(value); } /** *

The job driver parameters specified for Spark.

*/ inline JobDriver& WithSparkSubmit(const SparkSubmit& value) { SetSparkSubmit(value); return *this;} /** *

The job driver parameters specified for Spark.

*/ inline JobDriver& WithSparkSubmit(SparkSubmit&& value) { SetSparkSubmit(std::move(value)); return *this;} /** *

The job driver parameters specified for Hive.

*/ inline const Hive& GetHive() const{ return m_hive; } /** *

The job driver parameters specified for Hive.

*/ inline bool HiveHasBeenSet() const { return m_hiveHasBeenSet; } /** *

The job driver parameters specified for Hive.

*/ inline void SetHive(const Hive& value) { m_hiveHasBeenSet = true; m_hive = value; } /** *

The job driver parameters specified for Hive.

*/ inline void SetHive(Hive&& value) { m_hiveHasBeenSet = true; m_hive = std::move(value); } /** *

The job driver parameters specified for Hive.

*/ inline JobDriver& WithHive(const Hive& value) { SetHive(value); return *this;} /** *

The job driver parameters specified for Hive.

*/ inline JobDriver& WithHive(Hive&& value) { SetHive(std::move(value)); return *this;} private: SparkSubmit m_sparkSubmit; bool m_sparkSubmitHasBeenSet = false; Hive m_hive; bool m_hiveHasBeenSet = false; }; } // namespace Model } // namespace EMRServerless } // namespace Aws