JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 24
  • Score
    100M100P100Q56847F
  • License Unlicense

Tools for making a causality-key of cRelay client.

Package Exports

  • @litterpigger/crelay-js-sdk
  • @litterpigger/crelay-js-sdk/abstract-pool
  • @litterpigger/crelay-js-sdk/abstract-relay
  • @litterpigger/crelay-js-sdk/cip
  • @litterpigger/crelay-js-sdk/cip/auth
  • @litterpigger/crelay-js-sdk/cip/common-graph
  • @litterpigger/crelay-js-sdk/cip/community
  • @litterpigger/crelay-js-sdk/cip/constants
  • @litterpigger/crelay-js-sdk/cip/governance
  • @litterpigger/crelay-js-sdk/cip/key-token
  • @litterpigger/crelay-js-sdk/cip/keys
  • @litterpigger/crelay-js-sdk/cip/model-graph
  • @litterpigger/crelay-js-sdk/cip/openresearch
  • @litterpigger/crelay-js-sdk/cip/social
  • @litterpigger/crelay-js-sdk/cip/subspace
  • @litterpigger/crelay-js-sdk/core
  • @litterpigger/crelay-js-sdk/fakejson
  • @litterpigger/crelay-js-sdk/filter
  • @litterpigger/crelay-js-sdk/kinds
  • @litterpigger/crelay-js-sdk/nip04
  • @litterpigger/crelay-js-sdk/nip05
  • @litterpigger/crelay-js-sdk/nip06
  • @litterpigger/crelay-js-sdk/nip07
  • @litterpigger/crelay-js-sdk/nip10
  • @litterpigger/crelay-js-sdk/nip11
  • @litterpigger/crelay-js-sdk/nip13
  • @litterpigger/crelay-js-sdk/nip17
  • @litterpigger/crelay-js-sdk/nip18
  • @litterpigger/crelay-js-sdk/nip19
  • @litterpigger/crelay-js-sdk/nip21
  • @litterpigger/crelay-js-sdk/nip25
  • @litterpigger/crelay-js-sdk/nip27
  • @litterpigger/crelay-js-sdk/nip28
  • @litterpigger/crelay-js-sdk/nip29
  • @litterpigger/crelay-js-sdk/nip30
  • @litterpigger/crelay-js-sdk/nip39
  • @litterpigger/crelay-js-sdk/nip42
  • @litterpigger/crelay-js-sdk/nip44
  • @litterpigger/crelay-js-sdk/nip46
  • @litterpigger/crelay-js-sdk/nip49
  • @litterpigger/crelay-js-sdk/nip54
  • @litterpigger/crelay-js-sdk/nip57
  • @litterpigger/crelay-js-sdk/nip58
  • @litterpigger/crelay-js-sdk/nip59
  • @litterpigger/crelay-js-sdk/nip75
  • @litterpigger/crelay-js-sdk/nip94
  • @litterpigger/crelay-js-sdk/nip96
  • @litterpigger/crelay-js-sdk/nip98
  • @litterpigger/crelay-js-sdk/nip99
  • @litterpigger/crelay-js-sdk/pool
  • @litterpigger/crelay-js-sdk/pure
  • @litterpigger/crelay-js-sdk/references
  • @litterpigger/crelay-js-sdk/relay
  • @litterpigger/crelay-js-sdk/utils
  • @litterpigger/crelay-js-sdk/wasm

Readme

cRelay-js-sdk

This project serves as the official Javascript SDK for CausalityGraph, providing a robust implementation of the Nostr protocol with advanced causality tracking and secure messaging capabilities. It is designed to be the primary development toolkit for building decentralized applications that require strong causality guarantees and secure communication.

It combines three key technologies:

  1. Nostr (decentralized messaging protocol) and CIP (Causality Implementation Possibilities)
  2. Ethereum EIP-191 signatures (secure cryptographic signing)
  3. VLC (Verifiable Logical Clock)

Installation

# bun
curl -fsSL https://bun.sh/install | bash

