diff --git a/messages/zh-CN.json b/messages/zh-CN.json
index f297d1ea9..5df202a09 100644
--- a/messages/zh-CN.json
+++ b/messages/zh-CN.json
@@ -148,6 +148,11 @@
"createLink": "创建链接",
"resourcesNotFound": "找不到资源",
"resourceSearch": "搜索资源",
+ "machineSearch": "Search machines",
+ "machinesSearch": "Search machine clients...",
+ "machineNotFound": "No machines found",
+ "userDeviceSearch": "Search user devices",
+ "userDevicesSearch": "Search user devices...",
"openMenu": "打开菜单",
"resource": "资源",
"title": "标题",
@@ -323,6 +328,41 @@
"apiKeysDelete": "删除 API 密钥",
"apiKeysManage": "管理 API 密钥",
"apiKeysDescription": "API 密钥用于认证集成 API",
+ "provisioningKeysTitle": "Provisioning Key",
+ "provisioningKeysManage": "Manage Provisioning Keys",
+ "provisioningKeysDescription": "Provisioning keys are used to authenticate automated site provisioning for your organization.",
+ "provisioningKeys": "Provisioning Keys",
+ "searchProvisioningKeys": "Search provisioning keys...",
+ "provisioningKeysAdd": "Generate Provisioning Key",
+ "provisioningKeysErrorDelete": "Error deleting provisioning key",
+ "provisioningKeysErrorDeleteMessage": "Error deleting provisioning key",
+ "provisioningKeysQuestionRemove": "Are you sure you want to remove this provisioning key from the organization?",
+ "provisioningKeysMessageRemove": "Once removed, the key can no longer be used for site provisioning.",
+ "provisioningKeysDeleteConfirm": "Confirm Delete Provisioning Key",
+ "provisioningKeysDelete": "Delete Provisioning key",
+ "provisioningKeysCreate": "Generate Provisioning Key",
+ "provisioningKeysCreateDescription": "Generate a new provisioning key for the organization",
+ "provisioningKeysSeeAll": "See all provisioning keys",
+ "provisioningKeysSave": "Save the provisioning key",
+ "provisioningKeysSaveDescription": "You will only be able to see this once. Copy it to a secure place.",
+ "provisioningKeysErrorCreate": "Error creating provisioning key",
+ "provisioningKeysList": "New provisioning key",
+ "provisioningKeysMaxBatchSize": "Max batch size",
+ "provisioningKeysUnlimitedBatchSize": "Unlimited batch size (no limit)",
+ "provisioningKeysMaxBatchUnlimited": "Unlimited",
+ "provisioningKeysMaxBatchSizeInvalid": "Enter a valid max batch size (1–1,000,000).",
+ "provisioningKeysValidUntil": "Valid until",
+ "provisioningKeysValidUntilHint": "Leave empty for no expiration.",
+ "provisioningKeysValidUntilInvalid": "Enter a valid date and time.",
+ "provisioningKeysNumUsed": "Times used",
+ "provisioningKeysLastUsed": "Last used",
+ "provisioningKeysNoExpiry": "No expiration",
+ "provisioningKeysNeverUsed": "Never",
+ "provisioningKeysEdit": "Edit Provisioning Key",
+ "provisioningKeysEditDescription": "Update the max batch size and expiration time for this key.",
+ "provisioningKeysUpdateError": "Error updating provisioning key",
+ "provisioningKeysUpdated": "Provisioning key updated",
+ "provisioningKeysUpdatedDescription": "Your changes have been saved.",
"apiKeysSettings": "{apiKeyName} 设置",
"userTitle": "管理所有用户",
"userDescription": "查看和管理系统中的所有用户",
@@ -509,9 +549,12 @@
"userSaved": "用户已保存",
"userSavedDescription": "用户已更新。",
"autoProvisioned": "自动设置",
+ "autoProvisionSettings": "Auto Provision Settings",
"autoProvisionedDescription": "允许此用户由身份提供商自动管理",
"accessControlsDescription": "管理此用户在组织中可以访问和做什么",
"accessControlsSubmit": "保存访问控制",
+ "singleRolePerUserPlanNotice": "Your plan only supports one role per user.",
+ "singleRolePerUserEditionNotice": "This edition only supports one role per user.",
"roles": "角色",
"accessUsersRoles": "管理用户和角色",
"accessUsersRolesDescription": "邀请用户加入角色来管理访问组织",
@@ -887,7 +930,7 @@
"defaultMappingsRole": "默认角色映射",
"defaultMappingsRoleDescription": "此表达式的结果必须返回组织中定义的角色名称作为字符串。",
"defaultMappingsOrg": "默认组织映射",
- "defaultMappingsOrgDescription": "此表达式必须返回 组织ID 或 true 才能允许用户访问组织。",
+ "defaultMappingsOrgDescription": "When set, this expression must return the organization ID or true for the user to access that organization. When unset, defining an organization policy for that org is enough: the user is allowed in as long as a valid role mapping can be resolved for them within the organization.",
"defaultMappingsSubmit": "保存默认映射",
"orgPoliciesEdit": "编辑组织策略",
"org": "组织",
@@ -1119,6 +1162,7 @@
"setupTokenDescription": "从服务器控制台输入设置令牌。",
"setupTokenRequired": "需要设置令牌",
"actionUpdateSite": "更新站点",
+ "actionResetSiteBandwidth": "Reset Organization Bandwidth",
"actionListSiteRoles": "允许站点角色列表",
"actionCreateResource": "创建资源",
"actionDeleteResource": "删除资源",
@@ -1265,6 +1309,7 @@
"sidebarRoles": "角色",
"sidebarShareableLinks": "链接",
"sidebarApiKeys": "API密钥",
+ "sidebarProvisioning": "Provisioning",
"sidebarSettings": "设置",
"sidebarAllUsers": "所有用户",
"sidebarIdentityProviders": "身份提供商",
@@ -1890,6 +1935,40 @@
"exitNode": "出口节点",
"country": "国家",
"rulesMatchCountry": "当前基于源 IP",
+ "region": "Region",
+ "selectRegion": "Select region",
+ "searchRegions": "Search regions...",
+ "noRegionFound": "No region found.",
+ "rulesMatchRegion": "Select a regional grouping of countries",
+ "rulesErrorInvalidRegion": "Invalid region",
+ "rulesErrorInvalidRegionDescription": "Please select a valid region.",
+ "regionAfrica": "Africa",
+ "regionNorthernAfrica": "Northern Africa",
+ "regionEasternAfrica": "Eastern Africa",
+ "regionMiddleAfrica": "Middle Africa",
+ "regionSouthernAfrica": "Southern Africa",
+ "regionWesternAfrica": "Western Africa",
+ "regionAmericas": "Americas",
+ "regionCaribbean": "Caribbean",
+ "regionCentralAmerica": "Central America",
+ "regionSouthAmerica": "South America",
+ "regionNorthernAmerica": "Northern America",
+ "regionAsia": "Asia",
+ "regionCentralAsia": "Central Asia",
+ "regionEasternAsia": "Eastern Asia",
+ "regionSouthEasternAsia": "South-Eastern Asia",
+ "regionSouthernAsia": "Southern Asia",
+ "regionWesternAsia": "Western Asia",
+ "regionEurope": "Europe",
+ "regionEasternEurope": "Eastern Europe",
+ "regionNorthernEurope": "Northern Europe",
+ "regionSouthernEurope": "Southern Europe",
+ "regionWesternEurope": "Western Europe",
+ "regionOceania": "Oceania",
+ "regionAustraliaAndNewZealand": "Australia and New Zealand",
+ "regionMelanesia": "Melanesia",
+ "regionMicronesia": "Micronesia",
+ "regionPolynesia": "Polynesia",
"managedSelfHosted": {
"title": "托管自托管",
"description": "更可靠和低维护自我托管的 Pangolin 服务器,带有额外的铃声和告密器",
@@ -1938,6 +2017,25 @@
"invalidValue": "无效的值",
"idpTypeLabel": "身份提供者类型",
"roleMappingExpressionPlaceholder": "例如: contains(group, 'admin' &'Admin' || 'Member'",
+ "roleMappingModeFixedRoles": "Fixed Roles",
+ "roleMappingModeMappingBuilder": "Mapping Builder",
+ "roleMappingModeRawExpression": "Raw Expression",
+ "roleMappingFixedRolesPlaceholderSelect": "Select one or more roles",
+ "roleMappingFixedRolesPlaceholderFreeform": "Type role names (exact match per organization)",
+ "roleMappingFixedRolesDescriptionSameForAll": "Assign the same role set to every auto-provisioned user.",
+ "roleMappingFixedRolesDescriptionDefaultPolicy": "For default policies, type role names that exist in each organization where users are provisioned. Names must match exactly.",
+ "roleMappingClaimPath": "Claim Path",
+ "roleMappingClaimPathPlaceholder": "groups",
+ "roleMappingClaimPathDescription": "Path in the token payload that contains source values (for example, groups).",
+ "roleMappingMatchValue": "Match Value",
+ "roleMappingAssignRoles": "Assign Roles",
+ "roleMappingAddMappingRule": "Add Mapping Rule",
+ "roleMappingRawExpressionResultDescription": "Expression must evaluate to a string or string array.",
+ "roleMappingRawExpressionResultDescriptionSingleRole": "Expression must evaluate to a string (a single role name).",
+ "roleMappingMatchValuePlaceholder": "Match value (for example: admin)",
+ "roleMappingAssignRolesPlaceholderFreeform": "Type role names (exact per org)",
+ "roleMappingBuilderFreeformRowHint": "Role names must match a role in each target organization.",
+ "roleMappingRemoveRule": "Remove",
"idpGoogleConfiguration": "Google 配置",
"idpGoogleConfigurationDescription": "配置 Google OAuth2 凭据",
"idpGoogleClientIdDescription": "Google OAuth2 Client ID",
@@ -2334,6 +2432,8 @@
"logRetentionAccessDescription": "保留访问日志的时间",
"logRetentionActionLabel": "动作日志保留",
"logRetentionActionDescription": "保留操作日志的时间",
+ "logRetentionConnectionLabel": "Connection Log Retention",
+ "logRetentionConnectionDescription": "How long to retain connection logs",
"logRetentionDisabled": "已禁用",
"logRetention3Days": "3 天",
"logRetention7Days": "7 天",
@@ -2344,6 +2444,12 @@
"logRetentionEndOfFollowingYear": "下一年结束",
"actionLogsDescription": "查看此机构执行的操作历史",
"accessLogsDescription": "查看此机构资源的访问认证请求",
+ "connectionLogs": "Connection Logs",
+ "connectionLogsDescription": "View connection logs for tunnels in this organization",
+ "sidebarLogsConnection": "Connection Logs",
+ "sourceAddress": "Source Address",
+ "destinationAddress": "Destination Address",
+ "duration": "Duration",
"licenseRequiredToUse": "使用此功能需要企业版许可证或Pangolin Cloud。预约演示或POC试用。",
"ossEnterpriseEditionRequired": "需要 Enterprise Edition 才能使用此功能。 此功能也可在 Pangolin Cloud上获取。 预订演示或POC 试用。",
"certResolver": "证书解决器",
@@ -2683,5 +2789,6 @@
"approvalsEmptyStateStep2Description": "编辑角色并启用“需要设备审批”选项。具有此角色的用户需要管理员批准新设备。",
"approvalsEmptyStatePreviewDescription": "预览:如果启用,待处理设备请求将出现在这里供审核",
"approvalsEmptyStateButtonText": "管理角色",
- "domainErrorTitle": "我们在验证您的域名时遇到了问题"
+ "domainErrorTitle": "我们在验证您的域名时遇到了问题",
+ "idpAdminAutoProvisionPoliciesTabHint": "Configure role mapping and organization policies on the Auto Provision Settings tab."
}