Skip to main content
Glama

πŸ“‹ Table of Contents


πŸš€ Quick Start

Get a fully functional rental AI agent in 30 seconds.

# 1. Install
pip install -r requirements.txt

# 2. Run
python3 server.py

# 3. Add to Claude Desktop (see configuration below)
# Done. Your AI can now search listings, analyze neighborhoods,
# check affordability, compare options, review leases, and more.

That's it. No API keys. No database setup. No Docker required (though we support it). Just Python and an internet connection.

Prerequisites: Python 3.10+, pip, and an internet connection for location & listing data.


✨ Features

Rental Agent packs 8 purpose-built tools covering the entire rental workflow β€” from finding a place to signing the lease.

#

Tool

Description

πŸ”

rental_search_listings

Search for current rental listings in any city with price, bedroom, and result filters

🏘️

rental_neighborhood_report

Get a comprehensive neighborhood report: amenities, transit stops, parks, schools, and hospitals within 1km

πŸ’°

rental_affordability

Calculate how much rent you can afford using the 30% rule or 50/30/20 budget framework

βš–οΈ

rental_compare

Compare multiple listings side-by-side with auto-generated scores (0–100)

πŸ‘₯

rental_roommate_calculator

Split rent fairly β€” equal split, by room size, by income, or a combined method

πŸ“œ

rental_lease_analyzer

Analyze lease text for key terms, hidden fees, and red flags (late fees, pet policies, eviction clauses)

πŸš—

rental_commute_analysis

Estimate drive/transit time and monthly commuting costs between two locations

πŸ“ˆ

rental_market_trends

Get rental market context, estimated affordability, and city-level income benchmarks

Why these tools? Each one solves a concrete problem renters face. Combined, they form an end-to-end rental assistant that would normally require 5+ different websites and a spreadsheet.


πŸ—οΈ Architecture

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                        YOUR AI AGENT                                 β”‚
β”‚            (Claude Desktop, Cursor, VS Code, Copilot, etc.)          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                             β”‚
                             β–Ό
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                     Model Context Protocol (MCP)                     β”‚
β”‚                           StdIO Transport                            β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                             β”‚
                             β–Ό
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                         RENTAL AGENT MCP                             β”‚
β”‚                                                                      β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚
β”‚  β”‚ Search      β”‚  β”‚ Neighborhood β”‚  β”‚ Afford-     β”‚  β”‚ Compare   β”‚ β”‚
β”‚  β”‚ Listings    β”‚  β”‚ Report       β”‚  β”‚ ability     β”‚  β”‚ Listings  β”‚ β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”˜ β”‚
β”‚         β”‚                β”‚                 β”‚               β”‚       β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β” β”‚
β”‚  β”‚ Roommate    β”‚  β”‚ Lease        β”‚  β”‚ Commute     β”‚  β”‚ Market    β”‚ β”‚
β”‚  β”‚ Calculator  β”‚  β”‚ Analyzer     β”‚  β”‚ Analysis    β”‚  β”‚ Trends    β”‚ β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”˜ β”‚
β”‚         β”‚                β”‚                 β”‚               β”‚       β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”˜
          β”‚                β”‚                 β”‚               β”‚
          β–Ό                β–Ό                 β–Ό               β–Ό
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                      DATA SOURCES                                    β”‚
β”‚                                                                      β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”‚
β”‚  β”‚  OpenStreetMap  β”‚  β”‚   Nominatim    β”‚  β”‚    DuckDuckGo        β”‚   β”‚
β”‚  β”‚  (Overpass API)  β”‚  β”‚  (Geocoding)   β”‚  β”‚   (Web Search)       β”‚   β”‚
β”‚  β”‚  Amenities,     β”‚  β”‚  Lat/Lon from  β”‚  β”‚  Rental listings,    β”‚   β”‚
β”‚  β”‚  transit, parks β”‚  β”‚  place names   β”‚  β”‚  market data         β”‚   β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β”‚
β”‚                                                                      β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”‚
β”‚  β”‚              Built-in Calculations Engine                     β”‚   β”‚
β”‚  β”‚  Affordability math β”‚ Rent splitting β”‚ Commute estimation     β”‚   β”‚
β”‚  β”‚  Comparison scoring β”‚ Lease text analysis β”‚ Market insights   β”‚   β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Zero external dependencies for data. All sources are free, open, and require no API keys. The calculation engine is built into the server itself.


🎯 Use Cases

🏠 Apartment Hunting

Search listings, compare options with scores, and check neighborhood walkability β€” all in one conversation.

"Find me 2-bedroom apartments in Austin TX under $2,000, compare the top 3, and tell me about the neighborhoods."

πŸ—ΊοΈ Relocation Planning

