# Typesense API Reference for v30.1
This section of the documentation details all the API Endpoints available in Typesense and all the parameters you can use with them.
Use the links on the side navigation bar to get to the appropriate section you're looking for.
To learn how to install and run Typesense, see the Guide section (opens new window) instead.
# What's new
This release contains new features, enhancements, performance improvements, bug fixes and important API changes for synonyms, curation rules and analytics rules.
# New Features
- Diversify Search Results: Using Maximum Marginal Relevance (MMR), you can now diversify the top 250 hits on a pre-defined similarity metric. (Docs) (opens new window)
- Global Synonyms: Synonyms are now top-level resources, and can be shared between collections. (Docs) (opens new window)
- Global Curation Rules: Curations are also top-level resources now, and can be shared between multiple collections. (Docs) (opens new window)
- New features in JOINs:
facet_bynow supports JOINed reference fields. (Docs) (opens new window)- Fetch related docs count for a document in a joined collection with the
include_fieldsparam. (Docs) (opens new window) - Support sorting and limit on joined fields with
include_fieldsparameter. (Docs) (opens new window) - Support for altering reference fields in the collection schema.
- New
cascade_delete: falseJOIN parameter for areferencefield, to override the default behavior of document being cascade deleted in case all the documents it references are deleted. Requiresasync_referenceparameter to betrue. (Docs) (opens new window)
- New features in Union Search:
- Support for
group_bywith Union search. (Docs) (opens new window) - Support for the
pinned_hitssearch parameter in Union search. - Support for filtering out duplicates when using Union search with a new flag called
remove_duplicates. (Docs) (opens new window)
- Support for
- Facet Sampling: Make facet sampling dynamic using the new
facet_sample_slopesearch parameter. (Docs) (opens new window) - IPv6 Support: Typesense now supports binding to and serving requests over IPv6 addresses, enabling seamless integration and connectivity in modern IPv6-only or dual-stack networks.
# Enhancements
- Support for (optionally) copying documents when cloning collections. (Docs) (opens new window)
- Support for
!as a standalone negation operator in filters, allowingfield:![value]syntax as an alternative tofield:!=[value]. - Support for Azure OpenAI models in Natural Language Search. (Docs) (opens new window)
- Support for GCP service account authentication in Natural Language Search models. (Docs) (opens new window)
- Support for GCP service account authentication for auto-embedding with GCP models. (Docs) (opens new window)
- Configurable token truncation for string fields to improve exact match filtering on long strings, using the new
truncateparameter in the collection schema. (Docs) (opens new window) - Return an error message when a field is declared that references another field of the same collection.
- New
group_max_candidatessearch parameter which overrides the behavior ofgroup_byqueries introduced in v29.0 (opens new window) wherefoundvalue is an approximation. Whengroup_max_candidatesis passed,foundwill be accurate up until its value. (Docs) (opens new window) - Allow non-indexed nested fields to still be marked as required.
- Improved synonym matching logic: Previously, synonym matches with a higher number of tokens (query/synonym) would be ranked higher. Now, matches are ranked by how well they match the query/synonyms overall, not just by the number of matched tokens.
- Use Transliterator objects pool to enhance tokenization performance of Cyrillic and Chinese languages.
- Support for dynamic
facet_return_parentfields. (Docs) (opens new window) - Support for sending an empty array to avoid embedding generation for an optional auto embedding field when indexing a document.
- Highlight the actual search query when augmenting the search query with Natural Language search.
- Enhance image embedding models support by adding CLIP Multilingual Model support
- Support for synonym matching in curations (Docs) (opens new window)
- Support stemming with curations (Docs) (opens new window)
# Bug Fixes
- Fix parsing of
_eval()expressions when backticks are used to wrap strings containing parentheses. - Ensure unique analytics IDs are generated when queries differ by
filter_byoranalytics_tagmetadata to prevent aggregation issues. - Fix search highlighting to use field-specific token separators instead of collection-level ones for consistent behavior.
- Return
201status code when creating conversational models, personalization models, or natural language search models to follow REST conventions. - Fix custom OpenAI-compatible endpoint URLs not being used for auto-embedding.
- Fix schema updates with embedding fields incorrectly requiring
api_keyvalidation for local models. - Fix console logging to output info messages to stdout and warnings/errors to stderr instead of all to stderr.
- Fix phrase query highlighting to highlight only exact phrase matches instead of every individual keyword occurrence.
- Set user agent when initializing HTTP client for external API calls.
- Fix hyphen handling in negation searches to only apply special treatment when token starts with
-. - Fix query sub-tokenization to respect field-level
symbols_to_indexandtoken_separatorsconfiguration. - Fix union search pagination bug where global pagination parameters were not passed to individual queries.
- Fix missing groups in case of high cardinality fields.
- Fix various deadlock scenarios related to async reference fields.
- Fix an edge case in
group_byquery along withinfixsearch. - Fix non-deterministic bucketing order when combining
group_bywith text match score bucketing, ensuring stable group pagination. - Support
id:![...]negation syntax for id filters. - Fix remote embedder cache key handling for matryoshka models with different
num_dimvalues to prevent dimension mismatches. - Fix nested array highlights to respect
highlight_affix_num_tokensfor single-token matches. - Fix phrase highlighting in nested array fields to return all matching snippets.
- Fix a crash while searching when updates are happening in parallel.
- Fixed the override matching for wildcard queries, dynamic filter, dynamic sort, and placeholders.
- Fix sort using
_eval()foridfields. - Fix missing vector distance in results when doing hybrid search with union search.
- Fix missing results when querying a stemmed field with
drop_tokens_thresholdset. - Fix an edge case where field name can be empty.
- Fix synonym resolution when
synonym_prefixis disabled. - Fix allowing the addition of the same field multiple times when altering the collection.
- Fix an edge case that enables using resolved synonyms as prefixes when prefix search is enabled.
- Fix adding the field to schema despite an error, when sorting is enabled for a field that has
autoas its type. - Fix
max_bytesparameters usage for the OpenAI's o-series and GPT-5 models. - Prevent usage of
temperatureparameter for the o-series and GPT-5 models since it is not supported. - Fix curation rule matching when doing semantic search with embedding generation.
- Fix rocksdb params assignment
- Fix missing joined collection fields in pinned hits
- Fix blocking indexing while generating embeddings.
- Fix issues of using outdated schemas when altering operations is ongoing while indexing documents.
- Fix curations with rerank_hybrid_matches
- Fix uninitialized analytics manager crash
- Validate that curation rules with
matchalso includequery, returning400otherwise. - Fix dropping nested object fields to only remove dot-delimited children, preserving similarly-prefixed top-level fields.
- Fix conversation and natural language search model updates when the model ID changes, returning
409on ID conflicts. - [New in 30.1] Fixed precision issue with search latency metric in
/stats.jsonendpoint
# Deprecations / behavior changes
- ⚠️ Synonyms are no longer nested under Collections. We now have a top-level resource called a "Synonym Set" which is a list of synonyms that can be attached to one or more collections, or can be dynamically sent as a search parameter. Existing synonyms will be auto-migrated to synonym sets automatically on upgrading. (Docs) (opens new window)
- ⚠️ Overrides (aka Curation Rules) are no longer nested under Collections. Similar to synonym sets, we now have a top-level resource called a "Curation Set" that can be attached to one or more collections, or can be dynamically sent as a search parameter. Existing overrides will be auto-migrated to curation sets automatically on upgrading. The
override_tags(opens new window) parameter has also been renamed tocuration_tags. (Docs) (opens new window) - ⚠️ The structure of Analytics Rules has changed. Old rules will be automatically migrated to the new structure internally. Read more here. (Docs) (opens new window)
- The export endpoint doesn't stop streaming the response if an error is encountered while loading a document from disk. The error is logged and is also returned in the response stream.
- Collections having references to each other are not allowed. If mutual reference is detected, the reference field will not be indexed.
# Upgrading
Before upgrading your existing Typesense cluster to v30.1, please review the behavior changes above to prepare your application for the upgrade.
We'd recommend testing on your development / staging environments before upgrading.
Follow this upgrade guide (opens new window), depending on your mode of deployment.
⚠️ Breaking Changes
Please make sure to update your client libraries to the latest version, review the specific documentation links provided above and make any required changes to your code base if you programmatically create these resources using the API, before upgrading to this version. If self-hosting, perform a snapshot (opens new window) before upgrading for the Synonyms & Overrides to be migrated to v30.
# Downgrading
If you use synonyms, overrides (curation rules) or analytics rules in previous versions of Typesense, we will auto-migrate them to the new resources (Synonym Sets, Curation Sets and the new format for analytics rules) on upgrading. However, if you make any changes to these resources, and then downgrade later, those changes will not be ported back to the old version after downgrade.
Besides the above caveat, you can safely downgrade to any version above v27.
TIP
This documentation itself is open source. If you find any issues, click on the Edit page button at the bottom of the page and send us a Pull Request.