# Typesense API Reference for v30.0
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
RC Version
This version is still in RC (Release Candidate) stages, which means that we're actively iterating on it. The changelog below is a running list of changes, and we'll be updating it as we release new RC versions.
Most RC builds are stable to run in production, since we fix any reported issues quickly and/or deprecate RC versions that have known issues swiftly. But as with any version, we recommend that you test RC versions in your staging / dev environment before upgrading production.
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 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.
# 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 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.
# 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 Collection. Similar to synonym sets, we now have a top-level resource called a "Curation Set" that can be attached to one or more collection, or can be dynamically sent as a search parameter. Existing overrides will be auto-migrated to curation sets automatically on upgrading. (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.
⚠️ 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.
# Upgrading
Before upgrading your existing Typesense cluster to v30.0, 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.
# 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.