Moving to a new city? Get neighborhood reports, commute estimates, and market trends before you visit.

"I'm moving to Seattle for a job in South Lake Union. What neighborhoods are within a 30-minute commute and what's the average 1-bedroom rent?"

πŸ’° Budget Planning

Know exactly what you can afford before you start looking. No surprises.

"I make $72,000 a year with $400 in monthly student loans. What rent can I afford using the 50/30/20 rule?"

πŸ‘₯ Roommate Coordination

Fair rent splitting prevents arguments. Choose equal, by-room-size, by-income, or a hybrid.

"Split $3,200 rent between Alice (150 sqft, $50k income), Bob (120 sqft, $60k), and Carol (130 sqft, $45k) using the combined method."

πŸ“œ Lease Review

Catch red flags, hidden fees, and unfavorable terms before you sign.

"Here's my lease agreement. Can you analyze it for late fees, pet policy, subleasing restrictions, and maintenance obligations?"

πŸš— Commute Optimization

Compare neighborhoods by commute time and cost. The 45-minute threshold can save you thousands.

"Compare commute times from Downtown Austin vs Mueller vs East Austin to my office at 78701."


πŸ“¦ Installation

git clone https://github.com/Rumblingb/rental-agent-mcp.git
cd rental-agent-mcp
pip install -r requirements.txt
python3 server.py

uv (Fastest Python package manager)

git clone https://github.com/Rumblingb/rental-agent-mcp.git
cd rental-agent-mcp
uv pip install -r requirements.txt
python3 server.py

Docker

docker run -it --rm \
  -v $(pwd):/app \
  -w /app \
  python:3.11-slim \
  bash -c "pip install -r requirements.txt && python3 server.py"

Manual (From Source)

git clone https://github.com/Rumblingb/rental-agent-mcp.git
cd rental-agent-mcp
python3 -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate
pip install mcp httpx
python3 server.py

Smithery (Cloud Deployment)

Deploy on Smithery

One-click deployment to Smithery's cloud infrastructure. No local setup required.


βš™οΈ Configuration

Environment Variables

None required. Rental Agent works out of the box with zero configuration.

Variable

Required

Default

Description

β€”

❌

β€”

No env vars needed. Truly plug-and-play.

Claude Desktop

  1. Open Claude Desktop Settings β†’ Developer β†’ Edit Config

  2. Add to claude_desktop_config.json:

{
  "mcpServers": {
    "rental-agent": {
      "command": "python3",
      "args": ["/path/to/rental-agent-mcp/server.py"]
    }
  }
}

VS Code (Cline / Continue)

For Continue extension in VS Code, add to your ~/.continue/config.json:

{
  "experimental": {
    "mcpServers": {
      "rental-agent": {
        "command": "python3",
        "args": ["/path/to/rental-agent-mcp/server.py"]
      }
    }
  }
}

For Cline extension, configure in Cline settings β†’ MCP Servers:

{
  "mcpServers": {
    "rental-agent": {
      "command": "python3",
      "args": ["/path/to/rental-agent-mcp/server.py"]
    }
  }
}

Cursor

  1. Open Cursor Settings β†’ Features β†’ MCP Servers

  2. Click Add New MCP Server

  3. Set Name: rental-agent

  4. Set Type: command

  5. Set Command: python3 /path/to/rental-agent-mcp/server.py

  6. Click Save


πŸ”§ Tool Reference

πŸ” rental_search_listings

Search for current rental listings in any city using web search aggregation.

Parameters:

Parameter

Type

Required

Default

Description

location

string

βœ…

β€”

City, state, or neighborhood (e.g. "Austin TX", "Brooklyn NY")

min_price

integer

❌

β€”

Minimum monthly rent filter

max_price

integer

❌

β€”

Maximum monthly rent filter

bedrooms

integer

❌

β€”

Number of bedrooms filter

max_results

integer

❌

5

Maximum number of results to return

Example:

{
  "location": "Austin TX",
  "max_price": 2000,
  "bedrooms": 2,
  "max_results": 3
}

🏘️ rental_neighborhood_report

Get a comprehensive neighborhood report powered by OpenStreetMap data.

Parameters:

Parameter

Type

Required

Default

Description

location

string

βœ…

β€”

Neighborhood or city (e.g. "Williamsburg Brooklyn", "Downtown Austin")

Returns: Restaurants, cafes, bars, supermarkets, gyms, parks, pharmacies, libraries counts within ~1km, plus transit stops, schools, and hospitals.

Example:

{
  "location": "Williamsburg Brooklyn"
}

Sample output:

