Skip to main content
Glama

zk_create_link

Establishes a link between two notes in a Zettelkasten system, defining connection types like reference, extends, or contradicts. Supports bidirectional linking and optional descriptions for clarity.

Instructions

Create a link between two notes. Args: source_id: ID of the source note target_id: ID of the target note link_type: Type of link (reference, extends, refines, contradicts, questions, supports, related) description: Optional description of the link bidirectional: Whether to create a link in both directions

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
bidirectionalNo
descriptionNo
link_typeNoreference
source_idYes
target_idYes

Implementation Reference

  • The handler function that executes the zk_create_link tool logic. It validates inputs (converting link_type to enum), calls ZettelService.create_link, and handles errors including duplicate links.
    def zk_create_link(
        source_id: str,
        target_id: str,
        link_type: str = "reference",
        description: str | None = None,
        bidirectional: bool = False,
    ) -> str:
        """Create a semantic link between two notes to build knowledge connections.
    
        Args:
            source_id: The unique ID of the source note
            target_id: The unique ID of the target note
            link_type: Type of semantic relationship - one of: reference, extends, refines, contradicts, questions, supports, related (default: reference)
            description: Optional text describing the nature of this specific link
            bidirectional: If true, creates links in both directions (source→target and target→source)
        """
        try:
            # Convert link_type string to enum
            try:
                source_id_str = str(source_id)
                target_id_str = str(target_id)
                link_type_enum = LinkType(link_type.lower())
            except ValueError:
                return f"Invalid link type: {link_type}. Valid types are: {', '.join(t.value for t in LinkType)}"
    
            # Create the link
            source_note, target_note = self.zettel_service.create_link(
                source_id=source_id,
                target_id=target_id,
                link_type=link_type_enum,
                description=description,
                bidirectional=bidirectional,
            )
            if bidirectional:
                return f"Bidirectional link created between {source_id} and {target_id}"
            else:
                return f"Link created from {source_id} to {target_id}"
        except (Exception, sqlalchemy_exc.IntegrityError) as e:
            if "UNIQUE constraint failed" in str(e):
                return f"A link of this type already exists between these notes. Try a different link type."
            return self.format_error_response(e)
  • The registration of the zk_create_link tool using the FastMCP @tool decorator, specifying name, description, and hints. Includes function assignment to instance and logging.
    @self.mcp.tool(
        name="zk_create_link",
        description="Create a semantic link between two notes to build knowledge connections.",
        annotations={
            "readOnlyHint": False,
            "destructiveHint": False,
            "idempotentHint": False,
        },
    )
    def zk_create_link(
        source_id: str,
        target_id: str,
        link_type: str = "reference",
        description: str | None = None,
        bidirectional: bool = False,
    ) -> str:
        """Create a semantic link between two notes to build knowledge connections.
    
        Args:
            source_id: The unique ID of the source note
            target_id: The unique ID of the target note
            link_type: Type of semantic relationship - one of: reference, extends, refines, contradicts, questions, supports, related (default: reference)
            description: Optional text describing the nature of this specific link
            bidirectional: If true, creates links in both directions (source→target and target→source)
        """
        try:
            # Convert link_type string to enum
            try:
                source_id_str = str(source_id)
                target_id_str = str(target_id)
                link_type_enum = LinkType(link_type.lower())
            except ValueError:
                return f"Invalid link type: {link_type}. Valid types are: {', '.join(t.value for t in LinkType)}"
    
            # Create the link
            source_note, target_note = self.zettel_service.create_link(
                source_id=source_id,
                target_id=target_id,
                link_type=link_type_enum,
                description=description,
                bidirectional=bidirectional,
            )
            if bidirectional:
                return f"Bidirectional link created between {source_id} and {target_id}"
            else:
                return f"Link created from {source_id} to {target_id}"
        except (Exception, sqlalchemy_exc.IntegrityError) as e:
            if "UNIQUE constraint failed" in str(e):
                return f"A link of this type already exists between these notes. Try a different link type."
            return self.format_error_response(e)
    
    self.zk_create_link = zk_create_link
    
    logger.debug("Tool zk_create_link registered")
  • Input schema inferred from function parameters: source_id (str), target_id (str), link_type (str, default 'reference'), description (optional str), bidirectional (bool, default False). Output is str response.
    def zk_create_link(
        source_id: str,
        target_id: str,
        link_type: str = "reference",
        description: str | None = None,
        bidirectional: bool = False,
    ) -> str:

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/Liam-Deacon/zettelkasten-mcp'

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