npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@astrologer/astrology-mcp

v1.0.8

Published

MCP server for astrological natal chart calculations

Readme

Astrology MCP Server

A Model Context Protocol (MCP) server that provides astrological natal chart calculations. Built with TypeScript and the MCP SDK, this server enables AI assistants to calculate and interpret astrological birth charts based on date, time, and location.

🌟 Now powered by @swisseph/node - Using the Swiss Ephemeris calculation engine for highly accurate astronomical calculations.

Features

  • Accurate Calculations - Powered by Swiss Ephemeris for high precision.
  • Complete Natal Charts - Detailed planet positions, houses, aspects, and chart angles.
  • Flexible Location - Support for coordinates or city names (free geocoding).
  • Multiple House Systems - Placidus, Koch, Whole Sign, and more.
  • Modern Stack - TypeScript, Zod validation, and latest MCP SDK.

Quick Start

You can run the server directly using npx without installing anything:

npx -y @astrologer/astrology-mcp

Configuring with you MCP client

Standard config works in most tools.

{
  "mcpServers": {
    "astrology": {
      "command": "npx",
      "args": ["-y", "@astrologer/astrology-mcp"]
    }
  }
}

Manual Installation (From Source)

If you want to modify the code or run from source:

git clone https://github.com/intellecat/astrology-mcp.git
cd astrology-mcp
npm install
npm run build

Dependencies

Runtime

  • @modelcontextprotocol/sdk - Latest MCP SDK
  • @swisseph/node - Swiss Ephemeris calculation engine (high precision)
  • luxon - Timezone and date handling
  • node-geocoder - Location to coordinate conversion
  • zod - Schema validation

Development

  • typescript - TypeScript compiler
  • @types/node - Node.js type definitions
  • @types/node-geocoder - node-geocoder type definitions
  • @types/luxon - Luxon type definitions

Usage

Building

npm run build

Running the Server

npm start

Development Mode

npm run dev

Testing

Run the test script to verify the horoscope calculations:

npm test

MCP Tools

1. astrology_calculate_natal_chart

Calculate a complete natal chart based on birth data.

Parameters:

  • datetime (object, required): Birth date and time
    • year (number): Year (e.g., 1990)
    • month (number): Month (1-12, where 1=January, 12=December)
    • day (number): Day of month (1-31)
    • hour (number): Hour in local time (0-23)
    • minute (number): Minute (0-59)
  • location (object or string, required):
    • As object: {latitude: 40.7128, longitude: -74.0060}
    • As string: "New York, USA"
  • houseSystem (string, optional): House system to use (default: "Placidus")

Returns:

{
  "planets": [
    {
      "name": "Sun",
      "sign": "Taurus",
      "degree": "24° 39' 24\"",
      "longitude": 84.6567,
      "house": 9,
      "isRetrograde": false
    }
  ],
  "houses": [
    {
      "number": 1,
      "sign": "Virgo",
      "degree": "19° 27' 38\"",
      "cuspDegree": 169.4606
    }
  ],
  "aspects": [
    {
      "point1": "Sun",
      "point2": "Moon",
      "aspect": "Trine",
      "aspectLevel": "Major",
      "orb": 5.85,
      "orbUsed": 7
    }
  ],
  "chartAngles": {
    "ascendant": {
      "sign": "Virgo",
      "degree": "19° 27' 38\"",
      "longitude": 169.4606
    },
    "midheaven": {
      "sign": "Gemini",
      "degree": "17° 46' 33\"",
      "longitude": 77.7759
    },
    "descendant": {
      "sign": "Pisces",
      "degree": "19° 27' 38\"",
      "longitude": 349.4606
    },
    "imumCoeli": {
      "sign": "Sagittarius",
      "degree": "17° 46' 33\"",
      "longitude": 257.7759
    }
  },
  "sunSign": "Taurus",
  "birthData": {
    "datetime": {
      "year": 1990,
      "month": 5,
      "day": 15,
      "hour": 14,
      "minute": 30
    },
    "location": "New York, NY, USA",
    "latitude": 40.7128,
    "longitude": -74.006,
    "houseSystem": "Placidus"
  }
}

2. astrology_get_coordinates

Convert a location string to geographic coordinates.

Parameters:

  • location (string, required): Location in format "City, Country" (e.g., "London, UK")

Returns:

{
  "latitude": 51.5074,
  "longitude": -0.1278,
  "formattedAddress": "London, Greater London, England, UK"
}

Example Usage with MCP Client

Example 1: Calculate natal chart with coordinates

{
  "tool": "astrology_calculate_natal_chart",
  "arguments": {
    "datetime": {
      "year": 1990,
      "month": 5,
      "day": 15,
      "hour": 14,
      "minute": 30
    },
    "location": {
      "latitude": 40.7128,
      "longitude": -74.0060
    }
  }
}

Example 2: Calculate natal chart with city name

{
  "tool": "astrology_calculate_natal_chart",
  "arguments": {
    "datetime": {
      "year": 1995,
      "month": 12,
      "day": 25,
      "hour": 8,
      "minute": 0
    },
    "location": "Paris, France",
    "houseSystem": "Whole Sign"
  }
}

Example 3: Get coordinates for a location

{
  "tool": "astrology_get_coordinates",
  "arguments": {
    "location": "Tokyo, Japan"
  }
}

House Systems Supported

The server supports various house systems including:

  • Placidus (default)
  • Koch
  • Equal
  • Whole Sign
  • Campanus
  • Regiomontanus
  • And more supported by the Swiss Ephemeris library

Technical Details

Date Format

  • Month is 1-12 (1 = January, 12 = December)
  • Hour is in 24-hour format (0-23)
  • All times are in local time for the birth location

Coordinate Format

  • Latitude: -90 to 90 (negative for South)
  • Longitude: -180 to 180 (negative for West)

Zodiac System

  • Uses tropical zodiac (aligned with seasons)
  • Degrees are measured from 0° Aries

Astrological Information Provided

Planets

Sun, Moon, Mercury, Venus, Mars, Jupiter, Saturn, Uranus, Neptune, Pluto, North Node (Mean Node), Chiron

Chart Points

  • Ascendant (AS) - Rising sign
  • Midheaven (MC) - Medium Coeli
  • Descendant (DS) - Opposite Ascendant
  • Imum Coeli (IC) - Opposite Midheaven

Aspects

Automatically calculates aspects between all planets with configurable orbs:

Major Aspects:

  • Conjunction (0°, orb: 10°)
  • Sextile (60°, orb: 6°)
  • Square (90°, orb: 8°)
  • Trine (120°, orb: 8°)
  • Opposition (180°, orb: 10°)

Minor Aspects:

  • Semi-Sextile (30°, orb: 3°)
  • Semi-Square (45°, orb: 3°)
  • Sesquiquadrate (135°, orb: 3°)
  • Quincunx (150°, orb: 3°)

License

AGPL-3.0

Migration to Swiss Ephemeris

This server has been migrated from circular-natal-horoscope-js to @swisseph/node for improved accuracy. The Swiss Ephemeris is the industry standard for astronomical calculations in astrology, providing:

  • Higher precision planetary positions (accurate to arcminutes)
  • Reliable retrograde detection
  • Extensive support for asteroids and minor bodies
  • Industry-standard calculations used by professional astrologers

See MIGRATION_NOTES.md and compare-libraries.ts for migration details and accuracy comparisons.

Credits

Built with: