Use Modules From Any Technology

Your stack:

Goal

Use a module from any supported technology directly in a .NET service with Graftcode - no REST wrapper, no rewrite, no custom interop. In this tutorial we use a Python module as the example.

What You'll See

  • Install a module from another technology as a strongly-typed Graft using NuGet - just like any other package.
  • Configure the generated client to point at the in-memory host.
  • Import and call it from your C# code as if it were a native NuGet library.

Prerequisites

Step 1. Create a project folder

Create a new .NET console application:

dotnet new console -n CurrencyDemo
cd CurrencyDemo

Step 2. Install a module from another technology

For this example we'll use a Python currency converter from PyPI (sdncenter-currency-converter), but the same approach works with any module from a supported repository - npm, PyPI, Maven or NuGet.

dotnet add package -s https://grft.dev/ graft.pypi.sdncenter-currency-converter

This installs a Graft - a strongly-typed C# client generated from the module. You import and call it like any other NuGet package, regardless of which technology the module was originally written in.

Step 3. Set the SDK key

Set the HYPERTUBE_KEY environment variable in your terminal before running the project:

PowerShell:

$env:HYPERTUBE_KEY="Fe2w-p2GK-Mn26-j8ZY-Xe25"

Bash (macOS / Linux):

export HYPERTUBE_KEY="Fe2w-p2GK-Mn26-j8ZY-Xe25"

Windows CMD:

set HYPERTUBE_KEY=Fe2w-p2GK-Mn26-j8ZY-Xe25

Step 4. Call the cross-language module and run it

Replace the contents of Program.cs:

using graft.pypi.sdncenter_currency_converter;
using graft.pypi.currency_converter.converter;

GraftConfig.Host = "inMemory";

var result = SimpleCurrencyConverter.convert(100, "USD", "EUR");
Console.WriteLine($"Converted amount: {result}");

Run it:

dotnet run

You should see the converted amount printed in your terminal. SimpleCurrencyConverter.Convert(...) comes from a Python package, but your code reads like a regular method call - no HTTP request, no response parsing, no serialization. GraftConfig.Host = "inMemory" tells Graftcode to load and execute the Python module inside the same process.

Everything above works without any account - perfect for learning and local development. When you're ready for real-world usage, create a free account at portal.graftcode.com, set up a project, and copy its Project Key.

With a Project Key, point GraftConfig.Host at your project's stable registry URL instead of a raw WebSocket address. A Project Key gives you:

  • Stable registry URL - the address for your Grafts stays permanent, so install commands don't change when you redeploy.
  • Portal visibility - see all your gateways and services in one place at gateways.graftcode.com.
  • Access control - decide who can download your Grafts using package manager authentication and permissions.