blob: cea46f198762a56dcab5dcae5cbd70a716fa2964 [file] [log] [blame]
Rekha Aparna5e3ff852025-08-12 10:51:23 -05001#pragma once
2
Rekha Aparna9443af22025-08-28 02:40:08 -05003#include <string>
4#include <unordered_map>
5
Rekha Aparna5e3ff852025-08-12 10:51:23 -05006namespace vpd
7{
Sunny Srivastavaad7e25e2025-09-04 09:43:21 -05008enum error_code
Rekha Aparna5e3ff852025-08-12 10:51:23 -05009{
Sunny Srivastavaad7e25e2025-09-04 09:43:21 -050010 // File exceptions
11 FILE_NOT_FOUND = 2001, /*Just a random value*/
12 FILE_ACCESS_ERROR,
13 EMPTY_FILE,
Rekha Aparna5e3ff852025-08-12 10:51:23 -050014
Sunny Srivastavaad7e25e2025-09-04 09:43:21 -050015 // JSON exceptions
16 INVALID_JSON,
17 MISSING_FLAG,
18 MISSING_ACTION_TAG,
19 FRU_PATH_NOT_FOUND,
20 JSON_PARSE_ERROR,
21 JSON_MISSING_GPIO_INFO,
Rekha Aparnae0d24c02025-09-02 00:15:06 -050022 JSON_MISSING_SERVICE_NAME,
Rekha Aparna2d6f0712025-09-02 03:52:57 -050023 REDUNDANT_PATH_NOT_FOUND,
24 ERROR_GETTING_REDUNDANT_PATH,
25 NO_EEPROM_PATH,
Rekha Aparna5e3ff852025-08-12 10:51:23 -050026
Sunny Srivastavaad7e25e2025-09-04 09:43:21 -050027 // Generic errors.
28 INVALID_INPUT_PARAMETER,
29 DEVICE_NOT_PRESENT,
30 DEVICE_PRESENCE_UNKNOWN,
Rekha Aparna41f47e72025-09-18 01:44:09 -050031 GPIO_LINE_EXCEPTION,
32 ERROR_PROCESSING_SYSTEM_CMD
Sunny Srivastavaad7e25e2025-09-04 09:43:21 -050033};
Rekha Aparna9443af22025-08-28 02:40:08 -050034
35const std::unordered_map<int, std::string> errorCodeMap = {
Sunny Srivastavaad7e25e2025-09-04 09:43:21 -050036 {error_code::FILE_NOT_FOUND, "File does not exist."},
37 {error_code::FILE_ACCESS_ERROR, "Failed to access the file."},
38 {error_code::EMPTY_FILE, "Empty file."},
39 {error_code::INVALID_JSON,
40 "Either JSON is missing FRU tag or invalid JSON object."},
41 {error_code::MISSING_FLAG,
42 "JSON is missing the flag to procees for the FRU."},
43 {error_code::MISSING_ACTION_TAG,
Rekha Aparna9443af22025-08-28 02:40:08 -050044 "JSON is missing the action tag to be performed for the FRU."},
Sunny Srivastavaad7e25e2025-09-04 09:43:21 -050045 {error_code::FRU_PATH_NOT_FOUND, "The FRU path is not found in the JSON."},
46 {error_code::JSON_PARSE_ERROR, "Error while parsing JSON file."},
47 {error_code::INVALID_INPUT_PARAMETER,
Sunny Srivastava84c3d232025-09-03 00:47:10 -050048 "Either one of the input parameter is invalid or empty."},
Sunny Srivastavaad7e25e2025-09-04 09:43:21 -050049 {error_code::JSON_MISSING_GPIO_INFO, "JSON missing required GPIO info."},
Rekha Aparnae0d24c02025-09-02 00:15:06 -050050 {error_code::JSON_MISSING_SERVICE_NAME,
51 "JSON missing the service name for the FRU"},
Rekha Aparna2d6f0712025-09-02 03:52:57 -050052 {error_code::REDUNDANT_PATH_NOT_FOUND, "No redundant path for the FRU."},
53 {error_code::ERROR_GETTING_REDUNDANT_PATH,
54 "Error while trying to get redundant path for the FRU"},
55 {error_code::NO_EEPROM_PATH, "EEPROM path not found."},
Sunny Srivastavaad7e25e2025-09-04 09:43:21 -050056 {error_code::DEVICE_NOT_PRESENT,
Sunny Srivastava84c3d232025-09-03 00:47:10 -050057 "Presence pin read successfully but device was absent."},
Sunny Srivastavaad7e25e2025-09-04 09:43:21 -050058 {error_code::DEVICE_PRESENCE_UNKNOWN, "Exception on presence line GPIO."},
Rekha Aparna41f47e72025-09-18 01:44:09 -050059 {error_code::GPIO_LINE_EXCEPTION, "There was an exception in GPIO line."},
60 {error_code::ERROR_PROCESSING_SYSTEM_CMD,
61 "Error while executing system command tag."}};
Rekha Aparna5e3ff852025-08-12 10:51:23 -050062} // namespace vpd