Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/azigler/pinwheel

Highly opinionated fork of the Ranvier MUD engine
https://github.com/azigler/pinwheel

backend game-engine gamedev mud ranvier

Last synced: about 2 months ago
JSON representation

Highly opinionated fork of the Ranvier MUD engine

Awesome Lists containing this project

README

        

![](https://repository-images.githubusercontent.com/142938382/711ca600-2655-11ea-95f8-84f896671ff3)

# Pinwheel MUD Engine

[![Grapevine](https://img.shields.io/badge/Grapevine-MUD%20Chat%20Network-brightgreen.svg)](https://grapevine.haus/)
[![MUD Coders Slack](https://slack.mudcoders.com/badge.svg)](https://slack.mudcoders.com/)
[![Ranvier MUD Engine](https://img.shields.io/badge/Ranvier-MUD%20engine-brightgreen.svg?logo=)](https://github.com/RanvierMUD/ranviermud)
[![standard-readme](https://img.shields.io/badge/readme%20style-standard-DF1464.svg?style=popout-square)](https://github.com/RichardLitt/standard-readme)

[![@andrewzigler](https://img.shields.io/twitter/follow/andrewzigler.svg?label=@andrewzigler&style=social)](https://twitter.com/andrewzigler)
[![MIT License](https://img.shields.io/badge/license-MIT-DF1464.svg?style=popout-square)](https://github.com/azigler/pinwheel/blob/master/LICENSE)
[![](http://hits.dwyl.io/azigler/pinwheel.svg)](#)
[![contributions welcome](https://img.shields.io/badge/contributions-welcome-DF1464.svg?style=popout-square)](https://github.com/azigler/pinwheel/blob/master/CONTRIBUTING.md)
[![](https://img.shields.io/badge/powered%20by-Node.js-brightgreen.svg?style=popout-square)](https://nodejs.org/en/about/)

> A highly opinionated fork of the [Ranvier](https://github.com/shawncplus/ranviermud) MUD engine.

**Current Version: `0.5.0`**

Pinwheel is a *new* [MUD](https://www.andrewzigler.com/blog/2018/06/27/the-case-for-muds-in-modern-times/) engine built entirely in ES6 (JavaScript). It doesn't require a database and can be online for players within moments of downloading. Originally based on [Shawn Biddle](http://shawnbiddle.com)'s [Ranvier](http://ranviermud.com/), Pinwheel is a rewrite of the engine and its bundles into a highly opinionated format. The engine makes decisions about world persistence and core features so you can focus on building your world and community.

Pinwheel is an experimental game engine that aims to fuse MUD and browser gameplay. To get an idea of what version `1.0.0` of Pinwheel will entail, check out our [Roadmap](#chart_with_upwards_trend-roadmap).

:pencil2: Latest devlog post: [Initial Release of Pinwheel - January 26, 2019](https://www.andrewzigler.com/blog/2019/01/26/initial-release-of-pinwheel/)

## :book: Table of Contents

- [Install](#floppy_disk-install)
- [Usage](#rocket-usage)
- [Package Scripts](#nut_and_bolt-package-scripts)
- [JSON Configuration](#zap-json-configuration)
- [Features](#round_pushpin-features)
- [Roadmap](#chart_with_upwards_trend-roadmap)
- [Maintainer](#horse_racing-maintainer)
- [Contributing](#inbox_tray-contributing)

## :floppy_disk: Install

[![](https://i.imgur.com/4PHUzHx.png)](#)

Pinwheel requires [Node v8.9.4](https://nodejs.org/en/blog/release/v8.9.4/) or greater.

To install, run the following commands from your terminal:

```shell
git clone https://github.com/azigler/pinwheel/
cd pinwheel
npm install
npm run
```

Pinwheel can get up and running immediately, but it's recommended to configure your game via the [`pinwheel.json`](https://github.com/azigler/pinwheel/blob/master/pinwheel.json) file. For more information, see the [Usage](#rocket-usage) section.

## :rocket: Usage

Pinwheel has several built-in scripts that you can use with `npm run`. To launch the server, use `npm run start`. To launch the server quicker and without logging to a file (useful for development), use `npm run dev`.

This repository comes with a default account and administrator character, or you can make your own with the included aspects. To access the default account, use the following credentials:

```
username: Admin
password: pinwheel
```

### :nut_and_bolt: Package Scripts
- `start`: launches the server
- `dev`: launches the server without logging to a file, connecting to [Grapevine](https://grapevine.haus/), or running the `default` [gulp task](https://github.com/azigler/pinwheel/blob/master/gulpfile.js) (useful for development)
- `istanbul`: uses [Istanbul](https://istanbul.js.org/) to test coverage with [Chai](https://www.chaijs.com/)
- `test`: runs the `default` [gulp task](https://github.com/azigler/pinwheel/blob/master/gulpfile.js) and fires the `istanbul` script
- `build-docs`: uses [JSDoc](http://usejsdoc.org/) to build documentation in `docs/jsdoc/` from `src/`
- `bundle-install`: installs npm packages for all bundles
- `postinstall`: *automatically fires `bundle-install` after `npm install`*
- `clean-areas`: deletes the files in `data/area/` (useful for rapid testing)
- `clean-bugs`: deletes the files in `data/bug/` (useful for rapid testing)
- `clean-logs`: deletes the files in `data/log/` (useful for rapid testing)
- `clean-all`: fires all of the cleaning scripts (`clean-logs`, `clean-bugs`, `clean-areas`, and `clean-all`)

Many elements of Pinwheel can be configured via the [`pinwheel.json`](https://github.com/azigler/pinwheel/blob/master/pinwheel.json) file.

### :zap: JSON Configuration
*(in alphabetical order)*
- `allowMultiplay`: whether accounts can have multiple characters logged in at once *(default: `true`)*
- `aspects`: array of [`Aspect`](https://github.com/azigler/pinwheel/blob/master/src/Aspect.js) names *(default: `["archetype", "species", "trait"]`)*
- `bundles`: array of bundle names to include at runtime *(default: all bundles in this repository)*
- `creation`: object with properties whose values indicate default [`Aspect`](https://github.com/azigler/pinwheel/blob/master/src/Aspect.js) options available at character creation *(default: `{"archetype": ["tester"], "species": ["administrator"], "trait": ["immortal"]}`)*
- `currency`: name of default currency *(default: `"cowries"`)*
- `debugArea`: name of area where combat debugging will output *(default: `"start"`)*
- `entityTick`: time between entity update ticks, in miliseconds *(default: `500`)*
- `grapevine`: false if disabled, or object with [your game's authentication details](https://grapevine.haus/register/new) for [Grapevine](https://grapevine.haus/) *(example: `{"clientId": "YOUR-CLIENT-ID", "clientSecret": "YOUR-CLIENT-SECRET"}`), (default: `false`)*
- `introEvent`: initial `input-event` shown on connection *(default: `"intro"`)*
- `logLevel`: configures logging to file, either `"verbose"` or `"none"` *(default: `"verbose"`)*
- `maxCharacters`: number of active characters allowed on an account *(default: `3`)*
- `maxFailedLoginAttempts`: number of failed login attempts allowed before being kicked *(default: `3`)*
- `maxIdleMinutes`: number of minutes a character can idle before being kicked, 0 if disabled *(default: `0`)*
- `maxNameLength`: maximum name length for an account or character *(default: `20`)*
- `maxPlayerInventory`: maximum number of items that can be carried by a player *(default: `16`)*
- `meta`: *(example: `{"author": "John Doe", "gameName": "Pinwheel", "twitterHandle": "@johndoe"}`), (default: `false`)*
- `minNameLength`: minimum name length for an account or character *(default: `3`)*
- `minPasswordLength`: minimum character length for an account password *(default: `6`)*
- `motd`: filename in `data/motd/` to show on `intro` event *(default: `"pinwheel"`)*
- `moveCommand`: default command used to navigate a character *(default: `"move"`)*
- `playerTick`: time between player update ticks, in milliseconds *(default: `500`)*
- `reportBugsToAdmins`: whether to notify valid online users of reported bugs, typos, and suggestions *(default: `true`)*
- `skillLag`: default lag after skill use, in milliseconds *(default: `1000`)*
- `startingRoom`: entity reference for room in which all characters start after creation *(default: `"start:spawn"`)*
- `startingTraits`: number of traits that can be chosen at character creation *(default: `1`)*
- `telnetPort`: port for Telnet server *(default: `4000`)*
- `web`: object with information for web server *(example: `"web": {"header": {"description": "Powered by Pinwheel, a JavaScript MUD engine.", "faviconUrl": "/path/to/favicon.ico", "googleId": "YOUR-GOOGLE-ANALYTICS-TRACKING-ID", "image": "https://full.weburl.to/image.jpg"}, "https": {"fullchain": "/full/path/to/fullchain.pem", "port": 443, "key": "/full/path/to/privkey.pem"}, "port": 80}`), (default: `{"header": false, "https": false, "port": 80}`)*
- `webSocketPort`: port for [WebSocket](https://developer.mozilla.org/en-US/docs/Web/API/WebSockets_API) server *(default: `4001`)*

## :round_pushpin: Features

- Full game state persistence across sessions (areas, NPCs, players, and items)
- [Diku](http://mud.wikia.com/wiki/DikuMUD)-esque commands
- Customization of players and NPCs with species, archetypes, and traits
- Usage of human-readable YAML for game data in bundles
- Entity-based scripting with few differences between NPCs and players
- Turn-based combat with abilities, spells, and disciplines
- Usage-based improvement of skills with branching skill trees
- Communication channels and player parties
- Compatibility with the [Grapevine MUD Chat Network](https://grapevine.haus/)
- Player accounts
- Telnet and [WebSocket](https://developer.mozilla.org/en-US/docs/Web/API/WebSockets_API) support
- Data storage in JSON files, no database required
- Web server bound to state (for a website and/or API)

## :chart_with_upwards_trend: Roadmap

- [x] Refactor [Ranvier](http://ranviermud.com/) into Pinwheel
- [x] Reduce the differences between player characters and NPCs
- [x] Convert class system into aspects, allowing fine-tuned customization of players and NPCs alike with stackable components (e.g., species, archetypes, and traits)
- [x] Rewrite foundation for new combat system
- [ ] Add configurable time, seasons, and weather
- [ ] Implement [hot reloading](http://mud.wikia.com/wiki/Copyover_Recover) of bundles and core
- [ ] Enable [online creation (OLC)](http://mud.wikia.com/wiki/Online_Creation) of bundle content
- [ ] Create customizable player organizations
- [ ] Redesign quests into [dynamic events](https://wiki.guildwars2.com/wiki/Dynamic_event)
- [ ] Add crafting, resources, and a basic economy
- [ ] Expand emoting complexity with syntax for referencing the world
- [ ] Build an API with [Express](https://expressjs.com/) for the engine and game state, allowing extensibility beyond the original platform (e.g., apps, widgets, and third-party clients)
- [ ] Expand the web server to allow for gameplay, building, and administration in the browser
- [ ] Convert to [NPM package](https://docs.npmjs.com/about-packages-and-modules)

## :horse_racing: Maintainer

Pinwheel is maintained by [Andrew Zigler](https://www.andrewzigler.com/), a member of the [MUD Coders Guild](https://mudcoders.com/). Andrew can be reached on Twitter ([@andrewzigler](https://twitter.com/andrewzigler)) or Slack ([@Zig](https://mudcoders.slack.com/)).

## :inbox_tray: Contributing
Feedback and contributions are encouraged! After reading our [Code of Conduct](https://github.com/azigler/pinwheel/blob/master/CODE_OF_CONDUCT.md), use the [*Bug Report*](https://github.com/azigler/pinwheel/issues/new?assignees=&labels=&template=bug-report.md&title=) or [*Feature Request*](https://github.com/azigler/pinwheel/issues/new?assignees=&labels=&template=feature-request.md&title=) issue templates to discuss any bugs or potential contributions to Pinwheel. For more information, please read our [Contributing Guide](https://github.com/azigler/pinwheel/blob/master/CONTRIBUTING.md).