NET API
HSM Dinamo
Loading...
Looking for...
No entries found
m_of_n.cs

Example of splitting and retrieving a secret using M from N.

See Note on examples.
using Dinamo.Hsm;
using System;
using System.Text;
using System.IO;
namespace MofN
{
class Program
{
private static String addr = "127.0.0.1";
static void Main(string[] args)
{
try {
/*
Conecta utilizando uma sessão anônima no HSM.
Não é necessário uma conta de usuário para realizar essa operação.
*/
api.ConnectAnonymously(addr);
Console.Out.WriteLine("Conectado anonimamente com sucesso!");
/*
Divide o segredo em um esquema M de N, onde existe um conjunto de
6 partes e são necessárias 2 partes para reconstruir o segredo.
Neste caso como foi passado null no parâmetro secret, o segredo é
gerado randomicamente dentro do HSM.
*/
var splitInfo = api.MofNSplit(2, 6, null);
Console.Out.WriteLine("Segredo dividido com sucesso!");
Console.Out.WriteLine("Segredo: " + BitConverter.ToString(splitInfo.pbSecret).Replace("-", ""));
Console.Out.WriteLine("Total de partes: " + splitInfo.dwPartCount);
for (UInt32 i = 0; i < splitInfo.dwPartCount; i++) {
Console.Out.WriteLine("Parte " + (i + 1) + ": " + BitConverter.ToString(splitInfo.pstParts[i].pbPart).Replace("-", ""));
}
/*
Recupera o segredo a partir de 2 partes.
*/
parts[0] = splitInfo.pstParts[0];
parts[1] = splitInfo.pstParts[1];
var recoveredSecret = api.MofNRecover(parts);
Console.Out.WriteLine("Segredo recuperado com sucesso!");
Console.Out.WriteLine("Segredo recuperado: " + BitConverter.ToString(recoveredSecret).Replace("-", ""));
} catch (DinamoException e) {
Console.Out.WriteLine(e.Message);
} finally{
/*
Desconecta do HSM
*/
api.Disconnect();
Console.Out.WriteLine("Desconectado com sucesso!");
}
}
}
}
Classe de baixo nível para acesso ao HSM. Para utilizar essa classe é necessário o entendimento mais ...
Definição DinamoApi.cs:15
Classe de API para acesso às funcionalidades do HSM Dinamo. Nessa classe é possível programar utiliza...
Definição DinamoClient.cs:93
Classe de Excecao para erros do Dinamo.
Definição DinamoException.cs:10
override string Message
Definição DinamoException.cs:42
DinamoApi.DN_M_OF_N_SPLIT_INFO MofNSplit(byte bM, byte bN, byte[] pbSecret)
Faz a divisão M de N de um segredo. De acordo com o padrão de compartilhamento de segredos de Shamir.
Definição DinamoClient.cs:4216
byte[] MofNRecover(DinamoApi.DN_M_OF_N_PART[] parts)
Reconstrói o segredo M de N a partir das partes dos custodiantes. De acordo com o padrão de compartil...
Definição DinamoClient.cs:4239
void Disconnect(bool flagClose)
Encerra a conexão com o HSM.
Definição DinamoClient.cs:814
void ConnectAnonymously(string Address)
Estabelece uma conexão anônima com o HSM.
Definição DinamoClient.cs:722
Namespace que denota um conjunto de funções para acesso ao HSM Dinamo e suas respectivas exceptions.
Definição DinamoClient.cs:12
Definição DinamoApi.cs:2652