Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
mbed-cloud-client/source/CertificateParser.c
- Committer:
- MACRUM
- Date:
- 2018-07-02
- Revision:
- 0:276e7a263c35
File content as of revision 0:276e7a263c35:
// ----------------------------------------------------------------------------
// Copyright 2016-2017 ARM Ltd.
//
// SPDX-License-Identifier: Apache-2.0
//
// 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.
// ----------------------------------------------------------------------------
#include <stdint.h>
#include "pal.h"
#include "mbed-trace/mbed_trace.h"
#define TRACE_GROUP "mClt"
bool extract_cn_from_certificate(const uint8_t* cer, size_t cer_len, char* common_name)
{
tr_debug("extract_cn_from_certificate");
palX509Handle_t cert;
size_t len;
palStatus_t ret;
ret = pal_x509Initiate(&cert);
if (ret != PAL_SUCCESS) {
tr_error("extract_cn_from_certificate - cert init failed: %d", (int)ret);
pal_x509Free(&cert);
return false;
}
ret = pal_x509CertParse(cert, cer, cer_len);
if (ret != PAL_SUCCESS) {
tr_error("extract_cn_from_certificate - cert parse failed: %d", (int)ret);
pal_x509Free(&cert);
return false;
}
ret = pal_x509CertGetAttribute(cert, PAL_X509_CN_ATTR, common_name, 64, &len);
if (ret != PAL_SUCCESS) {
tr_error("extract_cn_from_certificate - cert attr get failed: %d", (int)ret);
pal_x509Free(&cert);
return false;
}
pal_x509Free(&cert);
return true;
}