当前位置: 首页>>代码示例>>C++>>正文


C++ ec_secret类代码示例

本文整理汇总了C++中ec_secret的典型用法代码示例。如果您正苦于以下问题:C++ ec_secret类的具体用法?C++ ec_secret怎么用?C++ ec_secret使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


在下文中一共展示了ec_secret类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: sign_compact

compact_signature sign_compact(ec_secret secret, hash_digest hash,
    ec_secret nonce)
{
    init.init();

    compact_signature out;
    if (0 < secp256k1_ecdsa_sign_compact(hash.data(), hash.size(),
        out.signature.data(), secret.data(), nonce.data(), &out.recid))
    {
        return out;
    }

    // Error case:
    return compact_signature{{{0}}, 0};
}
开发者ID:genjix,项目名称:libbitcoin,代码行数:15,代码来源:ec_keys.cpp

示例2: secret_to_public

bool secret_to_public(const secp256k1_context* context, byte_array<Size>& out,
    const ec_secret& secret)
{
    secp256k1_pubkey pubkey;
    return secp256k1_ec_pubkey_create(context, &pubkey, secret.data()) == 1 &&
        serialize(context, out, pubkey);
}
开发者ID:GeopaymeEE,项目名称:libbitcoin,代码行数:7,代码来源:elliptic_curve.cpp

示例3: sign

endorsement sign(ec_secret secret, hash_digest hash, ec_secret nonce)
{
    init.init();

    int out_size = max_endorsement_size;
    endorsement signature(out_size);
    if (0 < secp256k1_ecdsa_sign(hash.data(), hash.size(), signature.data(),
        &out_size, secret.data(), nonce.data()))
    {
        signature.resize(out_size);
        return signature;
    }

    // Error case:
    return endorsement();
}
开发者ID:genjix,项目名称:libbitcoin,代码行数:16,代码来源:ec_keys.cpp

示例4: sign

data_chunk sign(ec_secret secret, hash_digest hash, ec_secret nonce)
{
    std::reverse(hash.begin(), hash.end());
    init.init();
    int out_size = 72;
    data_chunk signature(out_size);

    if (!verify_private_key(nonce)) // Needed because of upstream bug
        return data_chunk();
    bool valid = secp256k1_ecdsa_sign(hash.data(), hash.size(),
        signature.data(), &out_size, secret.data(), nonce.data()) == 1;
    if (!valid)
        return data_chunk();

    signature.resize(out_size);
    return signature;
}
开发者ID:Airbitz,项目名称:libbitcoin,代码行数:17,代码来源:ec_keys.cpp

示例5: ec_multiply

bool ec_multiply(const secp256k1_context* context, byte_array<Size>& in_out,
    const ec_secret& secret)
{
    secp256k1_pubkey pubkey;
    return parse(context, pubkey, in_out) &&
        secp256k1_ec_pubkey_tweak_mul(context, &pubkey, secret.data()) == 1 &&
        serialize(context, in_out, pubkey);
}
开发者ID:GeopaymeEE,项目名称:libbitcoin,代码行数:8,代码来源:elliptic_curve.cpp

示例6: sign

bool sign(ec_signature& out, const ec_secret& secret, const hash_digest& hash)
{
    secp256k1_ecdsa_signature signature;
    const auto context = signing.context();

    if (secp256k1_ecdsa_sign(context, &signature, hash.data(), secret.data(),
        secp256k1_nonce_function_rfc6979, nullptr) != 1)
        return false;

    std::copy_n(std::begin(signature.data), out.size(), out.begin());
    return true;
}
开发者ID:GeopaymeEE,项目名称:libbitcoin,代码行数:12,代码来源:elliptic_curve.cpp

示例7: secret_to_public_key

