Source code for the /developer-tools portion of Interledger.org. This site is separate from the headless Drupal-powered main site and is built with Starlight, a documentation framework powered by Astro.
Inside this project, you'll see the following folders and files:
.
βββ public/
βββ src/
β βββ components/
β βββ content/
β β βββ docs/
β βββ content.config/
β βββ layouts/
β βββ pages/
β βββ styles/
β βββ env.d.ts
βββ astro.config.mjs
βββ package.json
βββ tsconfig.json
Starlight looks for .md or .mdx files in the src/content/docs/ directory. Each file is exposed as a route based on its file name.
Static assets, like favicons or images, can be placed in the public/ directory. When referencing these assets in your markdown, you do not have to include public/ in the file path, so an image would have a path like:

For more information about the way our documentation projects are set up, please refer to our documentation style guide.
We are using Bun in this repository, but you could theoretically use the package manager of your choice. To install Bun, run
curl -fsSL https://bun.sh/install | bashAll commands are run from the root of the project, from a terminal:
| Command | Action | 
|---|---|
| bun install | Installs dependencies | 
| bun run start | Starts local dev server at localhost:1103 | 
| bun run build | Build your production site to ./dist/ | 
| bun run preview | Preview your build locally, before deploying | 
| bun run astro ... | Run CLI commands like astro add,astro check | 
| bun run astro -- --help | Get help using the Astro CLI | 
| bun run format | Format all files with Prettier | 
| bun run format:check | Check code formatting for all files | 
| bun run lint | Run Linting | 
You can substitute the bun commands with whatever package manager of your choice uses.
Check out Starlightβs docs, read the Astro documentation, or jump into the Astro Discord server.
Thank You for Contributing! We appreciate your effort to write a blog post and share your expertise with the community!
Goal: Educate, drive adoption, and grow strategic influence.
Typical Target Audience:
- Technically-inclined users interested in Interledger development.
- Technically-inclined users interested in financial services technologies, innovations, or developments.
- Users keen on topics like APIs, data analytics, metrics, analysis, and quantitative assessment for digital networks.
- Users interested in privacy and related technologies.
Possible Content Framework:
If you're unsure how to structure your writing, you can use this as a guide.
- Introduction / main point
- Context - Interledgerβs perspective / stance / commitment on the topic being written [broader categories like privacy, metrics for growth, Digital Financial Inclusion etc.]
- The Challenge (or) The Problem
- The Solution
- The How / implementation
- Roadmap - short-term / long-term
- Note: A call to action (CTA) will be included automatically at the bottom of every post.
Ideal Word Count: Between 1,000 and 2,500 words, with links to relevant documents/pages for a deeper understanding.
Discuss Ideas: Before starting, share your blog post ideas with the tech team to ensure alignment and awareness.
Copy the Template: Begin your draft using this Google Doc template to maintain a consistent format.
Review Process##
Initial Reviews:
- Once your draft is ready, request specific reviewers or ask for feedback on the #tech-team Slack channel.
- Incorporate feedback and refine the blog post.
Finalizing:
- When the draft is stable, create a pull request in the interledger.org-developers GitHub repo.
- Please add links where appropriate so people can easily click to learn more about the concepts you reference.
- Include all images used in the post in the PR.
- No-one is expected to know the ins and outs of Astro (the framework that powers our site), so please tag Sarah as a reviewer to ensure everything Astro-related is in order.
- If you need an illustration, submit a design request in advance to Madalina via the #design Slack channel using the design request form.
- Before uploading images to GitHub, run them through an image optimizer such as TinyPNG.
- Ensure images are appropriately sized; feel free to ask Madalina or Sarah for assistance.
- Remember: merging the pull request will publish the blog post immediately.
- Ensure the publishing date in the blog post metadata matches the intended release date.
- Check with Ioana to confirm the publishing date and keep a consistent posting schedule. Ioana will also handle social media promotion.
- Run bun run formatandbun run lintto format your code and check for issues before creating a pull request.