{
  "neighborhood": "Williamsburg, Brooklyn, Kings County, New York, 11211, USA",
  "walkability": {
    "restaurants": 34,
    "cafes": 12,
    "bars": 18,
    "supermarkets": 4,
    "gyms": 3,
    "pharmacies": 2
  },
  "transit": { "transit_stops_nearby": 9 },
  "schools_nearby": 5,
  "walkability_note": "Higher amenity counts = more walkable. 5+ restaurants + cafes in 1km = very walkable."
}

πŸ’° rental_affordability

Calculate how much rent you can afford based on your income and expenses.

Parameters:

Parameter

Type

Required

Default

Description

annual_income

number

βœ…

β€”

Annual pre-tax income in USD

monthly_debt

number

❌

0

Monthly debt payments (loans, credit cards)

rule

string

❌

"30_percent"

Budget rule: "30_percent" or "50_30_20"

Budget Rules:

  • 30% Rule: Max rent = 30% of monthly gross income (landlord standard)

  • 50/30/20 Rule: 50% needs (rent within), 30% wants, 20% savings

Example:

{
  "annual_income": 75000,
  "monthly_debt": 300,
  "rule": "30_percent"
}

βš–οΈ rental_compare

Compare multiple rental options side-by-side with auto-generated scores (0–100).

Parameters:

Parameter

Type

Required

Default

Description

listings_json

string

βœ…

β€”

JSON array of listings with name, price, bedrooms, sqft, neighborhood

Listing format:

{
  "listings_json": "[{\"name\":\"Modern Downtown Studio\",\"price\":1800,\"bedrooms\":1,\"sqft\":650,\"neighborhood\":\"Downtown\"},{\"name\":\"East Side 2BR\",\"price\":2200,\"bedrooms\":2,\"sqft\":950,\"neighborhood\":\"East Austin\"},{\"name\":\"North Campus Studio\",\"price\":1200,\"bedrooms\":1,\"sqft\":500,\"neighborhood\":\"North Campus\"}]"
}

Scoring logic: Lower price = better score, more bedrooms = bonus, higher sqft = bonus, low $/sqft = bonus. Scores range 0–100.


πŸ‘₯ rental_roommate_calculator

Split rent fairly among roommates using one of four methods.

Parameters:

Parameter

Type

Required

Default

Description

total_rent

number

βœ…

β€”

Total monthly rent

roommates_json

string

βœ…

β€”

JSON array of roommates with name, room_size_sqft, income

method

string

❌

"by_room"

Method: "equal", "by_room", "by_income", or "combined"

Methods:

Method

Description

equal

Everyone pays the same amount

by_room

Split proportional to each person's room square footage

by_income

Split proportional to each person's income (progressive)

combined

50% by room size + 50% by income (fairest for most situations)

Example:

{
  "total_rent": 3200,
  "roommates_json": "[{\"name\":\"Alice\",\"room_size_sqft\":150,\"income\":50000},{\"name\":\"Bob\",\"room_size_sqft\":120,\"income\":60000},{\"name\":\"Carol\",\"room_size_sqft\":130,\"income\":45000}]",
  "method": "combined"
}

πŸ“œ rental_lease_analyzer

Analyze lease text for key terms, hidden fees, and red flags.

Parameters:

Parameter

Type

Required

Default

Description

lease_text

string

βœ…

β€”

Full text of the lease agreement

What it detects:

Category

Checks

Terms

Monthly rent amount, lease duration, security deposit

Fees

Late payment fees, pet fees/deposits

Red Flags

No subleasing, guest restrictions, eviction clauses, short inspection notice

Key Clauses

Utilities, parking, maintenance, renewal, termination

⚠️ Disclaimer: This tool provides informational analysis only and does not constitute legal advice. Always consult a lawyer for important lease decisions.


πŸš— rental_commute_analysis

Estimate commute time and monthly cost between two locations.

Parameters:

Parameter

Type

Required

Default

Description

from_location

string

βœ…

β€”

Your rental location or neighborhood

to_location

string

βœ…

β€”

Your workplace or destination

commute_days_per_month

integer

❌

20

Days you commute per month

What it calculates:

  • Straight-line distance (km and miles)

  • Estimated drive time (avg 50 km/h city speed)

  • Estimated transit time (avg 30 km/h + 10 min walk/wait)

  • Monthly driving cost (IRS rate: $0.60/mile)

  • Monthly transit cost (~$0.15/km)

Example:

{
  "from_location": "Mueller Austin",
  "to_location": "Downtown Austin",
  "commute_days_per_month": 22
}

πŸ“ˆ rental_market_trends

Get rental market context and price trends for any city.

Parameters:

Parameter

Type

Required

Default

Description

city

string

βœ…

β€”

City name (e.g. "Austin, TX", "Seattle, WA")

Returns: Web search results for average rental prices, plus estimated affordability based on median income benchmarks for major US cities (NYC, SF, LA, Chicago, Austin, Seattle, Boston, Denver, Miami, Portland, Nashville, Atlanta, Phoenix, Dallas, Houston).

