A comprehensive collection of production-ready WebAssembly plugin examples demonstrating real-world patterns for building Noorle platform plugins using the WebAssembly Component Model and WASI 0.2.
This repository provides working examples of Noorle plugins that showcase:
- HTTP API Integration - Real-world examples using OpenWeatherMap, NewsAPI, arXiv, and Exchange Rate APIs
- Multi-Language Support - Implementations in Rust, Go, Python, JavaScript, and TypeScript
- WASI 0.2 Patterns - Modern WebAssembly System Interface usage for secure, sandboxed execution
- Component Model - Type-safe, language-agnostic plugin interfaces using WIT
- Production Patterns - Error handling, environment configuration, and testing strategies
- WebAssembly Component Model - Next-generation WASM module composition
- WASI Preview 2 - Secure system interface for network, filesystem, and environment access
- WIT (WebAssembly Interface Types) - Language-agnostic interface definitions
- Cross-Language Compilation - TinyGo, ComponentizeJS, componentize-py, and cargo-component
- Developers building plugins for the Noorle platform
- Learning WebAssembly Component Model best practices
- Understanding WASI 0.2 HTTP client patterns
- Exploring cross-language WASM development
- Building secure, sandboxed API integrations
Each example includes comprehensive documentation, local testing instructions, and production-ready code patterns.
Get real-time weather information from OpenWeatherMap API.
Available in 5 languages:
- Rust - High-performance with wakiHTTP client, demonstrates returning complex non-primitive record types
- Go - TinyGo compilation with WASI HTTP bindings
- Python - Direct WASI bindings with componentize-py
- JavaScript - Native fetch()API with ComponentizeJS
- TypeScript - Type-safe development with full IDE support
Features:
- Fetches current weather data for any city
- Supports metric and imperial units
- Secure API key management via environment variables
- Robust error handling for network failures
- Returns complex weather response with nested fields (temperature, wind, conditions)
Search worldwide news articles and breaking headlines using NewsAPI.org.
Available in:
- Rust - NewsAPI.org integration with structured record types
Features:
- Search news articles by keywords or topics
- Returns structured article data (title, description, URL, source)
- Demonstrates complex record types with nested structures
- Rate limit and authentication error handling
- Secure API key management via environment variables
Real-time currency conversion and exchange rate information.
Available in:
- Rust - Multiple API endpoints with fallback support
Features:
- Get current exchange rates for any base currency
- Convert amounts between different currencies
- List all supported currencies
- Automatic fallback to secondary API if primary fails
- No API key required - uses free currency data sources
Search for flight offers and travel information using the Amadeus API.
Available in:
- Go - TinyGo implementation demonstrating complex non-primitive record type inputs
Features:
- Search for flight offers between cities
- Accepts complex search parameters (origin, destination, dates, passengers)
- Demonstrates handling of nested input structures in WASI components
- Secure API credential management via environment variables
- Returns detailed flight information including prices and segments
Search and download academic papers from arXiv repository.
Available in:
- Rust - Atom/RSS feed parsing with PDF downloads
Features:
- Search arXiv for academic papers
- Download paper PDFs directly
- Structured metadata including authors, abstracts, and categories
- Efficient feed parsing with feed-rs
All plugins use the WebAssembly Component Model with WASI 0.2, providing:
- Security: Capability-based sandboxing with fine-grained permissions
- Portability: Run on any WASI 0.2 runtime (wasmtime, wasmer, browser)
- Composition: Plugins can import/export interfaces between components
- Language Agnostic: WIT interfaces enable seamless interop
- wasm32-wasip2target for optimal WASM output
- wit-bindgenfor Component Model integration
- wakifor WASI-native HTTP client
- Zero-cost abstractions with minimal binary size
- TinyGo compiler for efficient WASM binaries
- wit-bindgen-gofor type-safe bindings
- Direct WASI HTTP interface access
- Go-idiomatic patterns adapted for WASM
- componentize-pyfor Python-to-WASM compilation
- Direct WASI HTTP bindings without external libraries
- Native JSON handling with built-in libraries
- Dataclasses and enums for type safety
- ComponentizeJS with StarlingMonkey runtime
- Built on SpiderMonkey (Firefox's JS engine)
- Native fetch()API support
- ES modules and modern JavaScript features
- Full type safety with compile-time checks
- Two-stage compilation: TypeScript β JavaScript β WASM
- IDE support with IntelliSense and autocomplete
- Type-safe JSON serialization
Install the Noorle CLI to build and deploy plugins:
Option 1: Quick Install (Recommended)
curl -L cli.noorle.dev | shOption 2: Download Platform-Specific Binary Download the latest release for your platform from GitHub Releases.
See the CLI Reference for detailed documentation.
To streamline development experience, Noorle plugins use a standard set of WASM tools. These are automatically installed when you run noorle plugin prepare:
- wasmtime - WebAssembly runtime for local testing
- wkg - WIT package manager for dependency management
- wasm-tools - WebAssembly component utilities
- Rust toolchain - Required for the above tools (they're built in Rust)
These tools are used by the build scripts across all language templates to ensure consistent WASM component generation.
- Clone the repository:
git clone https://github.com/noorle/plugin-examples
cd plugin-examples- Choose an example and language:
cd rust/weather- Prepare development environment:
# Install required WASM tools (one-time setup)
noorle plugin prepare
# Or check if tools are already installed
noorle plugin prepare --checkThe prepare command runs the template's prepare.sh script which:
- Checks for required development tools
- Installs missing dependencies (with your permission)
- Configures your environment for WASM development
- Ensures consistent tooling across all templates
- Configure environment variables (if needed):
cp .env.example .env
# Add your API key to .env- Build the plugin:
noorle plugin buildThis runs the template's build.sh script which:
- Compiles your code to WebAssembly
- Generates Component Model bindings
- Produces dist/plugin.wasm
- Creates a .npackarchive for deployment
- Test locally:
# Example for rust weather plugin (Rust version)
wasmtime run --wasi http --env OPENWEATHER_API_KEY=your_key \
  --invoke 'check-weather("Austin", metric)' dist/plugin.wasm- Deploy to Noorle:
# Authenticate first
noorle login
# Deploy the plugin
noorle plugin deploy
# Or build and deploy in one step
noorle plugin publishThe Noorle CLI provides a streamlined workflow for plugin development:
# List available templates
noorle plugin list-templates
# Create from template
noorle plugin init my-plugin --template rust
# Interactive template selection
noorle plugin init my-plugin# Check/install dependencies
noorle plugin prepare         # Interactive installation
noorle plugin prepare --check  # Check only
noorle plugin prepare --ci     # Non-interactive for CI/CD
# Build plugin
noorle plugin build           # Runs build.sh, creates WASM
# Validate configuration
noorle plugin validate noorle.yaml
# Create deployment package
noorle plugin pack            # Creates .npack archive# Authentication
noorle login                  # OAuth device flow
noorle logout                 # Clear tokens
# Deploy to platform
noorle plugin deploy          # Deploy existing .npack
noorle plugin publish         # Build + deployEach plugin follows a consistent structure:
language/plugin-name/
βββ src/ or app.*        # Main implementation
βββ wit/
β   βββ world.wit        # Component interface definition
βββ noorle.yaml          # Plugin permissions and config
βββ prepare.sh           # Dependency setup script
βββ build.sh             # Build script
βββ .env.example         # Environment template
βββ README.md            # Detailed documentation
βββ dist/
    βββ plugin.wasm      # Compiled WASM component
    βββ *.npack          # Deployment archive
- prepare.sh: Checks and installs development tools (wasmtime, wkg, wasm-tools)
- build.sh: Language-specific build script that produces WASM output
- world.wit: WebAssembly Interface Types definition for your plugin's API
- noorle.yaml: Specifies permissions, environment variables, and metadata
- Making external API calls from sandboxed WASM components
- Language-specific HTTP client patterns
- Timeout handling and connection management
- Request/response streaming
- Secure API key management
- Configuration through environment variables
- Capability-based permissions in noorle.yaml
- Robust patterns for network failures
- API error handling
- Result types and error propagation
- Graceful degradation with fallbacks
- Parsing and serializing external API data
- Type-safe data structures
- Handling optional fields and null values
- Clean WIT interface definitions
- Type mapping between languages and Component Model
- Export functions with documented parameters
- Result types for error handling
- Start with Weather Plugin: Learn HTTP integration and basic patterns with complex record types
- Try News Plugin: Understand NewsAPI integration, rate limiting, and structured data handling
- Explore Exchange Rate: Understand fallback strategies and data caching
- Study ArXiv Plugin: Master feed parsing and binary file handling
- Compare Languages: See how different languages approach the same problem
- Never hardcode API keys or secrets
- Use environment variables for configuration
- Specify minimal permissions in noorle.yaml
- Validate all external data
- Choose appropriate language for use case
- Optimize binary size (especially with TinyGo/Rust)
- Implement caching where appropriate
- Use streaming for large responses
- Always return Result types
- Provide meaningful error messages
- Implement retry logic for transient failures
- Add fallback mechanisms for critical services
- Write comprehensive tests
- Document all exported functions
- Follow language-specific idioms
- Use type safety where available
We welcome contributions! Please see CONTRIBUTING.md for guidelines.
- Choose a practical use case
- Implement in at least one language
- Include comprehensive README
- Add tests and documentation
- Follow existing patterns and structure
MIT License with Additional Terms for Noorle Platform
Copyright (c) 2024 Noorle
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
Additional Terms for Noorle Platform Integration:
- These examples are optimized for and officially supported on the Noorle platform
- When deploying to Noorle, plugins must comply with Noorle's Terms of Service
- The Noorle team may use these examples for platform documentation and promotion
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.