Skip to content

Commit

Permalink
Readme
Browse files Browse the repository at this point in the history
  • Loading branch information
AlexeyRaga committed Aug 12, 2024
1 parent 7a6db39 commit 5fa14ee
Show file tree
Hide file tree
Showing 4 changed files with 74 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,8 @@
<PackageReference Include="Nullable" Version="1.3.1" PrivateAssets="all"/>
</ItemGroup>

<ItemGroup>
<None Include="Readme.md" Pack="true" PackagePath="\"/>
</ItemGroup>

</Project>
60 changes: 60 additions & 0 deletions src/Contrib.KafkaFlow.CryptoShredding.Avro/Readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,66 @@ sensitiveData = EncryptedString.FromPlain("secret-value");
To prevent accidental leakage of secrets, `EncryptedString.Plain` cannot be serialized to Avro. An attempt to do so will result in an
exception.

### Generating Avro types

Here is an example of an Avro schema that uses encrypted secrets:

```avro
{
"type": "record",
"name": "EncryptedMessage",
"namespace": "TestContract",
"fields": [
{ "name": "secret",
"type": { "type": "string", "logicalType": "encrypted-string" } }
]
}
```

C# types can be generated using the [avrogen](https://www.nuget.org/packages/Apache.Avro.Tools) tool
or by using `Contrib.KafkaFlow.CryptoShredding.Avro.Analyzers` package.

In both cases, make sure to register `EncryptedString` as a logical type:

```csharp
LogicalTypeFactory.Instance.Register(new EncryptedStringLogicalType());
```

### Using avrogen

Install [avrogen](https://www.nuget.org/packages/Apache.Avro.Tools):

```bash
$ dotnet tool install Apache.Avro.Tools
```

Then generate C# types:

```bash
$ dotnet avrogen -s <schema-file> <output-directory>
```

### Using Avro Analyzers

Reference the package in your `.csproj` file:

```xml
<PackageReference Include="Contrib.KafkaFlow.CryptoShredding.Avro.Analyzers"
Version="x.x.x"
OutputItemType="Analyzer"
ReferenceOutputAssembly="false" />
```
and add `*.avsc` files:

```xml
<ItemGroup>
<AdditionalFiles Include="avro\*.avsc" />
</ItemGroup>
```

C# classes will be generated automatically for all schemas in the `avro` directory.

## Encryption Process

For serialization to occur, the secrets must be encrypted first, converting `EncryptedString.Plain` into `EncryptedString.Encrypted`. The
Expand Down
6 changes: 5 additions & 1 deletion src/Contrib.KafkaFlow.Outbox/Contrib.KafkaFlow.Outbox.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
<LangVersion>latest</LangVersion>
<EnableNETAnalyzers>true</EnableNETAnalyzers>
<AnalysisLevel>latest</AnalysisLevel>
<PackageVersion></PackageVersion>
<PackageReadmeFile>Readme.md</PackageReadmeFile>
</PropertyGroup>

<ItemGroup>
Expand All @@ -23,4 +23,8 @@
<PackageReference Include="System.Text.Json" Version="8.0.4" />
</ItemGroup>

<ItemGroup>
<None Include="Readme.md" Pack="true" PackagePath="\"/>
</ItemGroup>

</Project>
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
<LangVersion>latest</LangVersion>
<EnableNETAnalyzers>true</EnableNETAnalyzers>
<AnalysisLevel>latest</AnalysisLevel>
<PackageReadmeFile>Readme.md</PackageReadmeFile>
</PropertyGroup>

<ItemGroup>
Expand All @@ -20,4 +21,8 @@
<PackageReference Include="System.Text.Json" Version="8.0.4" />
</ItemGroup>

<ItemGroup>
<None Include="Readme.md" Pack="true" PackagePath="\"/>
</ItemGroup>

</Project>

0 comments on commit 5fa14ee

Please sign in to comment.