HCOSE_ENCRYPT COSE_Encrypt_Init_From_Object(cn_cbor * cbor, CBOR_CONTEXT_COMMA cose_errback * perr) { COSE_Encrypt * pobj; cose_errback error = { 0 }; if (perr == NULL) perr = &error; pobj = (COSE_Encrypt *) COSE_CALLOC(1, sizeof(COSE_Encrypt), context); if (pobj == NULL) { perr->err = COSE_ERR_OUT_OF_MEMORY; errorReturn: if (pobj != NULL) { _COSE_Encrypt_Release(pobj); COSE_FREE(pobj, context); } return NULL; } if (!_COSE_Init_From_Object(&pobj->m_message, cbor, CBOR_CONTEXT_PARAM_COMMA perr)) { goto errorReturn; } _COSE_InsertInList(&EncryptRoot, &pobj->m_message); return(HCOSE_ENCRYPT) pobj; }
HCOSE_ENCRYPT _COSE_Encrypt_Init_From_Object(cn_cbor * cbor, COSE_Encrypt * pIn, CBOR_CONTEXT_COMMA cose_errback * perr) { COSE_Encrypt * pobj = pIn; cn_cbor * pRecipients = NULL; cose_errback error = { 0 }; if (perr == NULL) perr = &error; if (pobj == NULL) pobj = (COSE_Encrypt *)COSE_CALLOC(1, sizeof(COSE_Encrypt), context); if (pobj == NULL) { perr->err = COSE_ERR_OUT_OF_MEMORY; errorReturn: if (pobj != NULL) { _COSE_Encrypt_Release(pobj); if (pIn == NULL) COSE_FREE(pobj, context); } return NULL; } if (!_COSE_Init_From_Object(&pobj->m_message, cbor, CBOR_CONTEXT_PARAM_COMMA perr)) { goto errorReturn; } pRecipients = _COSE_arrayget_int(&pobj->m_message, INDEX_RECIPIENTS); CHECK_CONDITION(pRecipients == NULL, COSE_ERR_INVALID_PARAMETER); _COSE_InsertInList(&EncryptRoot, &pobj->m_message); return(HCOSE_ENCRYPT) pobj; }
HCOSE_ENCRYPT COSE_Encrypt_Init(COSE_INIT_FLAGS flags, CBOR_CONTEXT_COMMA cose_errback * perr) { CHECK_CONDITION(flags == COSE_INIT_FLAGS_NONE, COSE_ERR_INVALID_PARAMETER); COSE_Encrypt * pobj = (COSE_Encrypt *)COSE_CALLOC(1, sizeof(COSE_Encrypt), context); CHECK_CONDITION(pobj != NULL, COSE_ERR_OUT_OF_MEMORY); if (!_COSE_Init(flags, &pobj->m_message, COSE_enveloped_object, CBOR_CONTEXT_PARAM_COMMA perr)) { _COSE_Encrypt_Release(pobj); COSE_FREE(pobj, context); return NULL; } _COSE_InsertInList(&EncryptRoot, &pobj->m_message); return (HCOSE_ENCRYPT) pobj; errorReturn: return NULL; }
bool COSE_Encrypt_Free(HCOSE_ENCRYPT h) { #ifdef USE_CBOR_CONTEXT cn_cbor_context context; #endif COSE_Encrypt * pEncrypt = (COSE_Encrypt *)h; if (!IsValidEncryptHandle(h)) return false; #ifdef USE_CBOR_CONTEXT context = ((COSE_Encrypt *)h)->m_message.m_allocContext; #endif _COSE_Encrypt_Release(pEncrypt); _COSE_RemoveFromList(&EncryptRoot, &pEncrypt->m_message); COSE_FREE((COSE_Encrypt *)h, &context); return true; }