1 /*---------------------------------------------------------------------------* 2 Project: Horizon 3 File: boss_Const.h 4 5 Copyright (C)2009 Nintendo Co., Ltd. All rights reserved. 6 7 These coded instructions, statements, and computer programs contain 8 proprietary information of Nintendo of America Inc. and/or Nintendo 9 Company Ltd., and are protected by Federal copyright law. They may 10 not be disclosed to third parties or copied or duplicated in any form, 11 in whole or in part, without the prior written consent of Nintendo. 12 13 $Rev: 31623 $ 14 *---------------------------------------------------------------------------*/ 15 16 #ifndef NN_BOSS_BOSS_CONST_H_ 17 #define NN_BOSS_BOSS_CONST_H_ 18 19 #include <nn/types.h> 20 21 #ifdef __cplusplus 22 23 namespace nn { 24 namespace boss { 25 26 /*! 27 @brief NSDのデータ種別です。 28 */ 29 static const bit32 DATA_TYPE_ALL = 0xffffffff; //!< すべてのデータ種別 30 static const bit32 DATA_TYPE_APPDATA = 0x00010000; //!< アプリ用のデータ種別 31 static const bit32 DATA_TYPE_NEWS = 0x00020000; //!< ニュース用データ種別 32 static const bit32 DATA_TYPE_EXBANNER = 0x00040000; //!< バナー用データ種別 33 34 /*! 35 @brief BOSSシステムの定数です。 36 */ 37 static const u32 MAX_FILEPATH_LENGTH = 256; //!< ファイルパス最大長 38 static const u32 MAX_URL_LENGTH = 512; //!< URLの最大長/ 39 static const u32 MAX_HTTP_HEADER_LABEL = 32; //!< HTTPヘッダラベルの最大長 40 static const u32 MAX_HTTP_HEADER_VALUE = 256; //!< HTTPヘッダ値の最大長 41 static const u32 MAX_HTTP_HEADER = 3; //!< 登録可能なヘッダ最大個数 42 static const u32 MAX_ROOT_CA = 3; //!< 設定可能な内蔵RootCA証明書の最大数 43 static const u32 MAX_CLIENT_CERT = 1; //!< 設定可能な内蔵クライアント証明書の最大数 44 static const u32 TASK_ID_LENGTH = 8; //!< ゼロ終端文字を含むタスクIDの最大文字数 45 static const u32 MAX_ERROR_MESSAGE = 256; //!< エラーメッセージの最大文字数 46 static const u32 MAX_APPLICATION_ID = 128; //!< 登録可能なアプリIDの最大個数 47 static const u32 MAX_TASK_ID = 256; //!< 登録可能なタスクIDの最大個数 48 static const u32 MAX_STEP_ID = 255; //!< 1つのタスクに登録可能なタスクステップの最大個数 49 static const u32 CURRENT_STEP_ID = MAX_STEP_ID; //!< 実行中のタスクステップのID 50 static const u32 DEFAULT_STEP_ID = 0; //!< ステップIDの指定を省略する場合のタスクステップID 51 static const u32 U32_CANNOT_GET_DATA = 0xFFFFFFFF; //!< u32を返す関数で値が取得できない場合の戻り値 52 static const u32 MAX_LASTMODIFIED_LENGTH = 64; //!< HTTP通信における更新日時の最大文字数 53 static const u32 UNLIMITED_COUNT = 0xFFFFFFFF; //!< 無限の消尽回数の指定値 54 55 /*! 56 @brief ファイルの読み書きの位置を指定することを示す定数群です。 57 */ 58 enum PositionBase 59 { 60 /*! 61 @brief ファイルの先頭を基準としてファイルのカレント位置を設定することを示す定数です。 62 */ 63 POSITION_BASE_BEGIN, 64 65 /*! 66 @brief ファイルのカレント位置を基準としてファイルのカレント位置を設定することを示す定数です。 67 */ 68 POSITION_BASE_CURRENT, 69 70 /*! 71 @brief ファイルの末尾を基準としてファイルのカレント位置を設定することを示す定数です。 72 */ 73 POSITION_BASE_END 74 }; 75 76 /*! 77 @brief プロパティを指定する定数群です。 78 */ 79 enum PropertyType 80 { 81 /*! 82 @brief TaskPolicyの属性を参照するための定数です。 83 */ 84 TASK_PRIORITY, //!< タスク登録時のタスク実行優先順位。データの型は、TaskPriorityです。 85 TASK_SCHEDULING_POLICY, //!< タスクのスケジューリングポリシー。データの型は、SchedulingPolicyです。 86 TASK_TARGET_DURATION, //!< 目標とするタスク実行時間。データの型は、u32(秒)です。(将来的な拡張用ですので使用できません) 87 TASK_EXEC_INTERVAL, //!< タスクの実行間隔。データの型は、u32(秒)です。 88 TASK_EXEC_COUNT, //!< タスクの消尽回数。データの型は、u16です。 89 TASK_PERMISSION, //!< タスク実行に伴うペアレンタルコントロール・EULAパーミッションの制御設定。データの型は、TaskPermission です。 90 91 /*! 92 @brief TaskActionの属性を参照するための定数です。 93 */ 94 ACTION_CODE, //!< タスクの種別コード。データの型は、Action です。 95 ACTION_URL, //!< 対象のURL。データの型は、char[MAX_URL_LENGTH] です。 96 ACTION_OFFSET, //!< URLで指定したデータの先頭位置オフセット。データの型は、u32 です。 97 ACTION_FILEDESC, //!< ファイル識別子のタイプ。データの型は、FileDescriptor です。 98 ACTION_FILEPATH, //!< ダウンロード先のファイルパス。データの型は、char[MAX_FILEPATH_LENGTH] です。 99 ACTION_FILEPATH_W, //!< ダウンロード先のファイルパス。データの型は、wchar_t[MAX_FILEPATH_LENGTH] です。 100 ACTION_FILE_HANDLE, //!< ダウンロード先のファイルハンドル。データの型は、nn::Handle です。 101 ACTION_HTTP_HEADER, //!< URLのオプションリクエストヘッダ構造体。データの型は、struct httpRequestHeader[MAX_HTTP_HEADER] です。 102 ACTION_CLIENT_CERT, //!< https通信用の内蔵クライアント証明書。データの型は、nn::http::InternalClientCertId[MAX_CLIENT_CERT] です。 103 ACTION_ROOT_CA, //!< https通信用の内蔵ルート証明書。データの型は、nn::http::InternalCaCertId です。 104 ACTION_PRIVATE_CLIENT_CERT, //!< プライベートクライアント証明書の有効フラグ。データの型は、u8 です。 105 ACTION_PRIVATE_ROOT_CA, //!< プライベートルート証明書の有効フラグ。データの型は、u8 です。 106 ACTION_AP_INFO, //!< HTTPクエリーへAP情報付与のためのアクセスポイント情報種別。データの型は、ApInfoType です。 107 ACTION_CLIENT_CERT_NUM, //!< 内蔵クライアント証明書の設定数。データの型は、u32 です。 108 ACTION_ROOT_CA_NUM, //!< 内蔵ルート証明書を指定の設定数。データの型は、u32 です。 109 ACTION_LAST_MODIFIED_TIME, //!< HTTPリクエストヘッダに設定する最終更新日時。データの型は、char[MAX_LASTMODIFIED_LENGTH] です。 110 ACTION_SERIAL_ID, //!< 起動タスク用のタイトルID。データの型は、nn::fs::TitleId です。(将来的な拡張用ですので使用できません) 111 SIGNAL_TASK_EVENT, //!< 起動タスク用のイベント。データの型は、nn::os::Event* です。(将来的な拡張用ですので使用できません) 112 113 /*! 114 @brief TaskOptionの属性を参照するための定数です。 115 */ 116 TASK_EXEC_OPTION, //!< タスク実行オプション。データの型は、ExecOption です。 117 TASK_STEP, //!< タスクステップのID番号。データの型は、u8 です。 118 TASK_OPTION_TARGET_STEP, //!< タスクステップのオプションID番号。データの型は、u8 です。(将来的な拡張用ですので使用できません) 119 TASK_OPTION_PARAM1, //!< タスクステップ実行のオプションパラメータ1。データの型は、u32 です。(将来的な拡張用ですので使用できません) 120 TASK_OPTION_PARAM2, //!< タスクステップ実行のオプションパラメータ2。データの型は、u32 です。(将来的な拡張用ですので使用できません) 121 122 /*! 123 @brief TaskStatusの属性を参照するための定数です。 124 */ 125 TASK_STATE_CODE, //!< タスクの状態情報。データの型は、TaskStateCode です。 126 TASK_STATE_RESUME, //!< 内部的なタスクの状態情報。データの型は、TaskStateCode です。 127 TASK_RESULT_CODE, //!< タスク実行結果コード。データの型は、TaskResultCode です。 128 TASK_SERVICE_STATUS, //!< タスク属性で指定したURLのサービス利用可能ステータス。データの型は、TaskServiceStatus です。 129 TASK_SERVICE_TERMINATED, //!< タスク属性で指定したURLのサービス利用可能フラグ。データの型は、bool です。 130 TASK_COMM_ERROR_CODE, //!< タスク実行時の通信エラーコード。データの型は、u32 です。 131 TASK_CURRENT_PRIORITY, //!< 現在のタスク実行の優先順位。データの型は、u8 です。 132 TASK_EXECUTE_COUNT, //!< タスクの消尽回数。データの型は、u32 です。 133 TASK_PENDING_TIME, //!< タスク実行開始予定時刻からの経過時間。データの型は、u32(秒) です。 134 TASK_REMAIN_TIME, //!< タスク実行までの残り時間。データの型は、u32(秒) です。(将来的な拡張用ですので使用できません) 135 TASK_START_TIME, //!< 2000/1/1を基点としたタスク実行指示時刻。データの型は、s64(ナノ秒) です。 136 TASK_STEP_START_TIME, //!< 2000/1/1を基点としたタスク実行指示時刻。データの型は、s64(ナノ秒) です。(将来的な拡張用ですので使用できません) 137 TASK_PROGRESS, //!< ダウンロード済みバイト数。データの型は、u32 です。 138 TASK_DATA_SIZE, //!< ダウンロード対象のURLの総バイト数。データの型は、u32 です。 139 TASK_CURRENT_STEP, //!< 実行中のタスクステップID番号。データの型は、u8 です。 140 TASK_ACTIVE_RATE, //!< 平均実行率。データの型は、u16 です。(将来的な拡張用ですので使用できません) 141 TASK_REQUEST_RATE, //!< 平均通信リクエスト率。データの型は、u16 です。(将来的な拡張用ですので使用できません) 142 TASK_LAST_MODIFIED_TIME, //!< HTTPレスポンスヘッダで返された最終更新日時。データの型は、char[MAX_LASTMODIFIED_LENGTH] です。 143 144 /*! 145 @brief TaskErrorの属性を参照するための定数です。 146 */ 147 TASK_ERROR_RESULT_CODE, //!< タスク実行結果コード。データの型は、TaskResultCode です。 148 TASK_ERROR_CODE, //!< タスク実行時の通信エラーコード。データの型は、u32 です。 149 TASK_ERROR_MESSAGE, //!< タスク実行時の通信エラーメッセージ。データの型は、char[MAX_ERROR_MESSAGE] です。(将来的な拡張用ですので使用できません) 150 151 /*! 152 @brief ApplicationIdListの属性を参照するための定数です。(内部処理用の列挙子です。) 153 */ 154 TASK_APPID_LIST_SIZE, //!< ApplicationIdListクラス用の内部サイズ。データの型は、u16 です。(内部処理用の列挙子です。) 155 TASK_APPID_LIST, //!< ApplicationIdListクラス用の内部アプリケーションIDリスト。データの型は、AppIdType[MAX_APPLICATION_ID] です。(内部処理用の列挙子です。) 156 /*! 157 @brief TaskIdListの属性を参照するための定数です。(内部処理用の列挙子です。) 158 */ 159 TASK_TASKID_LIST_SIZE, //!< TaskIdListクラス用の内部サイズ。データの型は、u16 です。(内部処理用の列挙子です。) 160 TASK_TASKID_LIST, //!< TaskIdListクラス用の内部タスクIDリスト。データの型は、u8[MAX_TASK_ID][TASK_ID_LENGTH] です。(内部処理用の列挙子です。) 161 /*! 162 @brief StepIdListの属性を参照するための定数です。(内部処理用の列挙子です。) 163 */ 164 TASK_STEPID_LIST_SIZE, //!< StepIdListクラス用の内部サイズ。データの型は、u16 です。(内部処理用の列挙子です。) 165 TASK_STEPID_LIST, //!< StepIdListクラス用の内部タスクステップIDリスト。データの型は、u8[MAX_TASK_ID] です。(内部処理用の列挙子です。) 166 /*! 167 @brief NsDataIdListの属性を参照するための定数です。(内部処理用の列挙子です。) 168 */ 169 TASK_NSDATA_LIST_SIZE, //!< NsDataIdListクラス用の内部サイズ。データの型は、u16 です。(内部処理用の列挙子です。) 170 TASK_NSDATA_LIST, //!< NsDataIdListクラス用の内部NsDataリスト。データの型は、u32[serialSize] です。(内部処理用の列挙子です。) 171 172 /*! 173 @brief 内部処理用の定数です。 174 */ 175 ACTION_SIGNAL_TASK_EVENT, //!< 起動タスク用のイベント。データの型は、nn::os::Event* です。(将来的な拡張用ですので使用できません) 176 ACTION_HTTP_HEADER_VALUE, //!< (内部処理用の列挙子です。) 177 TASK_ID, //!< (内部処理用の列挙子です。) 178 179 PROPERTY_TYPE_MAX_VALUE = (0x1u << 15) 180 }; 181 182 /*! 183 @brief スケジューリングポリシーを指定する定数群です。 184 */ 185 enum SchedulingPolicy 186 { 187 ENUM_POLICY_START, 188 STANDARD_POLICY, //!< 標準のスケジューリングポリシー設定 189 ENUM_POLICY_END, 190 SCHEDULING_POLICY_MAX_VALUE = (0x1u << 7) 191 }; 192 193 194 /*! 195 @brief タスクパーミッションを指定する定数群です。 196 */ 197 enum TaskPermission 198 { 199 TASK_PERMISSION_IN_NONE = 0, //!< 機器のペアレンタルコントロール状態と、EULA同意状態に従いタスクの実行をする設定値です。 200 TASK_PERMISSION_IN_EULA_DISAGREEMENT, //!< EULA同意がない場合でもタスクの実行を認める設定値です。 201 TASK_PERMISSION_IN_PARENTAL_CONTROL, //!< ペアレンタルコントロール状態でもタスクの実行を認める設定値です。 202 TASK_PERMISSION_IN_BOTH, //!< ペアレンタルコントロール状態でも、EULA同意がない場合でもタスクの実行を認める設定値です。 203 TASK_PERMISSION_MAX_VALUE = (0x1u << 7) 204 }; 205 206 207 /*! 208 @brief タスクのプライオリティを指定する定数群です。 209 */ 210 enum TaskPriority 211 { 212 PRIORITY_EXPEDITE = 35, //!< 最優先のタスクの実行優先順位設定 213 PRIORITY_HIGH = 80, //!< 高いタスクの実行優先順位設定 214 PRIORITY_MEDIUM = 125, //!< 中間タスクの実行優先順位設定 215 PRIORITY_LOW = 170, //!< 低いタスクの実行優先順位設定 216 PRIORITY_STOPPED = 255, //!< タスク停止中の実行優先順位設定 217 PRIORITY_MAX_VALUE = (0x1u << 7) 218 }; 219 220 /*! 221 @brief タスクアクションを指定する定数群です。 222 */ 223 enum Action 224 { 225 ENUM_ACTION_START, 226 DOWNLOAD_TASK, //!< RAWダウンロードタスク 227 NSA_DOWNLOAD_TASK, //!< NSAダウンロードタスク 228 UPLOAD_TASK, //!< アップロードタスク 229 SIGNAL_TASK, //!< シグナルタスク 230 ENUM_ACTION_END, 231 ACTION_MAX_VALUE = (0x1u << 7) 232 }; 233 234 /*! 235 @brief タスク実行オプションを指定する定数群です。 236 */ 237 enum ExecOption 238 { 239 ENUM_EXECOPTION_START, 240 NORMAL_EXEC, //!< 通常実行 241 ENUM_EXECOPTION_END, 242 OPTION_MAX_VALUE = (0x1u << 7) 243 }; 244 245 /*! 246 @brief タスクステートコードの定数群です。 247 */ 248 enum TaskStateCode 249 { 250 TASK_STOPPED, //!< タスク停止中 251 TASK_WAITING_TIMER, //!< タスクの開始時刻待ち状態 252 TASK_WAITING, //!< タスクの実行待ち状態 253 TASK_RUNNING, //!< タスク実行中 254 TASK_PAUSED, //!< タスクポーズ中 255 TASK_REGISTERED, //!< タスクを登録した状態 256 TASK_DONE, //!< タスク実行完了状態 257 TASK_ERROR, //!< タスク実行の異常終了 258 TASK_RETRY, //!< タスク実行中の通信エラーによるリトライ状態 259 GET_TASK_STATE_ERROR, //!< タスク状態取得エラー 260 STATUS_MAX_VALUE = (0x1u << 7) //!< 261 }; 262 263 /*! 264 * @brief タスク終了状態。タスク終了後にTask::GetResult()等で取得可能。 265 */ 266 enum TaskResultCode 267 { 268 TASK_SUCCESS, //!< タスク成功。 269 BOSS_ERROR_NOMEM, //!< メモリの動的取得失敗 270 271 GET_TASK_RESULT_ERROR, //!< タスクリザルトが取得できませんでした。 272 TASK_NOT_EXIST, //!< 指定されたタスクがありません。 273 274 // HTTP通信のエラー 275 HTTP_ERROR_NOMEM, //!< HTTP通信処理で メモリの動的取得に失敗。 276 HTTP_ERROR_CREATE_EVENT, //!< HTTP通信処理で 内部リソース(イベント)の作成に失敗。 277 HTTP_ERROR_CREATE_MUTEX, //!< HTTP通信処理で 内部リソース(ミューテックス)の作成に失敗。 278 HTTP_ERROR_CREATE_QUEUE, //!< HTTP通信処理で 内部リソース(キュー)の作成に失敗。 279 HTTP_ERROR_CREATE_THREAD, //!< HTTP通信処理で 内部リソース(スレッド)の作成に失敗。 280 HTTP_ERROR_IPC_SESSION, //!< IPCセッションが不正。 281 HTTP_ERROR_CLIENT_PROCESS_MAX, //!< 同時利用可能なクライアントプロセス数のクライアントがすでに利用中です。 282 HTTP_ERROR_IPC_SESSION_MAX, //!< 同時に接続可能なIPCセッション数のセッションがすでに接続されています。 283 HTTP_ERROR_MSGQ_SEND_LSN, //!< リスナースレッドメッセージキューへの送信失敗。 284 HTTP_ERROR_MSGQ_RECV_LSN, //!< リスナースレッドメッセージキュー受信失敗。 285 HTTP_ERROR_MSGQ_SEND_COMM, //!< 通信スレッドメッセージキュー受信失敗。 286 HTTP_ERROR_CONN_NOMORE, //!< 接続ハンドル登録最大数越え。 287 HTTP_ERROR_CONN_STATUS, //!< 接続ハンドル不正ステータス。 288 HTTP_ERROR_CONN_ADD, //!< 接続ハンドル登録失敗。 289 HTTP_ERROR_CONN_HOST_MAX, //!< 同一ホストへの最大同時接続数越え。 290 HTTP_ERROR_INVALID_URL, //!< 不正なURL。 291 HTTP_ERROR_RESPONSE_HEADER, //!< 不正なHTTPヘッダ。 292 HTTP_ERROR_NO_NEWLINE, //!< HTTPヘッダ次行なし。 293 HTTP_ERROR_SSL, //!< SSL認証エラー。 294 HTTP_ERROR_CERT_EXIST, //!< SSL証明書設定済み。(再登録前に削除が必要) 295 HTTP_ERROR_NO_CA_CERT_STORE, //!< SSL 該当するCA証明書ストアが登録されていません。 296 HTTP_ERROR_NO_CLIENT_CERT, //!< SSL 該当するクライアント証明書が登録されていません。 297 HTTP_ERROR_CA_CERT_STORE_MAX, //!< SSL プロセスごとのCA証明書ストア同時登録最大数の証明書ストアがすでに登録されています。 298 HTTP_ERROR_CLIENT_CERT_MAX, //!< SSL プロセスごとのクライアント証明書同時登録最大数の証明書がすでに登録されています。 299 HTTP_ERROR_FAIL_TO_CREATE_CERT_STORE, //!< SSL 証明書ストアの作成に失敗。 300 HTTP_ERROR_FAIL_TO_CREATE_CLIENT_STORE, //!< SSL クライアント証明書の作成に失敗。 301 HTTP_ERROR_DNS, //!< DNS名前解決失敗 302 HTTP_ERROR_SEND, //!< ソケットデータ送信失敗。(インフラ通信切断 など) 303 HTTP_ERROR_RECV, //!< ソケットデータ受信失敗。(インフラ通信切断 など) 304 HTTP_ERROR_CONNECT, //!< ソケット接続失敗。(サーバが見つからない場合 など) 305 HTTP_ERROR_GET_PROXY_SETTING, //!< 機器情報のプロキシ設定の取得に失敗。 306 HTTP_ERROR_TIMEOUT, //!< HTTP通信のタイムアウト。 307 HTTP_ERROR_401_UNAUTHORIZED, //!< ステータスコード401 Unauthorized を受信。 308 HTTP_ERROR_403_FORBIDDEN, //!< ステータスコード403 Forbidden を受信。 309 HTTP_ERROR_404_NOT_FOUND, //!< ステータスコード404 Not Found を受信。 310 HTTP_ERROR_408_REQUEST_TIMEOUT, //!< ステータスコード408 Request Timeout を受信。 311 HTTP_ERROR_416_REQUESTED_RANGE_NOT_SATISFABLE, //!< ステータスコード416 Requested Range Not Satisfable を受信。 312 HTTP_ERROR_500_INTERNAL_SERVER_ERROR, //!< ステータスコード500 Internal Server Error を受信。 313 HTTP_ERROR_502_BAD_GATEWAY, //!< ステータスコード502 Bad Gateway を受信。 314 HTTP_ERROR_503_SERVICE_UNAVAILABLE, //!< ステータスコード503 Service Unavailable を受信。 315 HTTP_ERROR_504_GATEWAY_TIMEOUT, //!< ステータスコード504 Gateway Timeout を受信。 316 HTTP_ERROR_505_VERSION_NOT_SUPPORTED, //!< ステータスコード505 Version Not Supported を受信。 317 HTTP_ERROR_UNSUPPORTED_STATUS, //!< HTTP通信処理で 上記以外の1xx 3xx 4xx 5xxエラーを受信。 318 319 // SSLエラー 320 SSL_ERROR_FAILED, //!< SSLプロトコルの失敗によるエラー。(サーバー側でクライアント証明書の検証が失敗した場合等) 321 SSL_ERROR_WANT_READ, //!< SSLモジュールで非同期ソケット使用時の Read 関数の処理未完了。(再試行してください。) 322 SSL_ERROR_WANT_WRITE, //!< SSLモジュールで非同期ソケット使用時のWrite 関数の処理未完了。(再試行してください。) 323 SSL_ERROR_SYSCALL, //!< SSLモジュールで内部で使用しているシステム関数が予期せぬエラーを返しました。 324 SSL_ERROR_ZERO_RETURN, //!< SSLモジュールで内部でSocketのRead / Write を実施した際、予期せぬタイミングでゼロが返されました。 325 SSL_ERROR_WANT_CONNECT, //!< SSLモジュールで非同期ソケット使用時の接続未完了。(再試行してください。) 326 SSL_ERROR_SSLID, //!< SSLモジュールで内部エラー。(不正なSSLID) 327 SSL_ERROR_VERIFY_CERT, //!< サーバ認証エラー。サーバ証明書の 認証に失敗しました。 328 SSL_ERROR_VERIFY_COMMON_NAME, //!< サーバ認証エラー。サーバ証明書の CommonName と、AssignServer()で指定した通信先サーバのホスト名が一致しません。 329 SSL_ERROR_VERIFY_ROOT_CA, //!< サーバ認証エラー。サーバ証明書の Root CA 証明書が、Connectionに設定された証明書と一致しません。 330 SSL_ERROR_VERIFY_CHAIN, //!< サーバ認証エラー。サーバ証明書の証明書チェインが不正。 331 SSL_ERROR_VERIFY_DATE, //!< サーバ認証エラー。サーバ証明書が有効期限外です。 332 SSL_ERROR_GET_SERVER_CERT, //!< 証明書データのバッファへの格納失敗。(引数有りのDoHandshake()で 証明書のサイズがバッファより大きい場合に発生) 333 SSL_ERROR_VERIFY_REVOKED_CERT, //!< サーバ認証エラー。サーバ証明書が失効リストに登録されているサーバ証明書でした。 334 SSL_ERROR_OUT_OF_MEMORY, //!< SSLモジュールでメモリの動的取得失敗。 335 SSL_ERROR_SESSION, //!< SSLモジュールでIPCセッションが不正。 336 SSL_ERROR_FAIL_TO_CREATE_CERT_STROE, //!< 証明書ストアの作成に失敗しました。 337 SSL_ERROR_FAIL_TO_CREATE_CRL_STORE, //!< CRLストアの作成に失敗しました。 338 SSL_ERROR_FAIL_TO_CREATE_CLIENT_CERT, //!< クライアント証明書の作成に失敗しました。 339 SSL_ERROR_CLIENT_PROCESS_MAX, //!< 同時利用可能なクライアントプロセス数のクライアントがすでに利用中です。 340 SSL_ERROR_IPC_SESSION, //!< 同時に接続可能なIPCセッション数のセッションがすでに接続されています。 341 SSL_ERROR_INTERNAL_CERT, //!< 内蔵証明書の利用に失敗。 342 SSL_ERROR_INTERNAL_CRL, //!< 内蔵CRLの利用に失敗。 343 344 // ファイルシステムアクセスのエラー 345 FS_ERROR_INVALID_POSITION_BASE, //!< ファイルシステムに関するエラーが発生しました。 346 FS_ERROR_ARCHIVE_NOT_FOUND, //!< ファイルシステムに関するエラーが発生しました。 347 FS_ERROR_FAILED_OPEN_FILE, //!< ファイルシステムに関するエラーが発生しました。 348 FS_ERROR_UNSUPPORTED_OPERATION, //!< ファイルシステムに関するエラーが発生しました。 349 FS_ERROR_INVALID_PATH_FORMAT, //!< ファイルシステムに関するエラーが発生しました。 350 FS_ERROR_ACCESS_DENIED, //!< ファイルシステムに関するエラーが発生しました。 351 FS_ERROR_LIBRARY_NOT_INITIALIZED, //!< ファイルシステムに関するエラーが発生しました。 352 FS_ERROR_INVALID_POSITION, //!< ファイルシステムに関するエラーが発生しました。 353 FS_ERROR_TOO_LONG_PATH, //!< ファイルシステムに関するエラーが発生しました。 354 FS_ERROR_NOT_DEVELOPMENT_ID, //!< ファイルシステムに関するエラーが発生しました。 355 FS_ERROR_HASH_MISMATCH, //!< ファイルシステムに関するエラーが発生しました。 356 FS_ERROR_NO_SUCH_PROCESS_REGISTERED, //!< ファイルシステムに関するエラーが発生しました。 357 FS_ERROR_INVALID_CXI_FORMAT, //!< ファイルシステムに関するエラーが発生しました。 358 FS_ERROR_UNSUPPORTED_ALIGNMENT, //!< ファイルシステムに関するエラーが発生しました。 359 FS_ERROR_INVALID_HANDLE, //!< ファイルシステムに関するエラーが発生しました。 360 FS_ERROR_NOT_FOUND, //!< ファイルシステムに関するエラーが発生しました。 361 362 // NSAエラー 363 NSA_ERROR_STORAGE_INSUFFICIENCY, //!< NSAストレージ領域が不足しています。 364 NSA_ERROR_NUMBER_OF_NSD_MAX, //!< NSA内のNSD数が最大数を超えました。 365 NSA_ERROR_VERIFY_HASH, //!< NSA INFOのハッシュにエラーが検出されました。 366 NSA_ERROR_VERIFY_SIGNATURE, //!< NSA INFOの署名にエラーが検出されました。 367 NSA_NSD_ERROR_VERIFY_HASH, //!< NSD HEADERのハッシュにエラーが検出されました。 368 NSA_NSD_ERROR_VERIFY_SIGNATURE, //!< NSD HEADDERの署名にエラーが検出されました。 369 NSA_NSD_ERROR_INVALID_FORMAT, //!< NSDフォーマット異常のエラーが検出されました。 370 NSA_ERROR_INVALID_FORMAT, //!< NSAフォーマット異常のエラーが検出されました。 371 372 // 想定外のエラー 373 SEVERE_ERROR, //! 想定外のエラーが検出されました。 374 UNKNOWN_ERROR, //! 上記以外のエラーが検出された場合、この値に発生したモジュールの列挙子の値(nn::Result::Module)を足した値が返ります。 375 ERROR_MAX_VALUE = (0x1u << 7) 376 }; 377 378 /*! 379 @brief タスクサービスステータスの定数群です。 380 */ 381 enum TaskServiceStatus 382 { 383 SERVICE_TERMINATED, //!< サービスが終了した状態 384 SERVICE_AVAILABLE, //!< サービス利用可能な状態 385 SERVICE_UNKNOWN, //!< サービスが状態がまだ確認できていない状態 386 GET_SERVICE_STATUS_ERROR, //!< サービス状態取得中にエラーが検出されました。 387 SERVICE_MAX_VALUE = (0x1u << 7) 388 }; 389 390 391 /*! 392 @brief NSDのヘッダ情報取得の種別を示す定数群です。 393 */ 394 enum HeaderInfoType 395 { 396 NSD_TITLEID, //!< タイトルID 397 NSD_FLAGS, //!< NSDフラグ 398 NSD_DATATYPE, //!< データタイプ 399 NSD_LENGTH, //!< ベイロードレングス 400 NSD_SERIALID, //!< シリアルID 401 NSD_VERSION, //!< バージョン番号 402 NSD_HEADER_MAX_VALUE = (0x1u << 7) 403 }; 404 405 /*! 406 @brief タスクアクションのファイルパス指定の定数群です。 407 */ 408 enum FileDescriptor 409 { 410 CHAR_TYPE, //!< 通常のキャラクタ(char)によるパス指定 411 WCHAR_TYPE, //!< ワイドキャラクタ(wchar_t)によるパス指定 412 HANDLE_TYPE, //!< ファイルハンドルによるファイル指定 413 FILE_TYPE_MAX_VALUE = (0x1u << 7) 414 }; 415 416 /*! 417 @brief アクセスポイントの識別子種別を示す定数群です。 418 */ 419 enum ApInfoType 420 { 421 APINFOTYPE_NONE = 0x00, //!< ゾーンAPの場合、HTTPクエリーへAP情報付与を行わない設定 422 APINFOTYPE_APGROUP = 0x01, //!< ゾーンAPの場合、HTTPクエリーへAPGROUP情報付与する設定 423 APINFOTYPE_APAREA = 0x02, //!< ゾーンAPの場合、HTTPクエリーへAPAREA情報付与する設定 424 APINFOTYPE_AP = 0x04, //!< ゾーンAPの場合、HTTPクエリーへすべてのAP情報付与する設定 425 APINFOTYPE_MAX_VALUE = (0x1u << 7) 426 }; 427 428 /*! 429 @brief BOSSストレージの種類を示す定数群です。 430 */ 431 enum StorageType 432 { 433 USER_EXT_SAVEDATA_STORAGE, //!< ユーザー拡張セーブデータ領域のBOSSストレージ。 434 SHARED_EXT_SAVEDATA_STORAGE, //!< 共有拡張セーブデータ領域のBOSSストレージ。 435 BOSSSTORAGETYPE_MAX_VALUE = (0x1u << 7) 436 }; 437 438 } // end of namespace boss 439 } // end of namespace nn 440 441 442 #endif /*__cplusplus*/ 443 444 #endif /* NN_BOSS_BOSS_CONST_H_ */ 445