Omniverse Client Library Changes
2.60.1
- OMPE-46156: Don’t print “Error: Shutdown” messages to the log when the Hub client is shutdown. 
2.60.0
- OMPE-40641: Fix issue where Hub cache sometimes stores a 0 byte file 
- OMPE-42421: Fix race condition in Nucleus list cache by not caching “not found” errors 
- HUB-1247: Expose BypassListCache function in Python API 
- OMPE-44986: Update storage-protos to 0.10.0 
- OMPE-44421: Fix calling stat on a non-existent file when using the storage provider. 
- OMPE-45527: Fix missing trailing quote on Linux when calling xdg-open to launch the web browser. 
- OMPE-29326: Support EnumerateVersions call in Storage APIs 
- OMPE-43369: Updated some arg help strings in run_tests.py Also a few small functionality tweaks to some args: - –only-py has “choices” (so –help will show allowed values) 
- –only-py accepts versions with a dot (ie, 3.10) 
- –server discards empty pieces after splitting OMNI_TEST_HOSTS env var 
 
- OMPE-43369: update tools/nucleus_runner/README.md 
- OMPE-27303: fix - PostArgs operator= didn’t return anything (fixes error with gcc-11) 
- OMPE-27303: update to doctest 2.4.5 to resolve compile error with gcc-11 
- OMPE-44100: add NVCFJWT utils for adding NVCF JWT headers when running in NVCF and are required for bridge passthrough - added information in README.md for platform based configuration 
 
 
2.59.0
- OMPE-38131: Added environment variable - OMNI_STORAGE_URL_REWRITEto perform client side URL remapping.
- OMPE-33522: Update to Nucleus connection library 1.14.52 to address live updates being applied out-of-order. 
2.58.0
- OMPE-37179: Update storage-protos to 0.9.0 
- OMPE-18832: Added support for delete when using the new storage api. 
- OMPE-30926: Added support for discovery & authentication to storage provider. Added environment variables: - set OMNI_STORAGE_DISCOVERY=<discovery url>
- set OMNI_STORAGE_CLIENT_ID=<client id from open id provider>
 
- OMPE-37648: Don’t disable cache if Hub is enabled because it may be intentionally pointing to a remote cache (or proxy). 
2.57.0
- OMPE-35911: Update connection library to 1.14.49. 
- OMPE-30125: Retry gRPC requests when the server returns certain error codes. 
- OMPE-18836: Add support for listing using the new storage api. 
- OMPE-35942: Fix a crash if an http server returns a code 429 with a “Retry-After” header. 
- OMPE-36695: Add client id to “x-request-id” header to grpc and http requests. 
2.56.0
- OMPE-28596: Allow https proxies 
2.55.0
- OMPE-30097: Update storage-protos to 0.8.0 
- OMPE-28902: Fixed a rare crash in omniClientResolve if the default search path changed in another thread. 
- OMPE-28861: Fixed omni.client.get_default_search_paths returning corrupt data. Note: The above 2 changes required deprecating omniClientGetDefaultSearchPaths. It has been replaced with omniClientGetDefaultSearchPaths2. 
- OMPE-28596: Update connection library, idl.cpp, and idl.py for NVCF 
2.54.0
- OMPE-17241: Update connection library to 1.14.44 
- OMPE-26701: Update openssl to 3.0.15 
- OMPE-1700: Update idl.cpp to 0.18 
- OMPE-28166: Update storage-protos to 0.7.0 
- OMPE-12180: Add support for writing using the new storage api 
2.53.3
- OMPE-27906: Remove the gRPC deadline. 
2.53.2
- OMPE-26372: Add support for Python 3.12 
- OMPE-10556: Upload wheels to Artifactory 
- OMPE-17424: Update Python for latest bug fixes 
- OMPE-21409: Remove “other” access when creating files & folders on Linux 
- OMPE-15441: Expose Hub HTTP port in API 
- OMPE-25343: Fix rare use-after-free bug in getLocalFile. 
- OMPE-25613: Added omniClientRegisterMetricsCallback 
- OMPE-26316: Fix a bug in omni.client.set_azure_sas_token which causes slow loads 
2.53.1
- DRIVE-20002: Update the omniverse connection library to address slow downloads in rare circumstances. 
2.53.0
- OMPE-19294: Update to storage-protos 0.5.0 
- OMPE-19355: Add OMNI_STORAGE_PROXY environment variable to specify a proxy used when downloading files using the new Storage API. 
- OMPE-19774: Update gRPC to 1.65.4 
- OMPE-19775: Force TLSv1.2 in HTTP connections 
2.52.0
- OMPE-2703: Update libcurl to 8.9.0 
- OMPE-16442: Update to Nucleus connection library 1.14.25.3 
- OMPE-17544: Update to storage-protos 0.4.0 
- OMPE-16821: Improve performance when loading 
- OMPE-17414: Add omniClientSetHttpHeader and omni.client.set_http_header 
- OMPE-15739: Add multi-part downloads to storage provider 
2.51.0
- OMPE-13818: Include linux-aarch64 build. 
- OMPE-14592: Don’t emit errors when calling stat on the root of an Azure URL. 
- OMPE-14657: Fix crash when loading from storage service. 
- OMPE-14659: Fix loading materials from storage service. 
- OMPE-15191: Update packman & repo tools. 
- OMPE-10831: Add metrics to storage service client provider. 
- HUB-1245: Allow plain hostname and make region/bucket optional in set_s3_configuration. 
2.50.0
- OMPE-9404: Add support for Storage API. Use the following environment variables to use it: - set OMNI_STORAGE_ENABLED=1defaults to 0
- set OMNI_STORAGE_HOST={host or ip}defaults to localhost
- set OMNI_STORAGE_PORT={port number}defaults to 50051
 
