Spectrum is a unified messaging SDK for TypeScript. Write your agent logic once and deliver it across every messaging platform — iMessage, WhatsApp, terminal, or your own — through one fully type-safe interface.
The fastest way to ship is with Spectrum Cloud — hosted infrastructure for platforms like iMessage, with credentials ready in minutes.
-
Sign up at app.photon.codes to get your project ID and secret.
-
Install the SDK:
bun add spectrum-ts
-
Start your app:
import { Spectrum } from "spectrum-ts"; import { imessage } from "spectrum-ts/providers/imessage"; const app = await Spectrum({ projectId: process.env.PROJECT_ID, projectSecret: process.env.PROJECT_SECRET, providers: [imessage.config()], }); for await (const [space, message] of app.messages) { await space.responding(async () => { await message.reply("Hello from Spectrum."); }); }
Spectrum also runs fully standalone — you can connect to a local iMessage database, bring your own gRPC endpoints, or build your own platform provider. See the docs for self-hosted setups.
Visit docs.photon.codes to view the full documentation.
| Platform | Package |
|---|---|
| iMessage | spectrum-ts/providers/imessage |
spectrum-ts/providers/whatsapp |
|
| Terminal | spectrum-ts/providers/terminal |
| Custom | definePlatform from spectrum-ts |
Found a bug or have a feature request? Please open an issue on GitHub. Before filing, search existing issues to avoid duplicates.
Contributions are welcome. Please read CONTRIBUTING.md for details on our code of conduct and the process for submitting pull requests.