Scoped registries allow Unity to communicate the location of any custom package registry server to the Package Manager so you can access several collections of packages at the same time.
Here are some important concepts to help you understand this feature:
Concept | 描述 |
---|---|
包注册表服务器 | An application that keeps track of packages and provides a place to store them. In Unity’s Package Manager window, all packages registered on Unity’s registry appear in the list panel when you select the Unity Registry context. |
Package Manager | An application that tells the user what packages are available, and downloads and installs whatever package the user requests for their project. Unity has implemented its own version of a package manager, but there are several similar applications in other organizations. |
范围 | Defines a package name or namespace (in reverse domain format), such as com.example.mycompany.animation or com.example . When a user requests a package, the Package Manager fetches the package from the registry that best matches the scope. For more information, refer to Managing scoped registries for a project below. |
The way you interact with scoped registries depends on your role:
As a package provider, make sure any package registry servers you set up conform to Unity’s Terms of Service and Unity’s Package Guiding Principles & Guidelines. Unity provides access to the Package Manager to facilitate sharing knowledge and creations, but not as a marketplace for third-party products.
As a package consumer, when you install a scoped registry, use the same level of caution that you use when installing any other third-party software:
Scoped registries can help to:
通过分发工具、库和其他资源来提供新的功能。
As a provider, you can create your own registry to distribute tools and scripts (or other types of assets) with version numbers that indicate how mature the package is. Version numbers also indicate whether updates introduce breaking API changes or minor fixes, based on Semantic Versioning. Your code can depend on code in other packages, because the Package Manager supports package dependencies.
As a consumer, your experience of browsing and installing third-party custom packages in the Package Manager is the same as browsing Unity’s packages.
扩展现有 Unity 包的功能。
As a consumer, you can have a seamless experience where the custom package overrides the Unity package without having to manually change registries or explicitly install a different package version. This is because you can map packages to a specific registry so that Package Manager fetches from either the Unity registry or a custom package registry server.
在封闭网络环境中访问包。
Some organizations work inside a closed network, which makes it difficult to access Unity’s package registry. In these cases, the organization can set up their own package registry on a server inside their closed network. The network administrators can then periodically synchronize with Unity’s package registry to make sure the scoped registry has the latest set of packages available.
If you’re a package consumer, refer to Managing scoped registries for a project for information about connecting to an existing custom package registry server in your Unity project. If you’re a package producer, refer to Sharing your package for information about supported package registry servers. This information also includes links to information on how to set them up to use with scoped registries.
Note: If you’re setting up a scoped registry that points to a package registry server with restricted access, you can configure Package Manager to pass your npm
authentication token to the server. For more information, refer to Scoped registry authentication.
If you’re working in a shared project, and another user adds a scoped registry to the project, Unity warns you that another user added a new scoped registry.
When you click Close, the Package Manager project settings window appears so you can add, modify, or remove scoped registries for your project.
If you click Read more, Unity opens the page you’re currently reading in your default web browser.
Tip: To access the Package Manager project settings window at any time, use the main menu in Unity (Edit > Project Settings, then the Package Manager category). You can also select Advanced Project Settings from the advanced settings menu in the Package Manager window.
To manage the scoped package registries in your project, you can either edit your project manifest file directly or use the Package Manager project settings window to let Unity change the manifest for you.
The project manifest uses a scopedRegistries property, which contains an array of scoped registry configuration objects. Each object has the following properties:
属性 | JSON 类型 | 描述 |
---|---|---|
name | String | The scope name as it appears in the user interface. The Package Manager window displays this name in the details panel. For example, "name": "Tools" . |
url | String | The URL to the npm-compatible registry server. For example, "url": "https://mycompany.example.com/tools-registry" Note: Not all registry providers are compatible with Unity’s Package Manager. Make sure the package registry server you’re trying to add implements the /-/v1/search or /-/all endpoints. |
scopes | 字符串数组 | Array of scopes that you can map to a package name, either as an exact match on the package name, or as a namespace. Wildcards and other glob patterns aren’t supported. For example, "scopes": [ "com.example", "com.example.tools.physics" ] Note: This configuration type assumes that packages follow the Reverse domain name notation. This ensures that com.unity is equivalent to any package name that matches the com.unity namespace, such as com.unity.timeline or com.unity.2d.animation .Warning: Unity doesn’t support npm’s scope notation. |
When the Package Manager decides which registry to fetch a package from, it compares the package name to the scopes values and finds the registry whose scopes value is the closest match.
例如,在以下项目清单中,有两个范围注册表(“General” 和 “Tools”):
{
"scopedRegistries": [
{
"name": "General",
"url": "https://example.com/registry",
"scopes": [
"com.example", "com.example.tools.physics"
]
},
{
"name": "Tools",
"url": "https://mycompany.example.com/tools-registry",
"scopes": [
"com.example.mycompany.tools"
]
}
],
"dependencies": {
"com.unity.animation": "1.0.0",
"com.example.mycompany.tools.animation": "1.0.0",
"com.example.tools.physics": "1.0.0",
"com.example.animation": "1.0.0"
}
}
When the Package Manager looks up the com.example.animation
package, it finds that the com.example
namespace is the closest match to its name, and fetches that package from the “General” registry.
当 Package Manager 查找com.example.tools.physics
包时,“General” 注册表具有与包名称完全匹配的范围。
When the Package Manager looks up the com.example.mycompany.tools.animation
package, the Package Manager finds that the com.example.mycompany.tools
namespace is the closest match to its name and fetches that package from the “Tools” registry. Even though it also matches the “General” scope, the com.example
namespace isn’t as close a match.
When the Package Manager looks up the com.unity.animation
package, the Package Manager doesn’t find a match in any of the scoped registries. In this case, it fetches the package from the default registry.