/*
 * Copyright (C) 2019 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

//#define LOG_NDEBUG 0
#define LOG_TAG "android.hardware.cas@1.1-TypeConvert"

#include "TypeConvert.h"
#include <utils/Log.h>

namespace android {
namespace hardware {
namespace cas {
namespace V1_1 {
namespace implementation {

Status toStatus(status_t legacyStatus) {
    Status status;
    switch (legacyStatus) {
        case android::OK:
            status = Status::OK;
            break;
        case android::ERROR_CAS_NO_LICENSE:
            status = Status::ERROR_CAS_NO_LICENSE;
            break;
        case android::ERROR_CAS_LICENSE_EXPIRED:
            status = Status::ERROR_CAS_LICENSE_EXPIRED;
            break;
        case android::ERROR_CAS_SESSION_NOT_OPENED:
            status = Status::ERROR_CAS_SESSION_NOT_OPENED;
            break;
        case android::ERROR_CAS_CANNOT_HANDLE:
            status = Status::ERROR_CAS_CANNOT_HANDLE;
            break;
        case android::ERROR_CAS_TAMPER_DETECTED:
            status = Status::ERROR_CAS_INVALID_STATE;
            break;
        case android::BAD_VALUE:
            status = Status::BAD_VALUE;
            break;
        case android::ERROR_CAS_NOT_PROVISIONED:
            status = Status::ERROR_CAS_NOT_PROVISIONED;
            break;
        case android::ERROR_CAS_RESOURCE_BUSY:
            status = Status::ERROR_CAS_RESOURCE_BUSY;
            break;
        case android::ERROR_CAS_INSUFFICIENT_OUTPUT_PROTECTION:
            status = Status::ERROR_CAS_INSUFFICIENT_OUTPUT_PROTECTION;
            break;
        case android::ERROR_CAS_DEVICE_REVOKED:
            status = Status::ERROR_CAS_DEVICE_REVOKED;
            break;
        case android::ERROR_CAS_DECRYPT_UNIT_NOT_INITIALIZED:
            status = Status::ERROR_CAS_DECRYPT_UNIT_NOT_INITIALIZED;
            break;
        case android::ERROR_CAS_DECRYPT:
            status = Status::ERROR_CAS_DECRYPT;
            break;
        default:
            ALOGW("Unable to convert legacy status: %d, defaulting to UNKNOWN", legacyStatus);
            status = Status::ERROR_CAS_UNKNOWN;
            break;
    }
    return status;
}

String8 sessionIdToString(const CasSessionId& sessionId) {
    String8 result;
    for (size_t i = 0; i < sessionId.size(); i++) {
        result.appendFormat("%02x ", sessionId[i]);
    }
    if (result.empty()) {
        result.append("(null)");
    }
    return result;
}

}  // namespace implementation
}  // namespace V1_1
}  // namespace cas
}  // namespace hardware
}  // namespace android