- OMPE-12040: Add support for connecting to the storage service on NVCF. In use these environment variables in addition to the ones above: - set OMNI_STORAGE_AUTHORIZATION=Bearer {your-api-token}
- set OMNI_STORAGE_FUNCTION_ID={function-id}
- set OMNI_STORAGE_FUNCTION_VERSION_ID={function-version-id}
 
- OVCC-1605: (Windows) Changed directory walking to use a Windows 7+ feature for increased performance. 
2.49.0
- OMPE-2707: Update to Hub 2024.1.0-beta.4, improves resilience when Hub is unavailable or not responding. 
2.48.0
- HUB-989: Support AWS STS Session Token 
2.47.1
- OM-122769: Update to Hub 2024.1.0-beta.3 to fix various CVEs 
2.47.0
- OM-122916: (Linux) Fixed a hang when listSubscribe was used when the system is out of inotify objects. 
2.46.0
- Update to Carbonite 165.0 
- OM-121740: Fix a crash when the user folder has unicode characters in it. 
2.45.0
- HUB-956: Add - omniClientWriteFileEx2function. Exposes the ability of skipping checkpoints.
- HUB-982: Remove Python 3.7 & 3.8 bindings 
- HUB-976: Update dependencies for security fixes 
- OM-120779: Update zlib to 1.3.1 and curl to 8.6.0 
2.44.0
- HUB-963: Update Hub to 2024.1.0-beta.1 
- OM-117444: Update to carb sdk 160.6 
- OM-119434: Support Python 3.11 
- OSEC-1099: Code sign Windows binaries 
2.43.0
- HUB-936: Update omni-trace to 1.6.9cb34d66 
- HUB-940: Update Hub in client library to 0.34.0-beta.3 
- HUB-939: Fix console error when using browser based auth in Linux. 
- HUB-878: Update all dependencies to get latest security fixes. 
- HUB-410: Added functions to copy/move a file or folder explicitly. These return a “wrong type” error if you try to copy a file, but it’s actually a folder and vice versa. 
- HUB-945: Added omniClientDeleteSingle to delete a single file or non-recursively delete an empty folder. 
2.42.0
- HUB-928: Don’t erase tokens from cache during sign out unless we signed in using those tokens. 
- HUB-929: Fix a crash that could happen if multiple threads are using Hub simultaneously. 
- HUB-931: Change omniClientGetOmniHubVersion to return software version rather than API version 
- HUB-934: Don’t ever use auth service “fast api”. 
2.41.0
- OMFP-3351: Skip cache if it’s localhost. 
- OMFP-3668: Integrate Nucleus connection library 1.14.25 to fix OMFP-2984. 
- OMFP-3561: Fix GIL issue in Python bindings. 
- OMFP-2623: Update to carb sdk 157 
- OMFP-3291 Integrate Nucleus connection library 1.14.24 to obfuscate the Auth Token. 
- OMFP-2627: Fixed improper null termination. 
- OMFP-2623: Update libcurl to 8.4.0 
- OM-113503: Creating a Folder in the C:/ root doesn’t work. 
- OM-107335: Fix crash when trying to watch a drive that doesn’t support watches. 
- OM-81689: Remove error when browsing drives which don’t support watches (ie: a Google Drive) 
- OM-111911: Fix a crash when authentication is quickly cancelled twice. 
- HUB-777: Mark - get_local_fileas deprecated. Use- open_cached_fileand- close_cached_fileinstead.
- HUB-909: Fixed omniClientGetLocalFile ignores the “download” flag with hub cache. 
- HUB-916: Removed OMNICLIENT_USE_HUB variable – use OMNICLIENT_HUB_MODE=disabled to disable Hub. 
- HUB-921: Update Hub to 0.33.0 
2.40.1
- HUB-900: Fix shutdown crash in hub client due to static destruction order. 
2.40.0
- HUB-854: Re-enable searching for Hub by default 
- OMFP-1915: Don’t call WSAStartup from DllMain. 
- OMFP-2642: Reduce verbose logging spam during live edit. 
- OMFP-2164: Fix error when there are no bookmarks. 
- OMFP-2330: Fix “ERROR_NOT_FOUND” when copying a live folder. 
- OM-112051: Fix crash while allocating a watch buffer. 
- HUB-735: Replace KvCache Hub functions with new bulk BlockCache functions 
2.39.0
- HUB-857: Fix random crash at shutdown inside SSL code. 
- HUB-869: Fix an asyncio exception in Python bindings if a task is cancelled. 
- OM-106654: Fix a crash during reconnect. 
- HUB-879: Fix crash in debug mode when authenticating. 
- OM-107411: Fix crash during authentication. 
2.38.0
- HUB-852: Update to Nucleus connection library 1.14.22 to fix an issue with mTLS. 
- HUB-847: Don’t cache checkpoints because they could change. 
- HUB-854: Don’t search for Hub by default 
- OMFP-808: Fix “Calling add_bookmark with an empty name corrupts omniverse.toml” 
2.37.0
- HUB-830: Add more profiling zones. 
- OM-105934: Fix rare crash that could happen while connecting to Nucleus. 
- OM-106211: Fix a crash that could happen after stopping an http request. 
- OM-103618: Update Nucleus connection library to 1.14.20 for improved mTLS support. 
- OM-106231: Support specifying an access token without a refresh token. 
- HUB-835: Fixed exception at startup if cache folder could not be created. 
- OM-107499: Fixed “Can not copy file to root directory of a local drive” 
- OM-106080: Potentially fixed a crash in the Python async functions if asyncio is torn down while a request is active. 
- HUB-816: Update to OpenSSL 3.0.10 
2.36.0
- OM-100906: Fix send error 10057. 
- HUB-813: Remove 24 hour maximum wait. 
- OM-80653: When doing a recursive copy, always use eOmniClientCopy_Overwrite on children, because we only want the “eOmniClientCopy_ErrorIfExists” behavior on the root (ie: the thing passed to the copy command). This fixes the problem where services are auto-generating derived data during the copy operation. 
- HUB-818: Modify the way bearer tokens are handled. 
- HUB-788: Add support for “list” in Azure, and reading private blobs using SAS tokens. 
- HUB-829: Fixed an issue reading files from HTTP through Python. 
2.35.0
- HUB-708: Replace CapnProto Hub client with the new MessagePack based client 
- HUB-792: Add support for “omniverses://” and “omnis://” URLs to force a secure connection using SSL/TLS. 
- OM-98128: Support Nucleus on public internet via Bearer tokens. 
- HUB-782: Invalidate the list cache when parent folders are automatically created. 
- OM-101032: Add binding for Nucleus connection library’s createAssetWithHash 
- HUB-806: When using Hub, properly cache files from mounts. 
- HUB-807: Pass object id to omniClientLiveRegisterQueuedCallback2 
- OM-99833: omniClientGetLocalFile will percent-decode “file:” URLs 
- OM-98800: Allow over-writing a file locked by this process. 
- OM-95284: Add a 1 second delay before re-parsing bookmarks after they change. 
2.34.0
- HUB-793: Update to Nucleus connection library v1.14.19 
- HUB-765: Remove support for directly connecting to the Nucleus core api server on port 3009 with an explicit username and password. Discovery and Authentication servers are now required. They have been available since Nucleus 1.11.0, released September 2021. 
- HUB-769: Discover via TLS prior to non-TLS. Also add a 10 second timeout for discovery. 
- HUB-768: When reading a token from cache, always refresh it. 
- HUB-791: Fixed device flow not triggering the callback a second time to hide the dialog. 
- OM-101827: Fix - _cache.jsonnot being written if the parent folder doesn’t exist.
2.33.0
- OM-94012: Now shipping wheel files to allow easy installation of the Python bindings via pip. They are found in the wheels subdirectory of the 7z package. 
- HUB-757: Print server name in error message when jitter reduction pings fail. 
- HUB-756: Improve random number generation – works around a bug with certain processors who don’t support std::random_device 
- HUB-753: Add support for “soft delete” server feature 
- HUB-755: Emit telemetry events when connecting/disconnecting to Nucleus servers 
- HUB-758: Add reconnect logic for jitter reduction pings 
- HUB-761: Add - omniClientTraceStart&- omniClientTraceStop
- OM-94500: Add support for new device auth flow. 
2.32.0
- Update to Nucleus connection library v1.14.12 
- HUB-413: trying to delete a non-existant Nucleus path with a slash at the end now returns “ERROR_NOT_FOUND” instead of “OK” 
- HUB-745: change log message for when cache is bypassed from warning to verbose 
- HUB-422: The behaviour of the “obliterate” command on servers not supporting soft-delete is now consistent with the behaviour on servers supporting soft-delete. 
- OM-93942: Improve performance loading scenes from local disk in Linux. 
2.31.0
- Update to Nucleus connection library v1.14.10 
- HUB-652: Fixed a crash that can happen if omni::kit::IApp is present, but not started prior to initializing client library. 
- HUB-587: When calling - liston a folder which doesn’t exist, cache the failure but also establish a list subscription to the parent folder to automatically invalidate the cache entry if the parent folder changes. This happens recursively up to root.
- HUB-720: Add python bindings: - omni.client.add_default_search_path
- omni.client.remove_default_search_path
- omni.client.get_default_search_paths
- omni.client.push_base_url
- omni.client.pop_base_url
- omni.client.get_base_url
 
