2024-03-19 16:58:34 +00:00
<?xml version="1.0" encoding="utf-8" ?>
< !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<!-- This file is generated by Nim. -->
< html xmlns = "http://www.w3.org/1999/xhtml" xml:lang = "en" lang = "en" >
< head >
< meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" / >
< 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 = "" >
<!-- 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' / >
<!-- CSS -->
< title > libp2p/crypto/curve25519< / title >
< link rel = "stylesheet" type = "text/css" href = "../../nimdoc.out.css" >
< script type = "text/javascript" src = "../../dochack.js" > < / script >
< 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 >
< / head >
< body >
< div class = "document" id = "documentId" >
< div class = "container" >
< h1 class = "title" > libp2p/crypto/curve25519< / h1 >
< div class = "row" >
< div class = "three columns" >
< 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" >
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 >
< a class = "reference reference-toplevel" href = "#7" id = "57" > Types< / a >
< ul class = "simple simple-toc-section" >
< li > < a class = "reference" href = "#Curve25519"
title="Curve25519 = object">Curve25519< / a > < / li >
< li > < a class = "reference" href = "#Curve25519Error"
title="Curve25519Error = enum
Curver25519GenError">Curve25519Error< / a > < / li >
< li > < a class = "reference" href = "#Curve25519Key"
title="Curve25519Key = array[Curve25519KeySize, byte]">Curve25519Key< / a > < / li >
< / ul >
< / li >
< li >
< a class = "reference reference-toplevel" href = "#10" id = "60" > Consts< / a >
< ul class = "simple simple-toc-section" >
< li > < a class = "reference" href = "#Curve25519KeySize"
title="Curve25519KeySize = 32">Curve25519KeySize< / a > < / li >
< / ul >
< / li >
< li >
< a class = "reference reference-toplevel" href = "#12" id = "62" > Procs< / a >
< ul class = "simple simple-toc-section" >
< ul class = "simple nested-toc-section" > getBytes
< li > < a class = "reference" href = "#getBytes%2CCurve25519Key"
title="getBytes(key: Curve25519Key): seq[byte]">getBytes(key: Curve25519Key): seq[byte]< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > intoCurve25519Key
< li > < a class = "reference" href = "#intoCurve25519Key%2CopenArray%5Bbyte%5D"
title="intoCurve25519Key(s: openArray[byte]): Curve25519Key">intoCurve25519Key(s: openArray[byte]): Curve25519Key< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > mul
< li > < a class = "reference" href = "#mul%2Ctype%5BCurve25519%5D%2CCurve25519Key%2CCurve25519Key"
title="mul(_: type[Curve25519]; point: var Curve25519Key; multiplier: Curve25519Key)">mul(_: type[Curve25519]; point: var Curve25519Key; multiplier: Curve25519Key)< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > public
< li > < a class = "reference" href = "#public%2CCurve25519Key"
title="public(private: Curve25519Key): Curve25519Key">public(private: Curve25519Key): Curve25519Key< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > random
< li > < a class = "reference" href = "#random%2Ctype%5BCurve25519Key%5D%2CHmacDrbgContext"
title="random(_: type[Curve25519Key]; rng: var HmacDrbgContext): Curve25519Key">random(_: type[Curve25519Key]; rng: var HmacDrbgContext): Curve25519Key< / a > < / li >
< / ul >
< / ul >
< / li >
< / ul >
< / div >
< a
href="https://github.com/status-im/nim-libp2p/tree/fix-sendMsgSlow/libp2p/crypto/curve25519.nim#L1"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/curve25519.nim#L1" class = "link-seesrc" target = "_blank" > Edit< / a >
< div class = "nine columns" id = "content" >
< div id = "tocRoot" > < / div >
< p class = "module-desc" > < p > This module integrates BearSSL Cyrve25519 mul and mulgen< / p >
< p > This module uses unmodified parts of code from BearSSL library < < a class = "reference external" href = "https://bearssl.org/" > https://bearssl.org/< / a > > Copyright(C) 2018 Thomas Pornin < pornin@bolet.org> .< / p >
< / p >
< div class = "section" id = "7" >
< h1 > < a class = "toc-backref" href = "#7" > Types< / a > < / h1 >
< dl class = "item" >
< div id = "Curve25519" class = "tohide" >
< dt > < pre > < a href = "curve25519.html#Curve25519" > < span class = "Identifier" > Curve25519< / span > < / a > < span class = "Other" > =< / span > < span class = "Keyword" > object< / span > < / pre > < / dt >
< dd >
< a
href="https://github.com/status-im/nim-libp2p/tree/fix-sendMsgSlow/libp2p/crypto/curve25519.nim#L29"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/curve25519.nim#L29" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< div id = "Curve25519Error" class = "tohide" >
< dt > < pre > < a href = "curve25519.html#Curve25519Error" > < span class = "Identifier" > Curve25519Error< / span > < / a > < span class = "Other" > =< / span > < span class = "Keyword" > enum< / span >
< span class = "Identifier" > Curver25519GenError< / span > < / pre > < / dt >
< dd >
< a
href="https://github.com/status-im/nim-libp2p/tree/fix-sendMsgSlow/libp2p/crypto/curve25519.nim#L31"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/curve25519.nim#L31" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< div id = "Curve25519Key" class = "tohide" >
< dt > < pre > < a href = "curve25519.html#Curve25519Key" > < span class = "Identifier" > Curve25519Key< / span > < / a > < span class = "Other" > =< / span > < span class = "Identifier" > array< / span > < span class = "Other" > [< / span > < span class = "Identifier" > Curve25519KeySize< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > byte< / span > < span class = "Other" > ]< / span > < / pre > < / dt >
< dd >
< a
href="https://github.com/status-im/nim-libp2p/tree/fix-sendMsgSlow/libp2p/crypto/curve25519.nim#L30"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/curve25519.nim#L30" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< / dl > < / div >
< div class = "section" id = "10" >
< h1 > < a class = "toc-backref" href = "#10" > Consts< / a > < / h1 >
< dl class = "item" >
< div id = "Curve25519KeySize" class = "tohide" >
< dt > < pre > < a href = "curve25519.html#Curve25519KeySize" > < span class = "Identifier" > Curve25519KeySize< / span > < / a > < span class = "Other" > =< / span > < span class = "DecNumber" > 32< / span > < / pre > < / dt >
< dd >
< a
href="https://github.com/status-im/nim-libp2p/tree/fix-sendMsgSlow/libp2p/crypto/curve25519.nim#L26"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/curve25519.nim#L26" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< / dl > < / div >
< div class = "section" id = "12" >
< h1 > < a class = "toc-backref" href = "#12" > Procs< / a > < / h1 >
< dl class = "item" >
< div id = "getBytes,Curve25519Key" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#getBytes%2CCurve25519Key" > < span class = "Identifier" > getBytes< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > key< / span > < span class = "Other" > :< / span > < a href = "curve25519.html#Curve25519Key" > < span class = "Identifier" > Curve25519Key< / 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 > < 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 >
< dd >
< a
href="https://github.com/status-im/nim-libp2p/tree/fix-sendMsgSlow/libp2p/crypto/curve25519.nim#L38"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/curve25519.nim#L38" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< div id = "intoCurve25519Key,openArray[byte]" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#intoCurve25519Key%2CopenArray%5Bbyte%5D" > < span class = "Identifier" > intoCurve25519Key< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > s< / 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 > < a href = "curve25519.html#Curve25519Key" > < span class = "Identifier" > Curve25519Key< / 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 >
< dd >
< a
href="https://github.com/status-im/nim-libp2p/tree/fix-sendMsgSlow/libp2p/crypto/curve25519.nim#L34"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/curve25519.nim#L34" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< div id = "mul,type[Curve25519],Curve25519Key,Curve25519Key" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#mul%2Ctype%5BCurve25519%5D%2CCurve25519Key%2CCurve25519Key" > < span class = "Identifier" > mul< / span > < / a > < span class = "Other" > (< / span > < span class = "Operator" > _< / span > < span class = "Other" > :< / span > < span class = "Identifier" > type< / span > < span class = "Other" > [< / span > < a href = "curve25519.html#Curve25519" > < span class = "Identifier" > Curve25519< / span > < / a > < span class = "Other" > ]< / span > < span class = "Other" > ;< / span > < span class = "Identifier" > point< / span > < span class = "Other" > :< / span > < span class = "Keyword" > var< / span > < a href = "curve25519.html#Curve25519Key" > < span class = "Identifier" > Curve25519Key< / span > < / a > < span class = "Other" > ;< / span >
< span class = "Identifier" > multiplier< / span > < span class = "Other" > :< / span > < a href = "curve25519.html#Curve25519Key" > < span class = "Identifier" > Curve25519Key< / 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 >
< a
href="https://github.com/status-im/nim-libp2p/tree/fix-sendMsgSlow/libp2p/crypto/curve25519.nim#L47"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/curve25519.nim#L47" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< div id = "public,Curve25519Key" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#public%2CCurve25519Key" > < span class = "Identifier" > public< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > private< / span > < span class = "Other" > :< / span > < a href = "curve25519.html#Curve25519Key" > < span class = "Identifier" > Curve25519Key< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < a href = "curve25519.html#Curve25519Key" > < span class = "Identifier" > Curve25519Key< / 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 = "Identifier" > RootEffect< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
< a
href="https://github.com/status-im/nim-libp2p/tree/fix-sendMsgSlow/libp2p/crypto/curve25519.nim#L79"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/curve25519.nim#L79" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< div id = "random,type[Curve25519Key],HmacDrbgContext" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#random%2Ctype%5BCurve25519Key%5D%2CHmacDrbgContext" > < span class = "Identifier" > random< / span > < / a > < span class = "Other" > (< / span > < span class = "Operator" > _< / span > < span class = "Other" > :< / span > < span class = "Identifier" > type< / span > < span class = "Other" > [< / span > < a href = "curve25519.html#Curve25519Key" > < span class = "Identifier" > Curve25519Key< / 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 = "curve25519.html#Curve25519Key" > < span class = "Identifier" > Curve25519Key< / 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 >
< a
href="https://github.com/status-im/nim-libp2p/tree/fix-sendMsgSlow/libp2p/crypto/curve25519.nim#L82"
class="link-seesrc" target="_blank">Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/crypto/curve25519.nim#L82" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< / dl > < / div >
< / div >
< / div >
< div class = "row" >
< div class = "twelve-columns footer" >
< span class = "nim-sprite" > < / span >
< br / >
2024-03-19 17:43:44 +00:00
< small style = "color: var(--hint);" > Made with Nim. Generated: 2024-03-19 17:43:33 UTC< / small >
2024-03-19 16:58:34 +00:00
< / div >
< / div >
< / div >
< / div >
< / body >
< / html >