ec_point secret_to_public_key(const ec_secret& secret, bool compressed)
{
    init.init();
    size_t size = ec_uncompressed_size;
    if (compressed)
        size = ec_compressed_size;

    ec_point out(size);
    int out_size;
    if (!secp256k1_ec_pubkey_create(init.getContext(), out.data(), &out_size, secret.data(),
            compressed))
        return ec_point();
    assert(size == static_cast<size_t>(out_size));
    return out;
}
开发者ID:damienvancouver,项目名称:vertcoin,代码行数:15,代码来源:stealth.cpp

示例8: secret_to_public_key

ec_point secret_to_public_key(const ec_secret& secret,
    bool compressed)
{
    init.init();
    size_t public_key_size = ec_uncompressed_size;
    if (compressed)
        public_key_size = ec_compressed_size;

    ec_point out(public_key_size);
    int out_size;
    if (!secp256k1_ec_pubkey_create(out.data(), &out_size, secret.data(),
            compressed))
        return ec_point();
    BITCOIN_ASSERT(public_key_size == static_cast<size_t>(out_size));
    return out;
}
开发者ID:genjix,项目名称:libbitcoin,代码行数:16,代码来源:ec_keys.cpp

示例9: sign_recoverable

bool sign_recoverable(recoverable_signature& out, const ec_secret& secret,
    const hash_digest& hash)
{
    int recovery_id;
    const auto context = signing.context();
    secp256k1_ecdsa_recoverable_signature signature;

    const auto result =
        secp256k1_ecdsa_sign_recoverable(context, &signature, hash.data(),
            secret.data(), secp256k1_nonce_function_rfc6979, nullptr) == 1 &&
        secp256k1_ecdsa_recoverable_signature_serialize_compact(context,
            out.signature.data(), &recovery_id, &signature) == 1;

    BITCOIN_ASSERT(recovery_id >= 0 && recovery_id <= 3);
    out.recovery_id = static_cast<uint8_t>(recovery_id);
    return result;
}
开发者ID:GeopaymeEE,项目名称:libbitcoin,代码行数:17,代码来源:elliptic_curve.cpp

示例10: ec_tweak_add

bool ec_tweak_add(ec_point& a, const ec_secret& b)
{
    init.init();
    return secp256k1_ecdsa_pubkey_tweak_add(a.data(), a.size(), b.data()) == 1;
}
开发者ID:Airbitz,项目名称:libbitcoin,代码行数:5,代码来源:ec_keys.cpp

示例11: ec_tweak_add

bool ec_tweak_add(ec_point& a, const ec_secret& b)
{
    init.init();
    return secp256k1_ec_pubkey_tweak_add(init.getContext(), a.data(), a.size(), b.data());
}
开发者ID:damienvancouver,项目名称:vertcoin,代码行数:5,代码来源:stealth.cpp

示例12: ec_multiply

bool ec_multiply(ec_secret& a, const ec_secret& b)
{
    init.init();
    return secp256k1_ecdsa_privkey_tweak_mul(a.data(), b.data()) == 1;
}
开发者ID:Airbitz,项目名称:libbitcoin,代码行数:5,代码来源:ec_keys.cpp

示例13: ec_multiply

bool ec_multiply(ec_point& a, const ec_secret& b)
{
    init.init();
    return secp256k1_ec_pubkey_tweak_mul(a.data(), a.size(), b.data()) == 1;
}
开发者ID:genjix,项目名称:libbitcoin,代码行数:5,代码来源:ec_keys.cpp

示例14: ec_add

bool ec_add(ec_secret& a, const ec_secret& b)
{
    init.init();
    return secp256k1_ec_privkey_tweak_add(a.data(), b.data()) == 1;
}
开发者ID:genjix,项目名称:libbitcoin,代码行数:5,代码来源:ec_keys.cpp

示例15: verify

bool verify(const ec_secret& secret)
{
    const auto context = verification.context();
    return secp256k1_ec_seckey_verify(context, secret.data()) == 1;
}
开发者ID:GeopaymeEE,项目名称:libbitcoin,代码行数:5,代码来源:elliptic_curve.cpp


注:本文中的ec_secret类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。