2023-10-20 09:31:28 +00:00
<?xml version="1.0" encoding="utf-8" ?>
2024-02-12 08:27:11 +00:00
< !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2023-10-20 09:31:28 +00:00
<!-- This file is generated by Nim. -->
2024-02-12 08:27:11 +00:00
< html xmlns = "http://www.w3.org/1999/xhtml" xml:lang = "en" lang = "en" >
2023-10-20 09:31:28 +00:00
< head >
< meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" / >
2024-02-12 08:27:11 +00:00
2023-10-20 09:31:28 +00:00
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
<!-- Favicon -->
< link rel = "shortcut icon" href = "" / >
< link rel = "icon" type = "image/png" sizes = "32x32" href = "" >
2024-02-12 08:27:11 +00:00
<!-- Google fonts -->
< link href = 'https://fonts.googleapis.com/css?family=Lato:400,600,900' rel = 'stylesheet' type = 'text/css' / >
< link href = 'https://fonts.googleapis.com/css?family=Source+Code+Pro:400,500,600' rel = 'stylesheet' type = 'text/css' / >
2023-10-20 09:31:28 +00:00
<!-- CSS -->
2024-02-12 08:27:11 +00:00
< title > libp2p/crypto/secp< / title >
2023-10-20 09:31:28 +00:00
< link rel = "stylesheet" type = "text/css" href = "../../nimdoc.out.css" >
< script type = "text/javascript" src = "../../dochack.js" > < / script >
2024-02-12 08:27:11 +00:00
< script type = "text/javascript" >
function main() {
var pragmaDots = document.getElementsByClassName("pragmadots");
for (var i = 0; i < pragmaDots.length ; i + + ) {
pragmaDots[i].onclick = function(event) {
// Hide tease
event.target.parentNode.style.display = "none";
// Show actual
event.target.parentNode.nextElementSibling.style.display = "inline";
}
}
function switchTheme(e) {
if (e.target.checked) {
document.documentElement.setAttribute('data-theme', 'dark');
localStorage.setItem('theme', 'dark');
} else {
document.documentElement.setAttribute('data-theme', 'light');
localStorage.setItem('theme', 'light');
}
}
const toggleSwitch = document.querySelector('.theme-switch input[type="checkbox"]');
if (toggleSwitch !== null) {
toggleSwitch.addEventListener('change', switchTheme, false);
}
var currentTheme = localStorage.getItem('theme');
if (!currentTheme & & window.matchMedia('(prefers-color-scheme: dark)').matches) {
currentTheme = 'dark';
}
if (currentTheme) {
document.documentElement.setAttribute('data-theme', currentTheme);
if (currentTheme === 'dark' & & toggleSwitch !== null) {
toggleSwitch.checked = true;
}
}
}
window.addEventListener('DOMContentLoaded', main);
< / script >
2023-10-20 09:31:28 +00:00
< / head >
< body >
2024-02-12 08:27:11 +00:00
< div class = "document" id = "documentId" >
< div class = "container" >
< h1 class = "title" > libp2p/crypto/secp< / h1 >
< div class = "row" >
2023-10-20 09:31:28 +00:00
< div class = "three columns" >
2024-02-12 08:27:11 +00:00
< div class = "theme-switch-wrapper" >
< label class = "theme-switch" for = "checkbox" >
< input type = "checkbox" id = "checkbox" / >
< div class = "slider round" > < / div >
< / label >
< em > Dark Mode< / em >
< / div >
< div id = "global-links" >
< ul class = "simple" >
< li >
< a href = "../../theindex.html" > Index< / a >
< / li >
< / ul >
< / div >
< div id = "searchInputDiv" >
Search: < input type = "text" id = "searchInput"
onkeyup="search()" />
< / div >
< div >
Group by:
< select onchange = "groupBy(this.value)" >
< option value = "section" > Section< / option >
< option value = "type" > Type< / option >
< / select >
< / div >
< script type = "text/javascript" >
2023-10-20 09:31:28 +00:00
function main2() {
// Create the slider
var firstSlider = document.getElementsByClassName("theme-switch-wrapper")[0];
var newSlider = document.createRange().createContextualFragment(`
< div class = "theme-switch-wrapper" >
< label class = "theme-switch" for = "internalcheckbox" >
< input type = "checkbox" id = "internalcheckbox" >
< div class = "slider round" > < / div >
< / label >
< em > Internal< / em >
< / div >
`);
var sliderInst = firstSlider.after(newSlider);
// Restore slider state from storage
var currentMode = localStorage.getItem('privateMode');
if (currentMode == "private") {
document.getElementById("internalcheckbox").checked = true;
} else {
hidePrivateProcs();
}
document.getElementById("internalcheckbox").onclick = togglePrivateProcs;
}
function hidePrivateProcs() {
var toHide = document.getElementsByClassName("tohide");
for (var i = 0; i < toHide.length ; i + + ) {
var pragmas = toHide[i].querySelectorAll("span.Identifier");
var public = false;
for (var z = 0; z < pragmas.length ; z + + ) {
if (pragmas[z].innerText == "public") {
public = true;
break;
}
}
if (public == false) {
toHide[i].style.display = "none";
toHide[i].classList.add("hidden");
links = document.querySelectorAll("a[href='#" + encodeURIComponent(toHide[i].id) + "']");
for (var y = 0; y < links.length ; y + + ) {
links[y].parentNode.style.display = "none";
links[y].parentNode.classList.add("hidden");
}
}
}
// TOC
var nestedSections = document.getElementsByClassName("nested-toc-section");
for (var i = 0; i < nestedSections.length ; i + + ) {
if (nestedSections[i].querySelectorAll("li:not(.hidden)").length == 0) {
nestedSections[i].style.display = "none";
nestedSections[i].classList.add("hidden");
}
}
var sections = document.getElementsByClassName("simple-toc-section");
for (var i = 0; i < sections.length ; i + + ) {
if (sections[i].querySelectorAll(".nested-toc-section:not(.hidden)").length == 0) {
sections[i].parentNode.style.display = "none";
sections[i].parentNode.classList.add("hidden");
}
}
// Sections
var sections = document.getElementsByClassName("section");
for (var i = 0; i < sections.length ; i + + ) {
if (sections[i].querySelectorAll(".item > div").length == 0) continue;
if (sections[i].querySelectorAll(".item > div:not(.hidden)").length == 0) {
sections[i].style.display = "none";
sections[i].classList.add("hidden");
}
}
}
function showPrivateProcs() {
var toHide = Array.from(document.getElementsByClassName("hidden"));
for (var i = 0; i < toHide.length ; i + + ) {
toHide[i].style.display = "";
toHide[i].classList.remove("hidden");
}
}
function togglePrivateProcs() {
if (document.getElementById("internalcheckbox").checked) {
localStorage.setItem('privateMode', 'private');
showPrivateProcs();
} else {
localStorage.setItem('privateMode', 'public');
hidePrivateProcs();
}
}
window.addEventListener("DOMContentLoaded", main2);
< / script >
< ul class = "simple simple-toc" id = "toc-list" >
< li >
2024-02-12 08:27:11 +00:00
< a class = "reference reference-toplevel" href = "#7" id = "57" > Types< / a >
< ul class = "simple simple-toc-section" >
< li > < a class = "reference" href = "#SkKeyPair"
title="SkKeyPair = distinct secp256k1.SkKeyPair">SkKeyPair< / a > < / li >
< li > < a class = "reference" href = "#SkPrivateKey"
title="SkPrivateKey = distinct secp256k1.SkSecretKey">SkPrivateKey< / a > < / li >
< li > < a class = "reference" href = "#SkPublicKey"
title="SkPublicKey = distinct secp256k1.SkPublicKey">SkPublicKey< / a > < / li >
< li > < a class = "reference" href = "#SkSignature"
title="SkSignature = distinct secp256k1.SkSignature">SkSignature< / a > < / li >
< / ul >
2023-10-20 09:31:28 +00:00
< / li >
< li >
2024-02-12 08:27:11 +00:00
< a class = "reference reference-toplevel" href = "#10" id = "60" > Consts< / a >
< ul class = "simple simple-toc-section" >
< li > < a class = "reference" href = "#SkRawPrivateKeySize"
title="SkRawPrivateKeySize = 32">SkRawPrivateKeySize< / a > < / li >
< li > < a class = "reference" href = "#SkRawPublicKeySize"
title="SkRawPublicKeySize = 33">SkRawPublicKeySize< / a > < / li >
< li > < a class = "reference" href = "#SkRawSignatureSize"
title="SkRawSignatureSize = 65">SkRawSignatureSize< / a > < / li >
< / ul >
2023-10-20 09:31:28 +00:00
< / li >
< li >
2024-02-12 08:27:11 +00:00
< a class = "reference reference-toplevel" href = "#12" id = "62" > Procs< / a >
< ul class = "simple simple-toc-section" >
2023-10-20 09:31:28 +00:00
< ul class = "simple nested-toc-section" > $
2024-02-12 08:27:11 +00:00
< li > < a class = "reference" href = "#%24%2CSkKeyPair"
title="`$`(key: SkKeyPair): string">`$`(key: SkKeyPair): string< / a > < / li >
< li > < a class = "reference" href = "#%24%2CSkPrivateKey"
title="`$`(key: SkPrivateKey): string">`$`(key: SkPrivateKey): string< / a > < / li >
< li > < a class = "reference" href = "#%24%2CSkPublicKey"
title="`$`(key: SkPublicKey): string">`$`(key: SkPublicKey): string< / a > < / li >
< li > < a class = "reference" href = "#%24%2CSkSignature"
title="`$`(key: SkSignature): string">`$`(key: SkSignature): string< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > ==
< li > < a class = "reference" href = "#%3D%3D%2CSkKeyPair%2CSkKeyPair"
title="`==`(a, b: SkKeyPair): bool">`==`(a, b: SkKeyPair): bool< / a > < / li >
< li > < a class = "reference" href = "#%3D%3D%2CSkPrivateKey%2CSkPrivateKey"
title="`==`(a, b: SkPrivateKey): bool">`==`(a, b: SkPrivateKey): bool< / a > < / li >
< li > < a class = "reference" href = "#%3D%3D%2CSkPublicKey%2CSkPublicKey"
title="`==`(a, b: SkPublicKey): bool">`==`(a, b: SkPublicKey): bool< / a > < / li >
< li > < a class = "reference" href = "#%3D%3D%2CSkSignature%2CSkSignature"
title="`==`(a, b: SkSignature): bool">`==`(a, b: SkSignature): bool< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > clear
< li > < a class = "reference" href = "#clear%2CSkPrivateKey"
title="clear(key: var SkPrivateKey)">clear(key: var SkPrivateKey)< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > getBytes
< li > < a class = "reference" href = "#getBytes%2CSkPrivateKey"
title="getBytes(key: SkPrivateKey): seq[byte]">getBytes(key: SkPrivateKey): seq[byte]< / a > < / li >
< li > < a class = "reference" href = "#getBytes%2CSkPublicKey"
title="getBytes(key: SkPublicKey): seq[byte]">getBytes(key: SkPublicKey): seq[byte]< / a > < / li >
< li > < a class = "reference" href = "#getBytes%2CSkSignature"
title="getBytes(sig: SkSignature): seq[byte]">getBytes(sig: SkSignature): seq[byte]< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > getPublicKey
< li > < a class = "reference" href = "#getPublicKey%2CSkPrivateKey"
title="getPublicKey(key: SkPrivateKey): SkPublicKey">getPublicKey(key: SkPrivateKey): SkPublicKey< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > init
< li > < a class = "reference" href = "#init%2CSkPrivateKey%2CopenArray%5Bbyte%5D"
title="init(key: var SkPrivateKey; data: openArray[byte]): SkResult[void]">init(key: var SkPrivateKey; data: openArray[byte]): SkResult[void]< / a > < / li >
< li > < a class = "reference" href = "#init%2CSkPrivateKey%2Cstring"
title="init(key: var SkPrivateKey; data: string): SkResult[void]">init(key: var SkPrivateKey; data: string): SkResult[void]< / a > < / li >
< li > < a class = "reference" href = "#init%2CSkPublicKey%2CopenArray%5Bbyte%5D"
title="init(key: var SkPublicKey; data: openArray[byte]): SkResult[void]">init(key: var SkPublicKey; data: openArray[byte]): SkResult[void]< / a > < / li >
< li > < a class = "reference" href = "#init%2CSkPublicKey%2Cstring"
title="init(key: var SkPublicKey; data: string): SkResult[void]">init(key: var SkPublicKey; data: string): SkResult[void]< / a > < / li >
< li > < a class = "reference" href = "#init%2CSkSignature%2CopenArray%5Bbyte%5D"
title="init(sig: var SkSignature; data: openArray[byte]): SkResult[void]">init(sig: var SkSignature; data: openArray[byte]): SkResult[void]< / a > < / li >
< li > < a class = "reference" href = "#init%2CSkSignature%2Cstring"
title="init(sig: var SkSignature; data: string): SkResult[void]">init(sig: var SkSignature; data: string): SkResult[void]< / a > < / li >
< li > < a class = "reference" href = "#init%2Ctypedesc%5BSkPrivateKey%5D%2CopenArray%5Bbyte%5D"
title="init(t: typedesc[SkPrivateKey]; data: openArray[byte]): SkResult[SkPrivateKey]">init(t: typedesc[SkPrivateKey]; data: openArray[byte]): SkResult[SkPrivateKey]< / a > < / li >
< li > < a class = "reference" href = "#init%2Ctypedesc%5BSkPrivateKey%5D%2Cstring"
title="init(t: typedesc[SkPrivateKey]; data: string): SkResult[SkPrivateKey]">init(t: typedesc[SkPrivateKey]; data: string): SkResult[SkPrivateKey]< / a > < / li >
< li > < a class = "reference" href = "#init%2Ctypedesc%5BSkPublicKey%5D%2CopenArray%5Bbyte%5D"
title="init(t: typedesc[SkPublicKey]; data: openArray[byte]): SkResult[SkPublicKey]">init(t: typedesc[SkPublicKey]; data: openArray[byte]): SkResult[SkPublicKey]< / a > < / li >
< li > < a class = "reference" href = "#init%2Ctypedesc%5BSkPublicKey%5D%2Cstring"
title="init(t: typedesc[SkPublicKey]; data: string): SkResult[SkPublicKey]">init(t: typedesc[SkPublicKey]; data: string): SkResult[SkPublicKey]< / a > < / li >
< li > < a class = "reference" href = "#init%2Ctypedesc%5BSkSignature%5D%2CopenArray%5Bbyte%5D"
title="init(t: typedesc[SkSignature]; data: openArray[byte]): SkResult[SkSignature]">init(t: typedesc[SkSignature]; data: openArray[byte]): SkResult[SkSignature]< / a > < / li >
< li > < a class = "reference" href = "#init%2Ctypedesc%5BSkSignature%5D%2Cstring"
title="init(t: typedesc[SkSignature]; data: string): SkResult[SkSignature]">init(t: typedesc[SkSignature]; data: string): SkResult[SkSignature]< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > random
< li > < a class = "reference" href = "#random%2Ctypedesc%5BSkKeyPair%5D%2CHmacDrbgContext"
title="random(t: typedesc[SkKeyPair]; rng: var HmacDrbgContext): SkKeyPair">random(t: typedesc[SkKeyPair]; rng: var HmacDrbgContext): SkKeyPair< / a > < / li >
< li > < a class = "reference" href = "#random%2Ctypedesc%5BSkPrivateKey%5D%2CHmacDrbgContext"
title="random(t: typedesc[SkPrivateKey]; rng: var HmacDrbgContext): SkPrivateKey">random(t: typedesc[SkPrivateKey]; rng: var HmacDrbgContext): SkPrivateKey< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > sign
< li > < a class = "reference" href = "#sign%2CSkPrivateKey%2CopenArray%5BT%5D"
title="sign[T: byte | char](key: SkPrivateKey; msg: openArray[T]): SkSignature">sign[T: byte | char](key: SkPrivateKey; msg: openArray[T]): SkSignature< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > toBytes
< li > < a class = "reference" href = "#toBytes%2CSkPrivateKey%2CopenArray%5Bbyte%5D"
title="toBytes(key: SkPrivateKey; data: var openArray[byte]): SkResult[int]">toBytes(key: SkPrivateKey; data: var openArray[byte]): SkResult[int]< / a > < / li >
< li > < a class = "reference" href = "#toBytes%2CSkPublicKey%2CopenArray%5Bbyte%5D"
title="toBytes(key: SkPublicKey; data: var openArray[byte]): SkResult[int]">toBytes(key: SkPublicKey; data: var openArray[byte]): SkResult[int]< / a > < / li >
< li > < a class = "reference" href = "#toBytes%2CSkSignature%2CopenArray%5Bbyte%5D"
title="toBytes(sig: SkSignature; data: var openArray[byte]): int">toBytes(sig: SkSignature; data: var openArray[byte]): int< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > verify
< li > < a class = "reference" href = "#verify%2CSkSignature%2CopenArray%5BT%5D%2CSkPublicKey"
title="verify[T: byte | char](sig: SkSignature; msg: openArray[T]; key: SkPublicKey): bool">verify[T: byte | char](sig: SkSignature; msg: openArray[T]; key: SkPublicKey): bool< / a > < / li >
< / ul >
< / ul >
2023-10-20 09:31:28 +00:00
< / li >
< li >
2024-02-12 08:27:11 +00:00
< a class = "reference reference-toplevel" href = "#18" id = "68" > Templates< / a >
< ul class = "simple simple-toc-section" >
2023-10-20 09:31:28 +00:00
< ul class = "simple nested-toc-section" > pubkey
2024-02-12 08:27:11 +00:00
< li > < a class = "reference" href = "#pubkey.t%2CSkKeyPair"
title="pubkey(v: SkKeyPair): SkPublicKey">pubkey(v: SkKeyPair): SkPublicKey< / a > < / li >
2023-10-20 09:31:28 +00:00
2024-02-12 08:27:11 +00:00
< / ul >
< ul class = "simple nested-toc-section" > seckey
< li > < a class = "reference" href = "#seckey.t%2CSkKeyPair"
title="seckey(v: SkKeyPair): SkPrivateKey">seckey(v: SkKeyPair): SkPrivateKey< / a > < / li >
2023-10-20 09:31:28 +00:00
2024-02-12 08:27:11 +00:00
< / ul >
2023-10-20 09:31:28 +00:00
2024-02-12 08:27:11 +00:00
< / ul >
2023-10-20 09:31:28 +00:00
< / li >
< / ul >
< / div >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L1"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L1" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< div class = "nine columns" id = "content" >
2024-02-12 08:27:11 +00:00
< div id = "tocRoot" > < / div >
< p class = "module-desc" > < / p >
< div class = "section" id = "7" >
< h1 > < a class = "toc-backref" href = "#7" > Types< / a > < / h1 >
< dl class = "item" >
< div id = "SkKeyPair" class = "tohide" >
2023-10-20 09:31:28 +00:00
< dt > < pre > < a href = "secp.html#SkKeyPair" > < span class = "Identifier" > SkKeyPair< / span > < / a > < span class = "Other" > =< / span > < span class = "Keyword" > distinct< / span > < span class = "Identifier" > secp256k1< / span > < span class = "Other" > .< / span > < span class = "Identifier" > SkKeyPair< / span > < / pre > < / dt >
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L33"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L33" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "SkPrivateKey" class = "tohide" >
< dt > < pre > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > =< / span > < span class = "Keyword" > distinct< / span > < span class = "Identifier" > secp256k1< / span > < span class = "Other" > .< / span > < span class = "Identifier" > SkSecretKey< / span > < / pre > < / dt >
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L30"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L30" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "SkPublicKey" class = "tohide" >
< dt > < pre > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > =< / span > < span class = "Keyword" > distinct< / span > < span class = "Identifier" > secp256k1< / span > < span class = "Other" > .< / span > < span class = "Identifier" > SkPublicKey< / span > < / pre > < / dt >
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L31"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L31" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "SkSignature" class = "tohide" >
< dt > < pre > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > =< / span > < span class = "Keyword" > distinct< / span > < span class = "Identifier" > secp256k1< / span > < span class = "Other" > .< / span > < span class = "Identifier" > SkSignature< / span > < / pre > < / dt >
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L32"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L32" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< / dl > < / div >
2023-10-20 09:31:28 +00:00
< div class = "section" id = "10" >
2024-02-12 08:27:11 +00:00
< h1 > < a class = "toc-backref" href = "#10" > Consts< / a > < / h1 >
< dl class = "item" >
< div id = "SkRawPrivateKeySize" class = "tohide" >
2023-10-20 09:31:28 +00:00
< dt > < pre > < a href = "secp.html#SkRawPrivateKeySize" > < span class = "Identifier" > SkRawPrivateKeySize< / span > < / a > < span class = "Other" > =< / span > < span class = "DecNumber" > 32< / span > < / pre > < / dt >
< dd >
Size of private key in octets (bytes)
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L21"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L21" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "SkRawPublicKeySize" class = "tohide" >
< dt > < pre > < a href = "secp.html#SkRawPublicKeySize" > < span class = "Identifier" > SkRawPublicKeySize< / span > < / a > < span class = "Other" > =< / span > < span class = "DecNumber" > 33< / span > < / pre > < / dt >
< dd >
Size of public key in octets (bytes)
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L25"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L25" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "SkRawSignatureSize" class = "tohide" >
< dt > < pre > < a href = "secp.html#SkRawSignatureSize" > < span class = "Identifier" > SkRawSignatureSize< / span > < / a > < span class = "Other" > =< / span > < span class = "DecNumber" > 65< / span > < / pre > < / dt >
< dd >
Size of signature in octets (bytes)
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L23"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L23" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< / dl > < / div >
2023-10-20 09:31:28 +00:00
< div class = "section" id = "12" >
2024-02-12 08:27:11 +00:00
< h1 > < a class = "toc-backref" href = "#12" > Procs< / a > < / h1 >
< dl class = "item" >
< div id = "$,SkKeyPair" class = "tohide" >
< dt > < pre > < span class = "Keyword" > func< / span > < a href = "#%24%2CSkKeyPair" > < span class = "Identifier" > `$`< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkKeyPair" > < span class = "Identifier" > SkKeyPair< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > string< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L208"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L208" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "$,SkPrivateKey" class = "tohide" >
2024-02-12 08:27:11 +00:00
< dt > < pre > < span class = "Keyword" > func< / span > < a href = "#%24%2CSkPrivateKey" > < span class = "Identifier" > `$`< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > string< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L205"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L205" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "$,SkPublicKey" class = "tohide" >
2024-02-12 08:27:11 +00:00
< dt > < pre > < span class = "Keyword" > func< / span > < a href = "#%24%2CSkPublicKey" > < span class = "Identifier" > `$`< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > string< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L206"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L206" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "$,SkSignature" class = "tohide" >
2024-02-12 08:27:11 +00:00
< dt > < pre > < span class = "Keyword" > func< / span > < a href = "#%24%2CSkSignature" > < span class = "Identifier" > `$`< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > string< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L207"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L207" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< div id = "==,SkKeyPair,SkKeyPair" class = "tohide" >
< dt > < pre > < span class = "Keyword" > func< / span > < a href = "#%3D%3D%2CSkKeyPair%2CSkKeyPair" > < span class = "Identifier" > `==`< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > a< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > b< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkKeyPair" > < span class = "Identifier" > SkKeyPair< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > bool< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L216"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L216" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "==,SkPrivateKey,SkPrivateKey" class = "tohide" >
2024-02-12 08:27:11 +00:00
< dt > < pre > < span class = "Keyword" > func< / span > < a href = "#%3D%3D%2CSkPrivateKey%2CSkPrivateKey" > < span class = "Identifier" > `==`< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > a< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > b< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > bool< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L210"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L210" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "==,SkPublicKey,SkPublicKey" class = "tohide" >
2024-02-12 08:27:11 +00:00
< dt > < pre > < span class = "Keyword" > func< / span > < a href = "#%3D%3D%2CSkPublicKey%2CSkPublicKey" > < span class = "Identifier" > `==`< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > a< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > b< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > bool< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L212"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L212" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "==,SkSignature,SkSignature" class = "tohide" >
2024-02-12 08:27:11 +00:00
< dt > < pre > < span class = "Keyword" > func< / span > < a href = "#%3D%3D%2CSkSignature%2CSkSignature" > < span class = "Identifier" > `==`< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > a< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > b< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > bool< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L214"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L214" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< div id = "clear,SkPrivateKey" class = "tohide" >
< dt > < pre > < span class = "Keyword" > func< / span > < a href = "#clear%2CSkPrivateKey" > < span class = "Identifier" > clear< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > )< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L203"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L203" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< div id = "getBytes,SkPrivateKey" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#getBytes%2CSkPrivateKey" > < span class = "Identifier" > getBytes< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > seq< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > {.< span class = "Identifier" > inline< / span > < span class = "Other" > ,< / span > < span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
Serialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > private< / span > < span class = "Identifier" > key< / span > < / span > < / tt > and return it.
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L179"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L179" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "getBytes,SkPublicKey" class = "tohide" >
2024-02-12 08:27:11 +00:00
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#getBytes%2CSkPublicKey" > < span class = "Identifier" > getBytes< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > seq< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > {.< span class = "Identifier" > inline< / span > < span class = "Other" > ,< / span > < span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
Serialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > public< / span > < span class = "Identifier" > key< / span > < / span > < / tt > and return it.
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L183"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L183" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "getBytes,SkSignature" class = "tohide" >
2024-02-12 08:27:11 +00:00
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#getBytes%2CSkSignature" > < span class = "Identifier" > getBytes< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > sig< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > seq< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > {.< span class = "Identifier" > inline< / span > < span class = "Other" > ,< / span > < span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
Serialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > signature< / span > < / span > < / tt > and return it.
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L187"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L187" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< div id = "getPublicKey,SkPrivateKey" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#getPublicKey%2CSkPrivateKey" > < span class = "Identifier" > getPublicKey< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
Calculate and return Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > public< / span > < span class = "Identifier" > key< / span > < / span > < / tt > from < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > private< / span > < span class = "Identifier" > key< / span > < / span > < / tt > < tt class = "docutils literal" > < span class = "pre" > key< / span > < / tt > .
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L143"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L143" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< div id = "init,SkPrivateKey,openArray[byte]" class = "tohide" >
2023-10-20 09:31:28 +00:00
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2CSkPrivateKey%2CopenArray%5Bbyte%5D" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < span class = "Identifier" > void< / span > < span class = "Other" > ]< / span > {.
2024-02-12 08:27:11 +00:00
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > private< / span > < span class = "Identifier" > key< / span > < / span > < / tt > < tt class = "docutils literal" > < span class = "pre" > key< / span > < / tt > from raw binary representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L56"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L56" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,SkPrivateKey,string" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2CSkPrivateKey%2Cstring" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > string< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < span class = "Identifier" > void< / span > < span class = "Other" > ]< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span >
2024-02-12 08:27:11 +00:00
< span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > private< / span > < span class = "Identifier" > key< / span > < / span > < / tt > < tt class = "docutils literal" > < span class = "pre" > key< / span > < / tt > from hexadecimal string representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L62"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L62" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,SkPublicKey,openArray[byte]" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2CSkPublicKey%2CopenArray%5Bbyte%5D" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < span class = "Identifier" > void< / span > < span class = "Other" > ]< / span > {.
2024-02-12 08:27:11 +00:00
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > public< / span > < span class = "Identifier" > key< / span > < / span > < / tt > < tt class = "docutils literal" > < span class = "pre" > key< / span > < / tt > from raw binary representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L68"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L68" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,SkPublicKey,string" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2CSkPublicKey%2Cstring" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > string< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < span class = "Identifier" > void< / span > < span class = "Other" > ]< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span >
2024-02-12 08:27:11 +00:00
< span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > public< / span > < span class = "Identifier" > key< / span > < / span > < / tt > < tt class = "docutils literal" > < span class = "pre" > key< / span > < / tt > from hexadecimal string representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L74"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L74" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,SkSignature,openArray[byte]" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2CSkSignature%2CopenArray%5Bbyte%5D" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > sig< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < span class = "Identifier" > void< / span > < span class = "Other" > ]< / span > {.
2024-02-12 08:27:11 +00:00
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > signature< / span > < / span > < / tt > < tt class = "docutils literal" > < span class = "pre" > sig< / span > < / tt > from raw binary representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L80"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L80" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,SkSignature,string" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2CSkSignature%2Cstring" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > sig< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > string< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < span class = "Identifier" > void< / span > < span class = "Other" > ]< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span >
2024-02-12 08:27:11 +00:00
< span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > signature< / span > < / span > < / tt > < tt class = "docutils literal" > < span class = "pre" > sig< / span > < / tt > from hexadecimal string representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L86"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L86" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,typedesc[SkPrivateKey],openArray[byte]" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2Ctypedesc%5BSkPrivateKey%5D%2CopenArray%5Bbyte%5D" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > t< / span > < span class = "Other" > :< / span > < span class = "Identifier" > typedesc< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > ]< / span > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span >
< a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > ]< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
< p > Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > private< / span > < span class = "Identifier" > key< / span > < / span > < / tt > from raw binary representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .< / p >
< p > Procedure returns < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > private< / span > < span class = "Identifier" > key< / span > < / span > < / tt > on success.< / p >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L97"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L97" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,typedesc[SkPrivateKey],string" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2Ctypedesc%5BSkPrivateKey%5D%2Cstring" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > t< / span > < span class = "Other" > :< / span > < span class = "Identifier" > typedesc< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > ]< / span > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > string< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > ]< / span > {.
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
< p > Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > private< / span > < span class = "Identifier" > key< / span > < / span > < / tt > from hexadecimal string representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .< / p >
< p > Procedure returns < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > private< / span > < span class = "Identifier" > key< / span > < / span > < / tt > on success.< / p >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L104"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L104" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,typedesc[SkPublicKey],openArray[byte]" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2Ctypedesc%5BSkPublicKey%5D%2CopenArray%5Bbyte%5D" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > t< / span > < span class = "Other" > :< / span > < span class = "Identifier" > typedesc< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > ]< / span > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > ]< / span > {.
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
< p > Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > public< / span > < span class = "Identifier" > key< / span > < / span > < / tt > from raw binary representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .< / p >
< p > Procedure returns < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > public< / span > < span class = "Identifier" > key< / span > < / span > < / tt > on success.< / p >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L111"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L111" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,typedesc[SkPublicKey],string" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2Ctypedesc%5BSkPublicKey%5D%2Cstring" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > t< / span > < span class = "Other" > :< / span > < span class = "Identifier" > typedesc< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > ]< / span > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > string< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > ]< / span > {.
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
< p > Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > public< / span > < span class = "Identifier" > key< / span > < / span > < / tt > from hexadecimal string representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .< / p >
< p > Procedure returns < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > public< / span > < span class = "Identifier" > key< / span > < / span > < / tt > on success.< / p >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L119"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L119" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,typedesc[SkSignature],openArray[byte]" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2Ctypedesc%5BSkSignature%5D%2CopenArray%5Bbyte%5D" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > t< / span > < span class = "Other" > :< / span > < span class = "Identifier" > typedesc< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > ]< / span > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > ]< / span > {.
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
< p > Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > signature< / span > < / span > < / tt > from raw binary representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .< / p >
< p > Procedure returns < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > signature< / span > < / span > < / tt > on success.< / p >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L127"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L127" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "init,typedesc[SkSignature],string" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#init%2Ctypedesc%5BSkSignature%5D%2Cstring" > < span class = "Identifier" > init< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > t< / span > < span class = "Other" > :< / span > < span class = "Identifier" > typedesc< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > ]< / span > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Identifier" > string< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > ]< / span > {.
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
< p > Initialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > signature< / span > < / span > < / tt > from hexadecimal string representation < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .< / p >
< p > Procedure returns < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > signature< / span > < / span > < / tt > on success.< / p >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L135"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L135" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< div id = "random,typedesc[SkKeyPair],HmacDrbgContext" class = "tohide" >
2023-10-20 09:31:28 +00:00
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#random%2Ctypedesc%5BSkKeyPair%5D%2CHmacDrbgContext" > < span class = "Identifier" > random< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > t< / span > < span class = "Other" > :< / span > < span class = "Identifier" > typedesc< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkKeyPair" > < span class = "Identifier" > SkKeyPair< / span > < / a > < span class = "Other" > ]< / span > < span class = "Other" > ;< / span > < span class = "Identifier" > rng< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < span class = "Identifier" > HmacDrbgContext< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkKeyPair" > < span class = "Identifier" > SkKeyPair< / span > < / a > {.
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L43"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L43" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "random,typedesc[SkPrivateKey],HmacDrbgContext" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#random%2Ctypedesc%5BSkPrivateKey%5D%2CHmacDrbgContext" > < span class = "Identifier" > random< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > t< / span > < span class = "Other" > :< / span > < span class = "Identifier" > typedesc< / span > < span class = "Other" > [< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > ]< / span > < span class = "Other" > ;< / span > < span class = "Identifier" > rng< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < span class = "Identifier" > HmacDrbgContext< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > {.
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L35"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L35" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< div id = "sign,SkPrivateKey,openArray[T]" class = "tohide" >
2023-10-20 09:31:28 +00:00
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#sign%2CSkPrivateKey%2CopenArray%5BT%5D" > < span class = "Identifier" > sign< / span > < / a > < span class = "Other" > [< / span > < span class = "Identifier" > T< / span > < span class = "Other" > :< / span > < span class = "Identifier" > byte< / span > < span class = "Operator" > |< / span > < span class = "Identifier" > char< / span > < span class = "Other" > ]< / span > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > msg< / span > < span class = "Other" > :< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > T< / span > < span class = "Other" > ]< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > {.
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
Sign message < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > msg< / span > < / span > < / tt > using private key < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > key< / span > < / span > < / tt > and return signature object.
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L193"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L193" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< div id = "toBytes,SkPrivateKey,openArray[byte]" class = "tohide" >
2023-10-20 09:31:28 +00:00
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#toBytes%2CSkPrivateKey%2CopenArray%5Bbyte%5D" > < span class = "Identifier" > toBytes< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < span class = "Identifier" > int< / span > < span class = "Other" > ]< / span > {.
2024-02-12 08:27:11 +00:00
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
< p > Serialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > private< / span > < span class = "Identifier" > key< / span > < / span > < / tt > < tt class = "docutils literal" > < span class = "pre" > key< / span > < / tt > to raw binary form and store it to < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .< / p >
< p > Procedure returns number of bytes (octets) needed to store Secp256k1 private key.< / p >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L147"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L147" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "toBytes,SkPublicKey,openArray[byte]" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#toBytes%2CSkPublicKey%2CopenArray%5Bbyte%5D" > < span class = "Identifier" > toBytes< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > SkResult< / span > < span class = "Other" > [< / span > < span class = "Identifier" > int< / span > < span class = "Other" > ]< / span > {.
2024-02-12 08:27:11 +00:00
< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
< p > Serialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > public< / span > < span class = "Identifier" > key< / span > < / span > < / tt > < tt class = "docutils literal" > < span class = "pre" > key< / span > < / tt > to raw binary form and store it to < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .< / p >
< p > Procedure returns number of bytes (octets) needed to store Secp256k1 public key.< / p >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L159"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L159" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
< div id = "toBytes,SkSignature,openArray[byte]" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#toBytes%2CSkSignature%2CopenArray%5Bbyte%5D" > < span class = "Identifier" > toBytes< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > sig< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > data< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > int< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span >
2024-02-12 08:27:11 +00:00
< span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
2023-10-20 09:31:28 +00:00
< dd >
< p > Serialize Secp256k1 < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > signature< / span > < / span > < / tt > < tt class = "docutils literal" > < span class = "pre" > sig< / span > < / tt > to raw binary form and store it to < tt class = "docutils literal" > < span class = "pre" > data< / span > < / tt > .< / p >
< p > Procedure returns number of bytes (octets) needed to store Secp256k1 signature.< / p >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L171"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L171" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< div id = "verify,SkSignature,openArray[T],SkPublicKey" class = "tohide" >
2023-10-20 09:31:28 +00:00
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#verify%2CSkSignature%2CopenArray%5BT%5D%2CSkPublicKey" > < span class = "Identifier" > verify< / span > < / a > < span class = "Other" > [< / span > < span class = "Identifier" > T< / span > < span class = "Other" > :< / span > < span class = "Identifier" > byte< / span > < span class = "Operator" > |< / span > < span class = "Identifier" > char< / span > < span class = "Other" > ]< / span > < span class = "Other" > (< / span > < span class = "Identifier" > sig< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkSignature" > < span class = "Identifier" > SkSignature< / span > < / a > < span class = "Other" > ;< / span > < span class = "Identifier" > msg< / span > < span class = "Other" > :< / span > < span class = "Identifier" > openArray< / span > < span class = "Other" > [< / span > < span class = "Identifier" > T< / span > < span class = "Other" > ]< / span > < span class = "Other" > ;< / span >
< span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > bool< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L198"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L198" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< / dl > < / div >
2023-10-20 09:31:28 +00:00
< div class = "section" id = "18" >
2024-02-12 08:27:11 +00:00
< h1 > < a class = "toc-backref" href = "#18" > Templates< / a > < / h1 >
< dl class = "item" >
< div id = "pubkey.t,SkKeyPair" class = "tohide" >
2023-10-20 09:31:28 +00:00
< dt > < pre > < span class = "Keyword" > template< / span > < a href = "#pubkey.t%2CSkKeyPair" > < span class = "Identifier" > pubkey< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > v< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkKeyPair" > < span class = "Identifier" > SkKeyPair< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPublicKey" > < span class = "Identifier" > SkPublicKey< / span > < / a > < / pre > < / dt >
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L53"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L53" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< div id = "seckey.t,SkKeyPair" class = "tohide" >
2023-10-20 09:31:28 +00:00
< dt > < pre > < span class = "Keyword" > template< / span > < a href = "#seckey.t%2CSkKeyPair" > < span class = "Identifier" > seckey< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > v< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkKeyPair" > < span class = "Identifier" > SkKeyPair< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < a href = "secp.html#SkPrivateKey" > < span class = "Identifier" > SkPrivateKey< / span > < / a > < / pre > < / dt >
< dd >
2024-02-12 08:27:11 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/p2p-research/libp2p/crypto/secp.nim#L50"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/secp.nim#L50" class = "link-seesrc" target = "_blank" > Edit< / a >
2023-10-20 09:31:28 +00:00
< / dd >
< / div >
2024-02-12 08:27:11 +00:00
< / dl > < / div >
2023-10-20 09:31:28 +00:00
< / div >
< / div >
2024-02-12 08:27:11 +00:00
< div class = "row" >
2023-10-20 09:31:28 +00:00
< div class = "twelve-columns footer" >
< span class = "nim-sprite" > < / span >
2024-02-12 08:27:11 +00:00
< br / >
2024-06-03 13:40:28 +00:00
< small style = "color: var(--hint);" > Made with Nim. Generated: 2024-06-03 13:40:12 UTC< / small >
2023-10-20 09:31:28 +00:00
< / div >
< / div >
< / div >
2024-02-12 08:27:11 +00:00
< / div >
2023-10-20 09:31:28 +00:00
< / body >
< / html >