# install just for linux
curl -LO https://github.com/casey/just/releases/download/1.28.0/just-1.28.0-x86_64-unknown-linux-musl.tar.gz
tar -xvf just-1.28.0-x86_64-unknown-linux-musl.tar.gz
sudo mv just /usr/local/bin/

# or for macOS
brew install just

# compile by yourself
just build

# or install by npm
npm i @ai-chen2050/crelay-js-sdk

# jsr
npx jsr add @ai-chen2050/crelay-js-sdk

If using TypeScript, this package requires TypeScript >= 5.0.

CIP Implementation

The cip directory implements various CIP (Common Interface Protocol) specifications:

CIP-01: Basic Subspace Operations

  • Subspace creation and management
  • Basic event operations
  • Authentication and authorization

CIP-02: Common Graph Operations

  • Project and task management
  • Entity and relation tracking
  • Observation recording
  • Structured data organization

CIP-03: Model Graph Operations

  • Model versioning and tracking
  • Dataset management
  • Compute and algorithm operations
  • Validation and fine-tuning
  • Conversation and session handling

CIP-04: OpenResearch Operations

  • Research paper submission and indexing
  • Paper annotations and reviews
  • AI analysis integration
  • Research discussions
  • Academic collaboration features
  • Paper likes and bookmarks
  • Paper downloads tracking
  • Personal notes and annotations

Each CIP implementation follows a consistent pattern:

  • Event type definitions
  • Tag structure specifications
  • Event creation and parsing
  • Subspace operation management

Examples

For detailed examples, please refer to the following files in the examples directory:

Subspace Operations

Basic subspace creation and management:

// Create and join a subspace
const subspaceEvent = NewSubspaceCreateEvent(
  subspaceName,
  DefaultCommonPrjOps + ',' + DefaultSubspaceOps,
  rules,
  description,
  imageURL,
)
ValidateSubspaceCreateEvent(subspaceEvent)

const joinEvent = NewSubspaceJoinEvent(subspaceEvent.subspaceID, 'Join')
ValidateSubspaceJoinEvent(joinEvent)

Common Operations

Project, task, entity, and relation management:

// Create a project
const projectEvent = await newProjectEvent(subspaceID, '')
projectEvent.setProjectInfo(
  'proj-001',
  'Test Project',
  'This is a test project',
  ['user1', 'user2'],
  'active',
)

// Create a task
const taskEvent = await newTaskEvent(subspaceID, '')
taskEvent.setTaskInfo(
  'proj-001',
  'task-001',
  'Test Task',
  'user1',
  'in_progress',
  '2024-12-31',
  'high',
)

Model Graph Operations

Model, dataset, and training management:

// Create a model
const modelEvent = await newModelEvent(subspaceID, '')
modelEvent.setParent('parent-hash-123')
modelEvent.setContributions('0.5,0.3,0.2')

// Create a dataset
const datasetEvent = await newDatasetEvent(subspaceID, '')
datasetEvent.setDatasetInfo(
  'proj-001',
  'task-001',
  'training',
  'json',
  ['user1', 'user2'],
)

OpenResearch Operations

Research paper and collaboration management:

// Create a paper
const paperEvent = await newPaperEvent(subspaceID, '')
paperEvent.setPaperInfo(
  '10.1234/example.2023',
  'research',
  ['John Doe', 'Jane Smith'],
  ['AI', 'Machine Learning', 'Research'],
  '2023',
  'Journal of Example Research',
  'Example Research Paper',
  'This is an example research paper abstract.',
  'https://example.com/paper',
  'abc123def456',
)

// Create a review
const reviewEvent = await newReviewEvent(subspaceID, '')
reviewEvent.setReviewInfo(
  paperEvent.id,
  4.5,
  {
    methodology: 4.5,
    results: 4.0,
    discussion: 5.0,
  },
  'Overall, this is a well-written paper with strong methodology.',
  'Clear methodology, comprehensive literature review.',
  'Could use more discussion on limitations.',
  'Consider expanding the discussion section.',
)

Each example demonstrates the core functionality of its respective CIP implementation. For complete working examples including relay connection, event signing, and publishing, please refer to the corresponding files in the examples directory.

Plumbing

To develop cRelay-js-sdk, install just and run just -l to see commands available.