- HUB-653: Pass product information to Nucleus during authentication. 
2.30.0
- HUB-604: Reverted this change, because it was causing issues on Linux when the path starts with ‘/’ but we actually do want to use the search paths. 
- HUB-610: Adding a dep/public-redist.packman.xml file that can be used by downstream packages to include the correct version of the omni-hub package to pull. Specifying the dependency to omni-hub and copying the hub.exe is still in the responsibility of the package using the ClientLibrary. 
- HUB-652: Added omniClientSetProductInfo & omni.client.set_product_info to set information which is sent to Nucleus servers when connecting, so we can have additional information about which clients are being used with which servers. 
- HUB-670: Pass product information to Hub during initialization. 
- HUB-671: Don’t log error message when Hub is not installed. 
- HUB-669: Don’t try to close locked files in omniClientKvCacheStat causing error message “Got exception when trying to close handle ‘0’: Handle not found in close operation” 
- HUB-677: Fix finding the latest version of the globally installed Hub. 
- HUB-680: Add omniClientLiveRead2 and omniClientLiveUpdate2 for Live v2. 
- HUB-681: Fix a race condition in getLocalFile when not using Hub. 
- OM-84940: Added a function to refresh the auth token: - omniClientRefreshAuthTokenand- omni.client.refresh_auth_token(with callback and async variants).
- HUB-696: Fixed a crash in omniClientResolveSubscribe which could happen when quickly stopping the resolve in one thread while it was still being started in another thread. 
2.29.0
- HUB-371: Relaunch Hub when the Hub client gets disconnected from the Hub server 
- HUB-654: Added - omniClientLiveRegisterQueuedCallback2which provides more information about the live update that was queued than- omniClientLiveSetQueuedCallback.
- HUB-656: Fixed a bug where a disconnection with only outstanding list requests wouldn’t trigger automatic reconnects. 
- HUB-657: Fixed a bug where the “connected” status message may not be delivered. 
2.28.1
- HUB-637: Fix potential crash in Nucleus Provider during shutdown 
2.28.0
- Add python bindings to set retry behavior - omni.client.set_retries
- OM-73093: Log an error (and don’t overwrite toml file) if parsing bookmarks fails. 
- OM-86199: Fix crash in debug builds without auth token present. 
- HUB-572: Use Hub if it is installed. This can be disabled with the environment variable “OMNICLIENT_USE_HUB=0” 
- HUB-600: Fixed stall on shutdown if the Hub was enabled. 
- HUB-603: Fixed a rare hang while loading scenes. 
- HUB-604: Resolving an absolute URL ignores search paths. Also, print resolve requests to the verbose log. 
- HUB-495: Refactor to use new Hub versioned API interfaces. 
- HUB-608: Allow using an older header with a newer binary as long as the major version matches. 
2.27.0
- HUB-470: Perform discovery & authentication asynchronously rather than blocking the tick thread. 
- HUB-470: Add automatic reconnect and retries for read-only requests. 
- OM-84043: Fixed calling stat subscribe on the root folder and an item inside the root folder in Nucleus. 
- OM-84125: Update to OpenSSL 1.1.1t 
Note: The changes below are disabled unless you are running the (currently experimental) Hub
- HUB-533: Hub configuration port no longer taken from environment variable, but read from http.port files produced by new hub version in the cache dir. 
- HUB-522: Use Hub connect/disconnect calls to maintain open file state if Hub or Client crashes 
2.26.0
- CC-1114: Convert “assert” to “CARB_ASSERT” 
- HUB-536: fix run_tests.py exception handling 
- OM-80070: Update to Nucleus connection library 1.14.6 to send websocket close codes 
Note: The changes below are disabled unless you are running the (currently experimental) Hub
- HUB-531: Hub usage now defaults to shared mode, trying to locate the latest version of shared hub in the Omniverse pkg folder 
- HUB-532: Added OMNICLIENT_HUB_CACHE_DIR. Specifying this will put OmniClient library into local Hub mode versus the default shared Hub mode. 
2.25.0
- HUB-480: Fix omniClientResolve(“omniverse://server/path”, “C:/path with spaces”); incorrectly returns a percent-encoded local path 
- HUB-494: added support for directory watches on MacOS in the file provider library. 
- HUB-499: added support for asynchronous read and write operations on Mac using Grand Central Dispatch. 
- HUB-513: reported file deletion events when a watched directory is deleted. 
- HUB-513: got all the file provider unit tests passing on MacOS. 
Note: The changes below are disabled unless you are running the (currently experimental) Hub
- HUB-519: Removed OMNICLIENT_LAUNCH_HUB 
2.24.0
- Update to Nucleus connection library v114.5 
- Include vcruntime140_1.dll in the package 
- HUB-472: disable s3 tests that require access keys by default 
- OM-77694: Fix URLs in documentation 
- HUB-500: Add “lockedBy” to list entry 
- HUB-501: Remove OMNI_HOST environment variable 
- OM-77709: Expand “Connecting to” dialog when the server name is long 
- OM-78052: Lock cache cleaner file while client library is active 
Note: The changes below are disabled unless you are running the (currently experimental) Hub
- HUB-350: Dynamically discover Hub configuration at runtime 
- HUB-366: Use Hub for read through S3 provider 
- HUB-341: Use Hub for read through http provider 
- HUB-378 Reconnection logic for Hub 
- HUB-358: Default Hub executable path to directory of the launching executable 
2.23.0
- HUB-206: Build client library for Mac 
- OM-73588: Fix trace propagation 
- OM-74155: Fixes an issue on Linux where some old XFS filesystems of ftype=0 would ignore recursive directories when moving files. 
- HUB-442: Update build tools to Visual Studio 2019 & C++17 
- OM-75253: Fix leak of connection object when auth service returns ‘token expired’ 
- HUB-453: Correctly emit ‘created’ event when a file is copied on Nucleus. 
- OM-76648: Fixed crash at shutdown in Python callback thread. 
- OM-75668: Fix omniClientGetLocalFile returning a path with a leading ‘/’ on Windows 
- OM-52351: Use configured chuck size for download also 
- HUB-469: Added omniClientBypassListCache 
- HUB-455: Add more eOmniClientConnectionStatus enums: - eOmniClientConnectionStatus_Connecting: Attempting to connect 
- eOmniClientConnectionStatus_Connected: Successfully connected 
- eOmniClientConnectionStatus_ConnectError: Connection error while trying to connect 
- eOmniClientConnectionStatus_Disconnected: Disconnected 
- eOmniClientConnectionStatus_SignedOut: omniClientSignOut called 
- eOmniClientConnectionStatus_NoUsername: No username was provided 
- eOmniClientConnectionStatus_AuthAbort: Application returned an abort code in the callback provided to omniClientRegisterAuthCallback 
- eOmniClientConnectionStatus_AuthCancelled: User clicked “Cancel” or the application called omniClientAuthenticationCancel 
- eOmniClientConnectionStatus_AuthError: Internal error while trying to authenticate 
- eOmniClientConnectionStatus_AuthFailed: Authentication failed 
- eOmniClientConnectionStatus_ServerIncompatible: The server is not compatible with this version of the client library 
 
Note: The changes below are disabled unless you are running the (currently experimental) Hub
- HUB-437: Add OMNICLIENT_USE_HUB environment variable. 
- HUB-339: Add OMNICLIENT_HUB_EXE environment variable to launch hub on demand. 
- HUB-385: Bypass Nucleus cache when Hub is enabled. 
- HUB-450: Fixed Hub cache not being filled when using extReadAsset. 
- HUB-456: Update to capnproto 0.10.3 
- HUB-400: Add retry logic when two clients access the same file at the same time. 
Unit test changes/fixes:
- HUB-440: Hub unit tests use their own local folders 
- HUB-446: Fix flaky “test_stat_deleted” test 
- HUB-376: Enable hub tests in CI/CD/CT 
2.22.0
- Adding connectivity to the OmniHub 
- OM-70781: Read aliases from omniverse.toml - also add python bindings for set_alias 
- OM-73388: Add support for “file://server/share” URLs 
- OM-23286: Fix “Cannot stat file in root” 
- OM-73588: CreateObject and LiveRead/UpdateObject omnitrace instrumentation 
- HUB-206: Added support for an initial build for Mac. 
Note: The changes below are disabled until Nucleus 115 is released
- HUB-317: Support soft-delete in the client-library - The C omniClientDelete function and the Python “delete..” functions now mark the files/folders as “deleted” instead of removing them from the Nucleus server entirely. 
- If a file has been deleted, and then a new file or file version is created at the same path by any operation, the restored file will have all the checkpoints of the previously deleted file. - To be backwards compatible, the copy/move/write commands on a deleted file will succeed even if the “ErrorIfExists” flag is set. 
 
- If a folder has been deleted, and a new file or folder is created in it, the folder will be restored. 
- All reading operations on a deleted file or folder will fail with ERROR_NOT_FOUND, unless the optional parameter include_deleted is set. - The existing list/stat functions in the C and Python API are backwards compatible - they will not list deleted files. 
- In the C API new functions omniClientStat2, omniClientStatSubscribe2, omniClientList2 and omniClientListSubscribe2 have been introduced which support listing all files, including deleted files. 
- In the Python API the existing list and stat functions have an additional optional parameter include_deleted to allow listing all files, including deleted files. 
 
- The return result of the C-API omniClientGetServerInfo and the Python get_server_info.. functions now contains a flag “undelete_enabled” to indicate if the server supports soft-delete, obliterate and undelete. 
 
- HUB-94: Added omniClientObliterate, plus matching event and list events, which allows deleting files permanently from the server. - Obliterate on a folder will fail unless the folder is empty. 
- Obliterate is only supported for the Nucleus provider. 
 
- HUB-91: Added omniClientUndelete, which allows restoring a deleted file or folder. - Undelete on a folder will restore only the folder, not its contents. 
- Undelete is only supported for the Nucleus provider. 
 
2.21.0
- Update to carbonite 134.0 
- Update omnitrace to 1.1 
- OM-66254: Fix cache bypass when accessing S3 through cloudfront 
- HUB-343: Fix exposing C++ symbols for unit tests 
- CC-733: Add “Resolve by timestamp” feature. This allows you to specify “?timestamp={unix_time_in_seconds}” to the “stat” and “read” commands and it will select the checkpoint closest to (but not later than) the specified timestamp. 
- OM-61992: Revert changes to omniClientBreakUrl. There are now 2 functions: - omniClientBreakUrlshould be used if you have either:- A URL which starts with a scheme such as “omniverse://host/path” or “http://host/path” or “file:/path” 
- A file path such as “C:/path” (windows) or “/path” (Linux) 
 
- omniClientBreakUrlReferenceshould be used if you have a URL reference such as “/path?query#fragment” which would be interpreted as a file path by- omniClientBreakUrl
 
2.20.0
- OM-52351 Use multipart_chunk_size field from Auth response to init chunk size in LFT uploads, support for override that value using OMNI_MULTIPART_CHUNK_SIZE_MB environment variable. 
- CC-763: Use new “rename2” command to support atomic checkpoints with move/rename 
- HUB-336: Fixed crash when resolving if path doesn’t have any slashes 
2.19.0
- Re-added python stub - omni.client.set_hang_detection_time_msto ease upgrading.
- Fixed a hang when waiting on a recurring request in Python. 
- HUB-332: Added connectionId to serverInfo. 
- HUB-334: Security Update zlib, libcurl, and python dependencies. 
- HUB-330: Fix omniClientNormalizeUrl(“../relative/path”); on Linux - Note that as a consequence of this change, omniClientBreakUrl will never return a “raw” file path on Windows. This matches the behavior on Linux, where it already never returned a raw file path, because it’s impossible to distinguish a raw local file path from a URL reference. - If you know that you are passing either a URL or an absolute path, you can use omniClientBreakUrlOrPath which assumes that anything which doesn’t have a scheme is a file path. - omniClientBreakUrl(“/local/file%20name#3.txt”) returns: path = “/local/file name” fragment = “3.txt” isRaw = false - omniClientBreakUrlOrPath(“/local/file%20name#3.txt”) returns: path = “/local/file%20name#3.txt” isRaw = true - But you should always prefer using “file” URLs because “file:/local/file%20name%233.txt” returns the same result when passed to either omniClientBreakUrl or omniClientBreakUrlOrPath. 
2.18.0
- HUB-322: Call python callbacks from a dedicated thread so the GIL can’t block the tick thread. 
- Removed warning when waiting in python. Also removed omni.client.set_hang_detection_time_ms 
- HUB-316: Fix resolveSubscribe when filename is percent-encoded 
- HUB-318: Update to latest python packages 
2.17.0
- CC-950: Added omniClientWriteFileEx to retrieve version & hash of newly written file 
- CC-969: Fix copying an empty folder on Nucleus 
2.16.0
- FDN-211: Distributed tracing instrumentation for open-telemetry interoperability 
- CC-920: removed an unused host dependency (“mirror”). 
- CC-920: updated the repo tools versions to the latest so that they all have Mac support. 
- CC-140: Add python bindings for resolve & resolve_subscribe 
- CC-912: makeFileUrl should prefix ‘/’ for absolute paths on Windows. 
- CC-936: Fixed crash that could happen on Windows if you stop a listSubscribe before it started. 
- CC-916: Throttled folder copies to no more than 10 at a time, to prevent using tons of memory when copying large folders. 
2.15.0
- CC-882: Fixed list subscribe with rename events 
- CC-873: Bypass cache until client-library restarts when cache failure is seen. Provide callback to notify applications of this behavior 
- CC-901: Trigger file status callbacks from the print thread to avoid Python GIL deadlocks 
- CC-903: Fixed a deadlock that could occur when calling wait from inside the create object callback 
2.14.0
- CC-819: Fix memory leak in - _allocedRequests
- CC-345: Pass callbacks by r-value instead of const reference 
- CC-812: Support “stat” on cloudfront URLs which are not configured for list 
- CC-836: Add ‘download’ parameter to omniClientGetLocalFile to retrieve the filename without downloading. 
- CC-771: Add “Listing” and “Stating” events to file status callback. Also trigger reading & writing events for omniClientGetLocalFile 
- CC-841: Remove automatic prepend of “Copied from” & “Moved from” messages 
2.13.0
- OM-57674: Update to Carbonite 128.0 
- CC-735: Added python bindings for omniClientMakePrintable and updated it to also percent-decode valid utf-8 and unreserved ascii characters (previously it would percent-encode invalid characters, but not percent-decode the valid ones). 
- CC-762: Automatically prepend message to checkpoint when copying & moving: “Copied from …” or “Moved from …” 
2.12.0
- CC-713: Update dependencies to latest versions: - Python: 3.7.13, 3.8.13, 3.9.13, 3.10.5 
- OpenSSL: 1.1.1q 
- zlib: 1.2.12 
- curl: 7.83.1 
- brotli: removed (no longer needed) 
 
- OM-54427: Add Python 3.10 builds 
- CC-749: Allow multiple connections to the same host by using the “userinfo” field of the URL 
2.11.1
- OM-55823: Update to Nucleus connection library 113.26 to resolve a crash that could happen during disconnect while downloading a file through LFT. 
2.11.0
- CC-691: increase default curl timeout to 1800, make it configurable in omniverse.toml, properly check curl error code from curl_multi handles. 
- CC-693: Fall back to old copy method when copying from a mount on older servers. 
- CC-534: Add ability to configure an S3 provider via - omniClientSetS3Configuration
- CC-124: Add ‘bookmark’ functions: - omniClientAddBookmark,- omniClientRemoveBookmark,- omniClientListBookmarks. The python bindings are- add_bookmark,- remove_bookmark, and- list_bookmarks_with_callback
- CC-732: Update to Nucleus connection library 113.25 to resolve a crash that could happen during disconnect while downloading a file through LFT. 
2.10.0
- CC-581: Fixed setting the checkpoint message when copying on the same Nucleus server 
- CC-583: Fix a case where automatic checkpoints didn’t exactly emulate atomic checkpoints. There was one case where automatic checkpoints would use the provided message for the checkpoint before and after the overwrite but atomic checkpoints use a blank message for the checkpoint prior to the overwrite. 
- CC-590: Fixed resolving UDIM URIs that have been percent encoded 
- CC-594: Always check that the logcallback function is valid before calling it. 
- CC-566: Added documentation: http://omniverse-docs.s3-website-us-east-1.amazonaws.com/client_library/ As part of this change, we have combined a number of include files. You should now only include “OmniClient.h” 
2.9.0
- CC-517: Move calling the log callback to its own thread. This moves having to acquire the GIL to call the log callback to its own thread, which can prevent deadlocks. This specifically fixes an observed deadlock with USD/usd-resolver trying to resolve several paths at once while holding the GIL. Additionaly this moves calling the log callback out of any critical paths, making the code more robust against potentially slow log callback implementations. 
- CC-493: Retry without cache when cache download fails 
- CC-553: Fixed two timing issues that could cause Stat/Resolve requests to hang. One affected Linux only and involved the initial callback, and the other affected both Windows and Linux and involved the subscription callback. 
2.8.0
- CC-491: Switch to using copy2 function in - NucleusProviderto support atomic checkpoints.
- CC-311: Map RESOURCE_BUSY error code to eOmniClientResult_ErrorLocked 
- CC-501: Add omniClientBreakUrlAbsolute & omni.client.break_url_absolute 
- OM-46177: Fix “checkpoint_version” could be stopped before it’s ever sent to the server 
- OM-49835: Speculative fix for a crash on shutdown 
- CC-504: Add - messageparameter to- omniClientCopy,- omniClientMove, and- omniClientWriteFilethat allows users to set the message field of the atomic checkpoints created by those functions.
- OM-47306: Print a warning (and a traceback) when python calls wait() and it takes longer than 20ms 
2.7.0
- OM-47514: Calling stat on a checkpoint will no longer have the “writable file” flag set 
- CC-476: Add user/group mangement python bindings 
- OM-35591: supporting atomic checkpoints 
- CC-424: Make - NucluesProviderFactory::initializeConnectionLibrary()thread safe.
- CC-482: Change shutdown warning to only print after - Core::Shutdownis complete.
- CC-436: Fix URL parsing methods to not percent-decode raw file paths 
- OM-49023: Properly handle large reads and writes in windows and linux file providers. 
2.6.0
- CC-333: Removed USD plugin (moved to OmniUsdResolver) 
- CC-397: Fixed makeRelative when there are percent-encoded urls 
- CC-406: Add Python 3.8 and 3.9 builds 
- CC-407: Fix listcache going out of date if the server sent a meta event after a deleted event 
- CC-437: Add python bindings for omniClientLiveSetQueuedCallback 
- OM-47554: Downgrade some “Error” messages during auth to “Verbose” We attempt to connect using 3 different methods, and it’s normal for 2 of them to fail. This avoids confusing users with error messages for a connection that ultimately succeeds. 
- OM-48252: Lower required “list2” version, to allow connecting to servers running Nucleus 112.0. 
- OM-28724: Retry up to 3 times when there’s an LFT error 
Notes for updating:
- If you are working with USD, you should no longer pull this omni_client_library directly anymore. 
Instead, pull the package “usd-resolver”:
  <dependency name="omni_usd_resolver" linkPath="../_build/target-deps/omni_usd_resolver">
    <package name="omni_usd_resolver.nv-20_08.py37.${platform}" version="1.0.0" />
  </dependency>
This includes a file named “deps/redist.packman.xml” that you can include in your own packman.xml to grab the exact version of USD and the client library that the resolver was built against. Note: This requires packman 6.4 or later!
  <project toolsVersion="5.0">
    <import path="../_build/target-deps/omni_usd_resolver/deps/redist.packman.xml">
    </import>
    <dependency name="usd_debug" linkPath="../_build/target-deps/usd/debug">
    </dependency>
    <dependency name="usd_release" linkPath="../_build/target-deps/usd/release">
    </dependency>
    <dependency name="omni_client_library" linkPath="../_build/target-deps/omni_client_library">
    </dependency>
  </project>
Ensure your build scripts also copy from (or refrence) the binaries in omni_usd_resolver.
NOTE: omniClientInitialize no longer registers the Omniverse USD Resolver plugin!
You must either copy the omni_usd_resolver plugin in the default USD plugin location, or register
the plugin location at application startup using PXR_NS::PlugRegistry::GetInstance().RegisterPlugins.
See the README.md in omni_usd_resolver for more information about how to set this up.
- “OmniUsdLive.h” was renamed to “OmniClientLive.h” C: All the function prefixes were changed from “omniUsdLive” to “omniClientLive” Py: All the function prefixes were changed from “omni.client.usd_live” to “omni.client.live” 
- There are no longer specific python flavors of client library. Instead, it ships with bindings for Python 3.7, 3.8, and 3.9 all in one package. In packman.xml, change “omni_client_library.py37.${platform}” to “omni_client_library.${platform}” This is only relevant if you are NOT getting this omni_client_library from the omni_usd_resolver. 
2.5.0
- CC-357: Fixed a deadlock that could occur when a python file status callback is being unregistered on one thread while another thread is simultaneously trying to call that file status callback 
- CC-367: Allow stat & list using cloudfront.net URLs 
- CC-384: Remove support for Nucleus 109 & 110 
- OM-45887: Enable extra connection logging 
- CC-366: Update OpenSSL to avoid a security vulnerability 
- CC-380: Fix SdfLayer::OpenAsAnonymous with “omniverse” URLs 
2.4.0
- OM-43249: Fixed crash that could occur when authentication result arrives after authentication was cancelled 
- OM-23151: Allow multiple authentication requests to be in flight at the same time This changes: - C: omniClientSetAuthenticationMessageBoxCallback 
- C: omniClientAuthenticationCancel 
- py: authentication_cancel 
- py: set_authentication_message_box_callback 
 
- CC-339: omniClientMakeRelative returns relative paths with ‘/’ even on Windows 
- CC-343: Files inside a mount should not have fOmniClientItem_WriteableFile 
- CC-186: Add support for moving/renaming files & folders - C: omniClientMove 
- Py: omni.client.move 
- Py: omni.client.move_async 
- Py: omni.client.move_with_callback 
 
- CC-219: Add user/group management for nucleus provider (other providers do not support user management) 
2.3.0
- CC-166: Trigger omniClientStatSubscribe callback when .live files change 
- CC-236: Add support for checkpoint change notification 
2.2.0
- CC-245: Fixed a deadlock that could occur rarely when connection failed. 
- CC-221: Upgrade OmniTrace to 0.5.8831531e for correct libstdc++ license 
- CC-32: Fixed a crash that could happen on disconnect 
- OM-43009: Removed “stop” from list of required capabilities, to discover newer servers which don’t advertise that capability 
- CC-271: Removed support for Nucleus 107 (released in Nov 2019) 
2.1.0
- CC-228: Subscription based authentication using ‘nonce’ 
- CC-231: Discover API server using minimum required capabilities rather than all capabilites 
- CC-239: Fixed an issue where log messages issued when omniclient.dll is unloading could access invalid memory. 
- OM-41660: updating the Nucleus connection library which was build with a proper toolchain (licensing fixes) 
- CC-225: Fixed a rare crash that could happen when disconnecting from a Nucleus server. 
- CC-123: Add support for deleting a checkpoint 
2.0.0
Big Live Mode Changes!
You can no longer enable live mode on any arbitrary layer. Instead, layers with the “.live” extension are considered live layers. Changes made to a live layer are replicated to other users when you call omniUsdLiveProcess (py: usd_live_process). Calling Save on a live layer does nothing.
This is not a backwards-compatible change. All clients must be using either client library version 1 or version 2 in order to do live-syncing with each other.
New (v2) clients can read & write USD files on old servers, but require a Nucleus server 111 or later in order to do live updates.
You can detect if a server supports the new live update method by calling “omniClientGetServerInfo” (py: omni.client.get_server_info) and checking the “omniObjectsEnabled” (py: omniojects_enabled) field.
Live files show up in “list” with the flags “fOmniClientItem_IsOmniObject” and “fOmniClientItem_CanLiveUpdate” (py: IS_OMNI_OBJECT | CAN_LIVE_UPDATE).
Copying a .live file from one Nucleus server to the same server or a different Nucleus server is supported, but copying it to a local drive or other provider types (http, for example) is not.
Removed the following functions:
- omniUsdLiveSetDefaultEnabled & omniUsdLiveGetDefaultEnabled 
- omniUsdLiveSetModeForUrl & omniUsdLiveGetModeForUrl 
- omniUsdLiveSetResolveMethod & omniUsdLiveGetResolveMethod 
The equivalent python bindings have also been removed:
- usd_live_set_default_enabled & usd_live_get_default_enabled 
- usd_live_set_mode_for_url & usd_live_get_mode_for_url 
Other Changes:
- CC-223: Fixed some cases where the list cache would be invalidated at the wrong time 
- CC-156: Improve Tokens Caching (cache moved to “auth.toml” and its structure changed to use auth. transport info) 
- CC-229: Fixed a case where the client library would not connect to Nucleus securely