Example:

{
  "city": "Denver, CO"
}

πŸ—ΊοΈ Data Sources

Rental Agent uses three free, open data sources β€” no API keys needed, ever.

OpenStreetMap (Overpass API)

What we use it for: Neighborhood amenities, transit stops, parks, schools, hospitals. Why it's free: OSM is the Wikipedia of maps β€” a global community of mappers contributing open geographic data. Reliability: Used by Apple Maps, Amazon, Meta, and thousands of other organizations. Updated continuously. Rate limits: Generous β€” suitable for hundreds of queries per day. No account needed: Public API, anonymous access.

Nominatim (OSM Geocoder)

What we use it for: Converting place names ("Williamsburg Brooklyn") to precise latitude/longitude coordinates. Why it's free: Operated by the OSM Foundation as a public service. Reliability: Powers geocoding for millions of applications worldwide. Usage policy: 1 request per second recommended (we use async with automatic spacing).

DuckDuckGo Instant Answers API

What we use it for: Searching for current rental listings and market trend data. Why it's free: DuckDuckGo provides a public API for non-commercial use. Reliability: Returns structured results from Wikipedia, Wikidata, and DuckDuckGo's index. No rate limiting: Generous access with no API key required.

Built-in Calculations Engine

All financial calculations (affordability, rent splitting, commute costs, comparison scoring, lease analysis) run locally on the server β€” no external API calls needed.


πŸ’° Pricing

Feature

Free

Pro

Price

$0

$19/mo

Daily queries

50/day

Unlimited

All 8 tools

βœ…

βœ…

All data sources

βœ…

βœ…

Zero API keys

βœ…

βœ…

Neighborhood reports

βœ…

βœ…

Lease analysis

βœ…

βœ…

Commute analysis

βœ…

βœ…

Market trends

βœ…

βœ…

Roommate calculator

βœ…

βœ…

Priority support

❌

βœ…

Early access to new tools

❌

βœ…

Get Pro: Subscribe Now

The free tier handles 50 queries/day β€” enough for casual apartment hunting. The Pro tier removes all limits for power users, real estate professionals, and teams.


🌐 API (Non-MCP)

You can also use Rental Agent as a standalone REST API server. This is useful if you want to integrate rental intelligence into your own application without the MCP protocol.

Quick Start (REST Mode)

from server import rental_search_listings, rental_neighborhood_report
import asyncio

async def main():
    # Search listings
    listings = await rental_search_listings(
        location="Austin TX",
        max_price=2000,
        bedrooms=2
    )
    print(listings)

    # Get neighborhood report
    report = await rental_neighborhood_report(
        location="Downtown Austin"
    )
    print(report)

asyncio.run(main())

Building a REST Wrapper

from fastapi import FastAPI
from server import rental_search_listings, rental_neighborhood_report
import asyncio

app = FastAPI()

@app.get("/search")
async def search(location: str, max_price: int = None, bedrooms: int = None):
    result = await rental_search_listings(
        location=location,
        max_price=max_price,
        bedrooms=bedrooms
    )
    return result

@app.get("/neighborhood")
async def neighborhood(location: str):
    result = await rental_neighborhood_report(location=location)
    return result

All 8 tools are async Python functions that accept the same parameters and return JSON strings β€” ready to be wrapped in any web framework.


🀝 Contributing

We welcome contributions from the community! Here's how to get started:

Development Setup

git clone https://github.com/Rumblingb/rental-agent-mcp.git
cd rental-agent-mcp
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt

Ways to Contribute

  • πŸ› Report bugs β€” Open an issue with a clear reproduction

  • πŸ’‘ Suggest features β€” New tools, data sources, or integrations

  • πŸ“ Improve docs β€” Better examples, clearer explanations

  • πŸ”§ Submit PRs β€” Code improvements, bug fixes, new tools

Guidelines

  1. Fork the repo and create a feature branch

  2. Write clean, typed Python with docstrings

  3. Test your changes locally with python3 server.py

  4. Open a PR with a clear description of what you changed and why

  5. Keep it simple β€” this project values clarity over cleverness

Roadmap Ideas

  • Zillow / Apartments.com direct API integration

  • Crime data overlay via open crime databases

  • School rating integration (GreatSchools API)

  • Transit time calculation using open GTFS data

  • Floor plan visualization analysis

  • Rent history tracking and prediction

  • Multi-language lease analysis


πŸ“„ License

MIT License β€” see LICENSE for details.

MIT License

Copyright (c) 2025 Rumblingb

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions...

A
license - permissive license
-
quality - not tested
C
maintenance

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Rumblingb/rental-agent-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server