/*
 * Copyright (C) 2017 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.0-TypeConvert"

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

namespace android {
namespace hardware {
namespace cas {
namespace V1_0 {
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_0
}  // namespace cas
}  // namespace hardware
}  // namespace android
