A Model Context Protocol (MCP) server for working with Building Information Modeling (BIM) files. This server provides tools to convert IFC files to fragment format, load fragments, and query BIM data by category.
- IFC to Fragment Conversion: Convert Industry Foundation Classes (IFC) files to the open and efficient fragment format
- Fragment Loading: Load and work with pre-converted fragment files
- Category-based Querying: Fetch BIM elements by category (e.g., walls, doors, windows) with configurable attributes and relations
Converts an IFC file to a .frag file format for efficient processing.
Parameters:
inputPath
(string): Full path of the IFC file to convertoutputPath
(string): Full path where the output .frags file will be saved
Example:
Input: /path/to/building.ifc
Output: /path/to/building.frag
Loads a .frag file into memory for querying.
Parameters:
filePath
(string): Full path of the .frag file to load
Fetches elements of a specified IFC category from loaded fragments.
Parameters:
category
(string): Category name (e.g., "IFCWALL", "IFCDOOR", "IFCWINDOW")config
(object): Configuration for fetching elements with the following structure:attributesDefault
(boolean): Include default attributesattributes
(array): List of specific attributes to includerelations
(object): Relation configurationHasAssociations
: Include association relationsIsDefinedBy
: Include definition relations
@modelcontextprotocol/sdk
: MCP server framework@thatopen/fragments
: Fragment processing libraryweb-ifc
: IFC file processingzod
: Schema validation
- Install dependencies:
pnpm install
- Run the server:
node main.ts
To use this MCP server with Claude Desktop, add the following configuration to your Claude Desktop settings file:
- Open Claude Desktop settings
- Navigate to the MCP servers configuration
- Add the following JSON configuration:
{
"mcpServers": {
"filesystem": {
"command": "npx",
"args": [
"-y",
"@modelcontextprotocol/server-filesystem",
"/path/to/your/models/directory"
]
},
"bim": {
"command": "npx",
"args": [
"-y",
"tsx",
"/path/to/your/openbim-mcp/main.ts"
]
}
}
}
- Node.js must be installed and accessible via
npx
- The
tsx
package should be available (install globally withnpm install -g tsx
if needed) - Both the filesystem and bim servers need to be configured for full functionality
- Convert IFC to Fragment: Use
convert-ifc-to-frag
to convert your IFC file to the efficient fragment format - Load Fragments: Use
load-frag
to load the fragment file into memory - Query Elements: Use
fetch-elements-of-category
to retrieve specific building elements by their IFC category
Common categories you can query include:
IFCWALL
- WallsIFCDOOR
- DoorsIFCWINDOW
- WindowsIFCSLAB
- Slabs/FloorsIFCBEAM
- BeamsIFCCOLUMN
- ColumnsIFCSPACE
- Spaces/Rooms
- Node.js
- File system access for reading IFC files and writing fragment files
- Compatible with Model Context Protocol clients
Helen Kwok