/* * FreeRTOS V202212.00 * Copyright (C) 2020 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Permission is hereby granted, free of charge, to any person obtaining a copy of * this software and associated documentation files (the "Software"), to deal in * the Software without restriction, including without limitation the rights to * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of * the Software, and to permit persons to whom the Software is furnished to do so, * subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * * https://www.FreeRTOS.org * https://github.com/FreeRTOS * */ #ifndef DEMO_CONFIG_H #define DEMO_CONFIG_H /* FreeRTOS config include. */ #include "FreeRTOSConfig.h" /**************************************************/ /******* DO NOT CHANGE the following order ********/ /**************************************************/ /* Include logging header files and define logging macros in the following order: * 1. Include the header file "logging_levels.h". * 2. Define the LIBRARY_LOG_NAME and LIBRARY_LOG_LEVEL macros depending on * the logging configuration for DEMO. * 3. Include the header file "logging_stack.h", if logging is enabled for DEMO. */ #include "logging_levels.h" /* Logging configuration for the Demo. */ #ifndef LIBRARY_LOG_NAME #define LIBRARY_LOG_NAME "JobsDemo" #endif #ifndef LIBRARY_LOG_LEVEL #define LIBRARY_LOG_LEVEL LOG_INFO #endif /* Prototype for the function used to print to console on Windows simulator * of FreeRTOS. * The function prints to the console before the network is connected; * then a UDP port after the network has connected. */ extern void vLoggingPrintf( const char * pcFormatString, ... ); /* Map the SdkLog macro to the logging function to enable logging * on Windows simulator. */ #ifndef SdkLog #define SdkLog( message ) vLoggingPrintf message #endif #include "logging_stack.h" /************ End of logging configuration ****************/ /** * @brief The Thing resource registered on your AWS IoT account to use in the demo. * A Thing resource is required to communicate with the AWS IoT Jobs service. * * @note The Things associated with your AWS account can be found in the * AWS IoT console under Manage/Things, or using the ListThings REST API (that can * be called with the AWS CLI command line tool). * * #define democonfigTHING_NAME "...insert here..." */ /** * @brief The MQTT client identifier used in this example. Each client identifier * must be unique so edit as required to ensure no two clients connecting to the * same broker use the same client identifier. * * #define democonfigCLIENT_IDENTIFIER "...insert here..." */ /** * @brief The AWS IoT broker endpoint to connect to in the demo. * * @note Your AWS IoT Core endpoint can be found in the AWS IoT console under * Settings/Custom Endpoint, or using the describe-endpoint REST API (with * AWS CLI command line tool). * * #define democonfigMQTT_BROKER_ENDPOINT "...insert here..." */ /** * @brief The port to use for the demo. * * In general, port 8883 is for secured MQTT connections. * * @note Port 443 requires use of the ALPN TLS extension with the ALPN protocol * name. Using ALPN with this demo would require additional changes, including * setting the `pAlpnProtos` member of the `NetworkCredentials_t` struct before * forming the TLS connection. When using port 8883, ALPN is not required. * * #define democonfigMQTT_BROKER_PORT ( insert here. ) */ /** * @brief Root CA certificate of AWS IoT broker. * * This certificate is used to identify the AWS IoT server and is publicly * available. Refer to the link below. * https://www.amazontrust.com/repository/AmazonRootCA1.pem * * @note This certificate should be PEM-encoded. * * Must include the PEM header and footer: * "-----BEGIN CERTIFICATE-----\n"\ * "...base64 data...\n"\ * "-----END CERTIFICATE-----\n" * * #define democonfigROOT_CA_PEM "...insert here..." */ /** * @brief Client certificate. * * Please refer to the AWS documentation below for details * regarding client authentication. * https://docs.aws.amazon.com/iot/latest/developerguide/client-authentication.html * * @note This certificate should be PEM-encoded. * * Must include the PEM header and footer: * "-----BEGIN CERTIFICATE-----\n"\ * "...base64 data...\n"\ * "-----END CERTIFICATE-----\n" * * #define democonfigCLIENT_CERTIFICATE_PEM "...insert here..." */ /** * @brief Client's private key. * * Please refer to the AWS documentation below for details * regarding client authentication. * https://docs.aws.amazon.com/iot/latest/developerguide/client-authentication.html * * @note This private key should be PEM-encoded. * * Must include the PEM header and footer: * "-----BEGIN RSA PRIVATE KEY-----\n"\ * "...base64 data...\n"\ * "-----END RSA PRIVATE KEY-----\n" * * #define democonfigCLIENT_PRIVATE_KEY_PEM "...insert here..." */ /** * @brief The username value for authenticating client to the MQTT broker when * username/password based client authentication is used. * * Please refer to the AWS IoT documentation below for * details regarding client authentication with a username and password. * https://docs.aws.amazon.com/iot/latest/developerguide/custom-authentication.html * An authorizer setup needs to be done, as mentioned in the above link, to use * username/password based client authentication. * * #define democonfigCLIENT_USERNAME "...insert here..." */ /** * @brief The password value for authenticating client to the MQTT broker when * username/password based client authentication is used. * * Please refer to the AWS IoT documentation below for * details regarding client authentication with a username and password. * https://docs.aws.amazon.com/iot/latest/developerguide/custom-authentication.html * An authorizer setup needs to be done, as mentioned in the above link, to use * username/password based client authentication. * * #define democonfigCLIENT_PASSWORD "...insert here..." */ /** * @brief The name of the operating system that the application is running on. * The current value is given as an example. Please update for your specific * operating system. */ #define democonfigOS_NAME "FreeRTOS" /** * @brief The version of the operating system that the application is running * on. The current value is given as an example. Please update for your specific * operating system version. */ #define democonfigOS_VERSION tskKERNEL_VERSION_NUMBER /** * @brief The name of the hardware platform the application is running on. The * current value is given as an example. Please update for your specific * hardware platform. */ #define democonfigHARDWARE_PLATFORM_NAME "WinSim" /** * @brief The name of the MQTT library used and its version, following an "@" * symbol. */ #include "core_mqtt.h" /* Include coreMQTT header for MQTT_LIBRARY_VERSION macro. */ #define democonfigMQTT_LIB "core-mqtt@"MQTT_LIBRARY_VERSION /** * @brief Set the stack size of the main demo task. * * In the Windows port, this stack only holds a structure. The actual * stack is created by an operating system thread. */ #define democonfigDEMO_STACKSIZE configMINIMAL_STACK_SIZE /** * @brief Size of the network buffer for MQTT packets. */ #define democonfigNETWORK_BUFFER_SIZE ( 1024U ) #endif /* DEMO_CONFIG_H */