142 lines
3.9 KiB
C++
142 lines
3.9 KiB
C++
|
//***************************************************************************
|
||
|
// apps/crypto/controlse/cstring.cxx
|
||
|
//
|
||
|
// Licensed to the Apache Software Foundation (ASF) under one or more
|
||
|
// contributor license agreements. See the NOTICE file distributed with
|
||
|
// this work for additional information regarding copyright ownership. The
|
||
|
// ASF licenses this file to you 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.
|
||
|
//
|
||
|
//**************************************************************************
|
||
|
|
||
|
// Copyright 2024 NXP
|
||
|
|
||
|
//***************************************************************************
|
||
|
// Included Files
|
||
|
//***************************************************************************
|
||
|
|
||
|
#include "crypto/controlse/cstring.hxx"
|
||
|
#include "crypto/controlse/csecure_element.hxx"
|
||
|
#include <cstring>
|
||
|
|
||
|
namespace Controlse
|
||
|
{
|
||
|
|
||
|
//***************************************************************************
|
||
|
// Class Method Implementations
|
||
|
//***************************************************************************
|
||
|
|
||
|
CString::CString(const ISecureElement &se, uint32_t keystore_id)
|
||
|
{
|
||
|
(void)LoadFromSecureElement(se, keystore_id);
|
||
|
}
|
||
|
|
||
|
CString::CString(char *string, size_t size) : m_size(size)
|
||
|
{
|
||
|
m_string = new char[m_size];
|
||
|
memcpy(m_string, string, m_size);
|
||
|
}
|
||
|
|
||
|
CString::CString(const CString &p1) : CString(p1.m_string, p1.m_size) {}
|
||
|
|
||
|
CString::~CString()
|
||
|
{
|
||
|
if (m_string != nullptr)
|
||
|
{
|
||
|
delete[] m_string;
|
||
|
m_size = 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
CString &CString::operator=(const CString &other)
|
||
|
{
|
||
|
if (this != &other)
|
||
|
{
|
||
|
auto new_string = new char[other.m_size];
|
||
|
memcpy(new_string, other.m_string, other.m_size);
|
||
|
|
||
|
delete[] m_string;
|
||
|
|
||
|
m_string = new_string;
|
||
|
m_size = other.m_size;
|
||
|
}
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
bool CString::operator==(CString &a) const
|
||
|
{
|
||
|
if (a.m_size != m_size)
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
return 0 == (memcmp(a.m_string, m_string, m_size));
|
||
|
}
|
||
|
|
||
|
bool CString::operator!=(CString &a) const { return !operator==(a); }
|
||
|
|
||
|
char *CString::c_str(void) const
|
||
|
{
|
||
|
char *c_str = nullptr;
|
||
|
if (IsLoaded() && (m_size > 0))
|
||
|
{
|
||
|
bool add_termination_character = false;
|
||
|
if (m_string[m_size - 1] != 0)
|
||
|
{
|
||
|
add_termination_character = true;
|
||
|
}
|
||
|
c_str = new char[m_size + (add_termination_character ? 1 : 0)];
|
||
|
memcpy(c_str, m_string, m_size);
|
||
|
if (add_termination_character)
|
||
|
{
|
||
|
c_str[m_size] = 0;
|
||
|
}
|
||
|
}
|
||
|
return c_str;
|
||
|
}
|
||
|
|
||
|
bool CString::IsLoaded() const { return m_string != nullptr; }
|
||
|
|
||
|
bool CString::StoreOnSecureElement(const ISecureElement &se,
|
||
|
uint32_t keystore_id) const
|
||
|
{
|
||
|
auto result = false;
|
||
|
if (IsLoaded())
|
||
|
{
|
||
|
struct se05x_key_transmission_s args
|
||
|
= { .entry = { .id = keystore_id },
|
||
|
.content = { .buffer = reinterpret_cast<uint8_t *>(m_string),
|
||
|
.buffer_size = m_size } };
|
||
|
result = se.SetData(args);
|
||
|
}
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
bool CString::LoadFromSecureElement(const ISecureElement &se,
|
||
|
uint32_t keystore_id)
|
||
|
{
|
||
|
uint8_t buffer[1000];
|
||
|
struct se05x_key_transmission_s args
|
||
|
= { .entry = { .id = keystore_id },
|
||
|
.content = { .buffer = buffer, .buffer_size = sizeof(buffer) } };
|
||
|
auto result = se.GetData(args);
|
||
|
|
||
|
if (result)
|
||
|
{
|
||
|
m_size = args.content.buffer_content_size;
|
||
|
m_string = new char[m_size + 1];
|
||
|
memcpy(m_string, buffer, m_size);
|
||
|
m_string[m_size] = 0;
|
||
|
}
|
||
|
return result;
|
||
|
}
|
||
|
} // namespace Controlse
|