XamarinChatNugget 1.0.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package XamarinChatNugget --version 1.0.0
NuGet\Install-Package XamarinChatNugget -Version 1.0.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="XamarinChatNugget" Version="1.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="XamarinChatNugget" Version="1.0.0" />
<PackageReference Include="XamarinChatNugget" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add XamarinChatNugget --version 1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: XamarinChatNugget, 1.0.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package XamarinChatNugget@1.0.0
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=XamarinChatNugget&version=1.0.0
#tool nuget:?package=XamarinChatNugget&version=1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Hereβs a README.md you can drop into your NuGet project repo β written for developers discovering your package:
# XamarinChatNugget π¦π
End-to-End Encrypted (E2EE) Messaging library for **Xamarin.Forms / .NET Standard 2.0**.
Built on [Sodium.Core](https://www.nuget.org/packages/Sodium.Core/) (libsodium crypto), [Xamarin.Essentials](https://learn.microsoft.com/xamarin/essentials/), and [sqlite-net-pcl](https://github.com/praeclarum/sqlite-net).
---
## β¨ Features
- π Identity key pair (X25519) auto-generated & stored securely (Keychain / Keystore).
- π End-to-end encryption (ECDH + XSalsa20-Poly1305).
- π Ephemeral keys per message for forward secrecy.
- π¦ Payload contains ciphertext, nonce, and ephemeral public key.
- π² Secure storage of own + peer public keys.
- πΎ Optional persistence layer with SQLite (swap for SQLCipher in prod).
- π Extensible transport (SignalR, WebSockets, REST).
---
## π¦ Installation
Add via NuGet:
```bash
dotnet add package XamarinChatNugget
Or in Visual Studio:
Manage NuGet Packages β Browse β
XamarinChatNugget
π Quick Start
1. Initialize in App
using XamarinChatNugget.Services;
public partial class App : Application
{
public static SodiumKeyStore KeyStore { get; private set; }
public static SodiumCryptoService Crypto { get; private set; }
public App()
{
InitializeComponent();
KeyStore = new SodiumKeyStore();
Crypto = new SodiumCryptoService(KeyStore);
MainPage = new MainPage();
}
}
2. Send a Message
var keyStore = App.KeyStore;
var crypto = App.Crypto;
// Store Bob's public key (normally obtained via QR/server)
await keyStore.StorePeerPublicKeyAsync("bob", bobPublicKey);
// Encrypt for Bob
var payload = await crypto.EncryptForAsync("bob", Encoding.UTF8.GetBytes("Hello Bob!"));
// Send payload.Ciphertext + payload.Nonce + payload.EphemeralPublicKey over the network
3. Receive & Decrypt
var plaintextBytes = await App.Crypto.DecryptWithEphemeralAsync("alice", payload);
var plaintext = Encoding.UTF8.GetString(plaintextBytes);
Console.WriteLine($"Decrypted: {plaintext}");
π Key Exchange
On first contact, users must exchange public keys.
Options:
- QR Code scan π±
- Server lookup π
- Invite link π
β οΈ Security Notes
This package demonstrates secure message encryption/decryption. For production apps, you should also add:
- β Auth & user accounts
- β Secure key exchange (QR or authenticated server)
- β SQLCipher for encrypted DB storage
- β Transport layer (SignalR/WebSockets/HTTPS)
- β Push notifications
- β Ratchet protocol (for Signal-style secrecy)
π License
MIT License Β© 2025 YourName
---
π Do you want me to also include a **demo screenshot** section with fake chat UI (Alice β Bob) so your NuGet page looks more professional on nuget.org/GitHub?
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- Sodium.Core (>= 1.4.0)
- Xamarin.Essentials (>= 1.8.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.