Merge branch 'dev' into web/config-provider
* dev: blueprints: improve file change handler (#7813) web/user: fix search not updating app (#7825) web: bump the storybook group in /web with 5 updates (#7819) core: compile backend translations (#7827) translate: Updates for file locale/en/LC_MESSAGES/django.po in de (#7812) core: bump github.com/go-openapi/strfmt from 0.21.8 to 0.21.9 (#7814) ci: bump actions/stale from 8 to 9 (#7815) web: bump the wdio group in /tests/wdio with 1 update (#7816) translate: Updates for file web/xliff/en.xlf in zh_CN (#7820) web: bump the sentry group in /web with 2 updates (#7817) web: bump vite-tsconfig-paths from 4.2.1 to 4.2.2 in /web (#7818) translate: Updates for file web/xliff/en.xlf in zh-Hans (#7821) translate: Updates for file locale/en/LC_MESSAGES/django.po in zh-Hans (#7822) translate: Updates for file locale/en/LC_MESSAGES/django.po in zh_CN (#7823) web: bump typescript from 5.3.2 to 5.3.3 in /web (#7806) website: bump typescript from 5.3.2 to 5.3.3 in /website (#7807) web: bump typescript from 5.3.2 to 5.3.3 in /tests/wdio (#7808) core: bump goauthentik.io/api/v3 from 3.2023104.1 to 3.2023104.2 (#7809) ci: bump actions/setup-go from 4 to 5
This commit is contained in:
		
							
								
								
									
										6
									
								
								.github/workflows/ci-outpost.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/ci-outpost.yml
									
									
									
									
										vendored
									
									
								
							| @ -16,7 +16,7 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/setup-go@v4 | ||||
|       - uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version-file: "go.mod" | ||||
|       - name: Prepare and generate API | ||||
| @ -37,7 +37,7 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/setup-go@v4 | ||||
|       - uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version-file: "go.mod" | ||||
|       - name: Setup authentik env | ||||
| @ -125,7 +125,7 @@ jobs: | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           ref: ${{ github.event.pull_request.head.sha }} | ||||
|       - uses: actions/setup-go@v4 | ||||
|       - uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version-file: "go.mod" | ||||
|       - uses: actions/setup-node@v4 | ||||
|  | ||||
							
								
								
									
										4
									
								
								.github/workflows/release-publish.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/release-publish.yml
									
									
									
									
										vendored
									
									
								
							| @ -67,7 +67,7 @@ jobs: | ||||
|           - radius | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/setup-go@v4 | ||||
|       - uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version-file: "go.mod" | ||||
|       - name: Set up QEMU | ||||
| @ -126,7 +126,7 @@ jobs: | ||||
|         goarch: [amd64, arm64] | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/setup-go@v4 | ||||
|       - uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version-file: "go.mod" | ||||
|       - uses: actions/setup-node@v4 | ||||
|  | ||||
							
								
								
									
										2
									
								
								.github/workflows/repo-stale.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/repo-stale.yml
									
									
									
									
										vendored
									
									
								
							| @ -18,7 +18,7 @@ jobs: | ||||
|         with: | ||||
|           app_id: ${{ secrets.GH_APP_ID }} | ||||
|           private_key: ${{ secrets.GH_APP_PRIVATE_KEY }} | ||||
|       - uses: actions/stale@v8 | ||||
|       - uses: actions/stale@v9 | ||||
|         with: | ||||
|           repo-token: ${{ steps.generate_token.outputs.token }} | ||||
|           days-before-stale: 60 | ||||
|  | ||||
| @ -75,13 +75,13 @@ class BlueprintEventHandler(FileSystemEventHandler): | ||||
|             return | ||||
|         if event.is_directory: | ||||
|             return | ||||
|         if isinstance(event, FileCreatedEvent): | ||||
|             LOGGER.debug("new blueprint file created, starting discovery") | ||||
|             blueprints_discovery.delay() | ||||
|         if isinstance(event, FileModifiedEvent): | ||||
|             path = Path(event.src_path) | ||||
|         root = Path(CONFIG.get("blueprints_dir")).absolute() | ||||
|         path = Path(event.src_path).absolute() | ||||
|         rel_path = str(path.relative_to(root)) | ||||
|         if isinstance(event, FileCreatedEvent): | ||||
|             LOGGER.debug("new blueprint file created, starting discovery", path=rel_path) | ||||
|             blueprints_discovery.delay(rel_path) | ||||
|         if isinstance(event, FileModifiedEvent): | ||||
|             for instance in BlueprintInstance.objects.filter(path=rel_path, enabled=True): | ||||
|                 LOGGER.debug("modified blueprint file, starting apply", instance=instance) | ||||
|                 apply_blueprint.delay(instance.pk.hex) | ||||
| @ -98,39 +98,32 @@ def blueprints_find_dict(): | ||||
|     return blueprints | ||||
|  | ||||
|  | ||||
| def blueprints_find(): | ||||
| def blueprints_find() -> list[BlueprintFile]: | ||||
|     """Find blueprints and return valid ones""" | ||||
|     blueprints = [] | ||||
|     root = Path(CONFIG.get("blueprints_dir")) | ||||
|     for path in root.rglob("**/*.yaml"): | ||||
|         rel_path = path.relative_to(root) | ||||
|         # Check if any part in the path starts with a dot and assume a hidden file | ||||
|         if any(part for part in path.parts if part.startswith(".")): | ||||
|             continue | ||||
|         LOGGER.debug("found blueprint", path=str(path)) | ||||
|         with open(path, "r", encoding="utf-8") as blueprint_file: | ||||
|             try: | ||||
|                 raw_blueprint = load(blueprint_file.read(), BlueprintLoader) | ||||
|             except YAMLError as exc: | ||||
|                 raw_blueprint = None | ||||
|                 LOGGER.warning("failed to parse blueprint", exc=exc, path=str(path)) | ||||
|                 LOGGER.warning("failed to parse blueprint", exc=exc, path=str(rel_path)) | ||||
|             if not raw_blueprint: | ||||
|                 continue | ||||
|             metadata = raw_blueprint.get("metadata", None) | ||||
|             version = raw_blueprint.get("version", 1) | ||||
|             if version != 1: | ||||
|                 LOGGER.warning("invalid blueprint version", version=version, path=str(path)) | ||||
|                 LOGGER.warning("invalid blueprint version", version=version, path=str(rel_path)) | ||||
|                 continue | ||||
|         file_hash = sha512(path.read_bytes()).hexdigest() | ||||
|         blueprint = BlueprintFile( | ||||
|             str(path.relative_to(root)), version, file_hash, int(path.stat().st_mtime) | ||||
|         ) | ||||
|         blueprint = BlueprintFile(str(rel_path), version, file_hash, int(path.stat().st_mtime)) | ||||
|         blueprint.meta = from_dict(BlueprintMetadata, metadata) if metadata else None | ||||
|         blueprints.append(blueprint) | ||||
|         LOGGER.debug( | ||||
|             "parsed & loaded blueprint", | ||||
|             hash=file_hash, | ||||
|             path=str(path), | ||||
|         ) | ||||
|     return blueprints | ||||
|  | ||||
|  | ||||
| @ -138,10 +131,12 @@ def blueprints_find(): | ||||
|     throws=(DatabaseError, ProgrammingError, InternalError), base=MonitoredTask, bind=True | ||||
| ) | ||||
| @prefill_task | ||||
| def blueprints_discovery(self: MonitoredTask): | ||||
| def blueprints_discovery(self: MonitoredTask, path: Optional[str] = None): | ||||
|     """Find blueprints and check if they need to be created in the database""" | ||||
|     count = 0 | ||||
|     for blueprint in blueprints_find(): | ||||
|         if path and blueprint.path != path: | ||||
|             continue | ||||
|         check_blueprint_v1_file(blueprint) | ||||
|         count += 1 | ||||
|     self.set_status( | ||||
| @ -171,7 +166,11 @@ def check_blueprint_v1_file(blueprint: BlueprintFile): | ||||
|             metadata={}, | ||||
|         ) | ||||
|         instance.save() | ||||
|         LOGGER.info( | ||||
|             "Creating new blueprint instance from file", instance=instance, path=instance.path | ||||
|         ) | ||||
|     if instance.last_applied_hash != blueprint.hash: | ||||
|         LOGGER.info("Applying blueprint due to changed file", instance=instance, path=instance.path) | ||||
|         apply_blueprint.delay(str(instance.pk)) | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										8
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								go.mod
									
									
									
									
									
								
							| @ -10,7 +10,7 @@ require ( | ||||
| 	github.com/go-http-utils/etag v0.0.0-20161124023236-513ea8f21eb1 | ||||
| 	github.com/go-ldap/ldap/v3 v3.4.6 | ||||
| 	github.com/go-openapi/runtime v0.26.0 | ||||
| 	github.com/go-openapi/strfmt v0.21.8 | ||||
| 	github.com/go-openapi/strfmt v0.21.9 | ||||
| 	github.com/golang-jwt/jwt v3.2.2+incompatible | ||||
| 	github.com/google/uuid v1.4.0 | ||||
| 	github.com/gorilla/handlers v1.5.2 | ||||
| @ -27,7 +27,7 @@ require ( | ||||
| 	github.com/sirupsen/logrus v1.9.3 | ||||
| 	github.com/spf13/cobra v1.8.0 | ||||
| 	github.com/stretchr/testify v1.8.4 | ||||
| 	goauthentik.io/api/v3 v3.2023104.1 | ||||
| 	goauthentik.io/api/v3 v3.2023104.2 | ||||
| 	golang.org/x/exp v0.0.0-20230210204819-062eb4c674ab | ||||
| 	golang.org/x/oauth2 v0.15.0 | ||||
| 	golang.org/x/sync v0.5.0 | ||||
| @ -49,7 +49,7 @@ require ( | ||||
| 	github.com/go-logr/logr v1.2.3 // indirect | ||||
| 	github.com/go-logr/stdr v1.2.2 // indirect | ||||
| 	github.com/go-openapi/analysis v0.21.4 // indirect | ||||
| 	github.com/go-openapi/errors v0.20.3 // indirect | ||||
| 	github.com/go-openapi/errors v0.20.4 // indirect | ||||
| 	github.com/go-openapi/jsonpointer v0.19.5 // indirect | ||||
| 	github.com/go-openapi/jsonreference v0.20.0 // indirect | ||||
| 	github.com/go-openapi/loads v0.21.2 // indirect | ||||
| @ -69,7 +69,7 @@ require ( | ||||
| 	github.com/prometheus/common v0.44.0 // indirect | ||||
| 	github.com/prometheus/procfs v0.11.1 // indirect | ||||
| 	github.com/spf13/pflag v1.0.5 // indirect | ||||
| 	go.mongodb.org/mongo-driver v1.11.3 // indirect | ||||
| 	go.mongodb.org/mongo-driver v1.13.0 // indirect | ||||
| 	go.opentelemetry.io/otel v1.14.0 // indirect | ||||
| 	go.opentelemetry.io/otel/trace v1.14.0 // indirect | ||||
| 	golang.org/x/crypto v0.16.0 // indirect | ||||
|  | ||||
							
								
								
									
										20
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								go.sum
									
									
									
									
									
								
							| @ -103,8 +103,8 @@ github.com/go-openapi/analysis v0.21.4/go.mod h1:4zQ35W4neeZTqh3ol0rv/O8JBbka9Qy | ||||
| github.com/go-openapi/errors v0.19.8/go.mod h1:cM//ZKUKyO06HSwqAelJ5NsEMMcpa6VpXe8DOa1Mi1M= | ||||
| github.com/go-openapi/errors v0.19.9/go.mod h1:cM//ZKUKyO06HSwqAelJ5NsEMMcpa6VpXe8DOa1Mi1M= | ||||
| github.com/go-openapi/errors v0.20.2/go.mod h1:cM//ZKUKyO06HSwqAelJ5NsEMMcpa6VpXe8DOa1Mi1M= | ||||
| github.com/go-openapi/errors v0.20.3 h1:rz6kiC84sqNQoqrtulzaL/VERgkoCyB6WdEkc2ujzUc= | ||||
| github.com/go-openapi/errors v0.20.3/go.mod h1:Z3FlZ4I8jEGxjUK+bugx3on2mIAk4txuAOhlsB1FSgk= | ||||
| github.com/go-openapi/errors v0.20.4 h1:unTcVm6PispJsMECE3zWgvG4xTiKda1LIR5rCRWLG6M= | ||||
| github.com/go-openapi/errors v0.20.4/go.mod h1:Z3FlZ4I8jEGxjUK+bugx3on2mIAk4txuAOhlsB1FSgk= | ||||
| github.com/go-openapi/jsonpointer v0.19.3/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg= | ||||
| github.com/go-openapi/jsonpointer v0.19.5 h1:gZr+CIYByUqjcgeLXnQu2gHYQC9o73G2XUeOFYEICuY= | ||||
| github.com/go-openapi/jsonpointer v0.19.5/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg= | ||||
| @ -123,8 +123,8 @@ github.com/go-openapi/spec v0.20.8/go.mod h1:2OpW+JddWPrpXSCIX8eOx7lZ5iyuWj3RYR6 | ||||
| github.com/go-openapi/strfmt v0.21.0/go.mod h1:ZRQ409bWMj+SOgXofQAGTIo2Ebu72Gs+WaRADcS5iNg= | ||||
| github.com/go-openapi/strfmt v0.21.1/go.mod h1:I/XVKeLc5+MM5oPNN7P6urMOpuLXEcNrCX/rPGuWb0k= | ||||
| github.com/go-openapi/strfmt v0.21.3/go.mod h1:k+RzNO0Da+k3FrrynSNN8F7n/peCmQQqbbXjtDfvmGg= | ||||
| github.com/go-openapi/strfmt v0.21.8 h1:VYBUoKYRLAlgKDrIxR/I0lKrztDQ0tuTDrbhLVP8Erg= | ||||
| github.com/go-openapi/strfmt v0.21.8/go.mod h1:adeGTkxE44sPyLk0JV235VQAO/ZXUr8KAzYjclFs3ew= | ||||
| github.com/go-openapi/strfmt v0.21.9 h1:LnEGOO9qyEC1v22Bzr323M98G13paIUGPU7yeJtG9Xs= | ||||
| github.com/go-openapi/strfmt v0.21.9/go.mod h1:0k3v301mglEaZRJdDDGSlN6Npq4VMVU69DE0LUyf7uA= | ||||
| github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= | ||||
| github.com/go-openapi/swag v0.19.15/go.mod h1:QYRuS/SOXUCsnplDa677K7+DxSOj6IPNl/eQntq43wQ= | ||||
| github.com/go-openapi/swag v0.21.1/go.mod h1:QYRuS/SOXUCsnplDa677K7+DxSOj6IPNl/eQntq43wQ= | ||||
| @ -328,13 +328,14 @@ github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/ | ||||
| github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= | ||||
| github.com/stretchr/testify v1.8.4 h1:CcVxjf3Q8PM0mHUKJCdn+eZZtm5yQwehR5yeSVQQcUk= | ||||
| github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo= | ||||
| github.com/tidwall/pretty v1.0.0 h1:HsD+QiTn7sK6flMKIvNmpqz1qrpP3Ps6jOKIKMooyg4= | ||||
| github.com/tidwall/pretty v1.0.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk= | ||||
| github.com/xdg-go/pbkdf2 v1.0.0/go.mod h1:jrpuAogTd400dnrH08LKmI/xc1MbPOebTwRqcT5RDeI= | ||||
| github.com/xdg-go/scram v1.0.2/go.mod h1:1WAq6h33pAW+iRreB34OORO2Nf7qel3VV3fjBj+hCSs= | ||||
| github.com/xdg-go/scram v1.1.1/go.mod h1:RaEWvsqvNKKvBPvcKeFjrG2cJqOkHTiyTpzz23ni57g= | ||||
| github.com/xdg-go/scram v1.1.2/go.mod h1:RT/sEzTbU5y00aCK8UOx6R7YryM0iF1N2MOmC3kKLN4= | ||||
| github.com/xdg-go/stringprep v1.0.2/go.mod h1:8F9zXuvzgwmyT5DUm4GUfZGDdT3W+LCvS6+da4O5kxM= | ||||
| github.com/xdg-go/stringprep v1.0.3/go.mod h1:W3f5j4i+9rC0kuIEJL0ky1VpHXQU3ocBgklLGvcBnW8= | ||||
| github.com/xdg-go/stringprep v1.0.4/go.mod h1:mPGuuIYwz7CmR2bT9j4GbQqutWS1zV24gijq1dTyGkM= | ||||
| github.com/youmark/pkcs8 v0.0.0-20181117223130-1be2e3e5546d/go.mod h1:rHwXgn7JulP+udvsHwJoVG1YGAP6VLg4y9I5dyZdqmA= | ||||
| github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= | ||||
| github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= | ||||
| @ -343,8 +344,8 @@ github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5t | ||||
| go.mongodb.org/mongo-driver v1.7.3/go.mod h1:NqaYOwnXWr5Pm7AOpO5QFxKJ503nbMse/R79oO62zWg= | ||||
| go.mongodb.org/mongo-driver v1.7.5/go.mod h1:VXEWRZ6URJIkUq2SCAyapmhH0ZLRBP+FT4xhp5Zvxng= | ||||
| go.mongodb.org/mongo-driver v1.10.0/go.mod h1:wsihk0Kdgv8Kqu1Anit4sfK+22vSFbUrAVEYRhCXrA8= | ||||
| go.mongodb.org/mongo-driver v1.11.3 h1:Ql6K6qYHEzB6xvu4+AU0BoRoqf9vFPcc4o7MUIdPW8Y= | ||||
| go.mongodb.org/mongo-driver v1.11.3/go.mod h1:PTSz5yu21bkT/wXpkS7WR5f0ddqw5quethTUn9WM+2g= | ||||
| go.mongodb.org/mongo-driver v1.13.0 h1:67DgFFjYOCMWdtTEmKFpV3ffWlFnh+CYZ8ZS/tXWUfY= | ||||
| go.mongodb.org/mongo-driver v1.13.0/go.mod h1:/rGBTebI3XYboVmgz+Wv3Bcbl3aD0QF9zl6kDDw18rQ= | ||||
| go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU= | ||||
| go.opencensus.io v0.22.0/go.mod h1:+kGneAE2xo2IficOXnaByMWTGM9T73dGwxeWcUqIpI8= | ||||
| go.opencensus.io v0.22.2/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= | ||||
| @ -358,8 +359,8 @@ go.opentelemetry.io/otel/trace v1.14.0 h1:wp2Mmvj41tDsyAJXiWDWpfNsOiIyd38fy85pyK | ||||
| go.opentelemetry.io/otel/trace v1.14.0/go.mod h1:8avnQLK+CG77yNLUae4ea2JDQ6iT+gozhnZjy/rw9G8= | ||||
| go.uber.org/goleak v1.2.1 h1:NBol2c7O1ZokfZ0LEU9K6Whx/KnwvepVetCUhtKja4A= | ||||
| go.uber.org/goleak v1.2.1/go.mod h1:qlT2yGI9QafXHhZZLxlSuNsMw3FFLxBr+tBRlmO1xH4= | ||||
| goauthentik.io/api/v3 v3.2023104.1 h1:cvAsgoKP/fmO4fzifx0OyICknauFeyN88C4Z1LdWXDs= | ||||
| goauthentik.io/api/v3 v3.2023104.1/go.mod h1:zz+mEZg8rY/7eEjkMGWJ2DnGqk+zqxuybGCGrR2O4Kw= | ||||
| goauthentik.io/api/v3 v3.2023104.2 h1:TV3SdaPGhjVE7If0l1kt+H23xwgEabWUFgX4ijkkeSc= | ||||
| goauthentik.io/api/v3 v3.2023104.2/go.mod h1:zz+mEZg8rY/7eEjkMGWJ2DnGqk+zqxuybGCGrR2O4Kw= | ||||
| golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= | ||||
| golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | ||||
| golang.org/x/crypto v0.0.0-20190422162423-af44ce270edf/go.mod h1:WFFai1msRO1wXaEeE5yQxYXgSfI8pQAWXbQop6sCtWE= | ||||
| @ -519,6 +520,7 @@ golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | ||||
| golang.org/x/text v0.3.5/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | ||||
| golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | ||||
| golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= | ||||
| golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ= | ||||
| golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= | ||||
| golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8= | ||||
| golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= | ||||
|  | ||||
										
											Binary file not shown.
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										16
									
								
								tests/wdio/package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										16
									
								
								tests/wdio/package-lock.json
									
									
									
										generated
									
									
									
								
							| @ -9,7 +9,7 @@ | ||||
|                 "@trivago/prettier-plugin-sort-imports": "^4.3.0", | ||||
|                 "@typescript-eslint/eslint-plugin": "^6.13.2", | ||||
|                 "@typescript-eslint/parser": "^6.13.2", | ||||
|                 "@wdio/cli": "^8.24.13", | ||||
|                 "@wdio/cli": "^8.24.16", | ||||
|                 "@wdio/local-runner": "^8.24.12", | ||||
|                 "@wdio/mocha-framework": "^8.24.12", | ||||
|                 "@wdio/spec-reporter": "^8.24.12", | ||||
| @ -19,7 +19,7 @@ | ||||
|                 "npm-run-all": "^4.1.5", | ||||
|                 "prettier": "^3.1.0", | ||||
|                 "ts-node": "^10.9.1", | ||||
|                 "typescript": "^5.3.2", | ||||
|                 "typescript": "^5.3.3", | ||||
|                 "wdio-wait-for": "^3.0.9" | ||||
|             }, | ||||
|             "engines": { | ||||
| @ -1141,9 +1141,9 @@ | ||||
|             "dev": true | ||||
|         }, | ||||
|         "node_modules/@wdio/cli": { | ||||
|             "version": "8.24.13", | ||||
|             "resolved": "https://registry.npmjs.org/@wdio/cli/-/cli-8.24.13.tgz", | ||||
|             "integrity": "sha512-UG4dvnT6KfnKDsNVn/GeUidi21Pso6N6eu1O5oin9+fP612zpPFrx3/TuYrAfjJb+qmy1QkKq3zX99y+xlp7og==", | ||||
|             "version": "8.24.16", | ||||
|             "resolved": "https://registry.npmjs.org/@wdio/cli/-/cli-8.24.16.tgz", | ||||
|             "integrity": "sha512-DaXSdkWMlI0pPiTWMJRP5kBGpBrzEJfPdF1VqIw+HBC9vn4OWyZWAOlA3TZ1uKifTJQ3ydaXpclbDW0/x31YhQ==", | ||||
|             "dev": true, | ||||
|             "dependencies": { | ||||
|                 "@types/node": "^20.1.1", | ||||
| @ -8197,9 +8197,9 @@ | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/typescript": { | ||||
|             "version": "5.3.2", | ||||
|             "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.2.tgz", | ||||
|             "integrity": "sha512-6l+RyNy7oAHDfxC4FzSJcz9vnjTKxrLpDG5M2Vu4SHRVNg6xzqZp6LYSR9zjqQTu8DU/f5xwxUdADOkbrIX2gQ==", | ||||
|             "version": "5.3.3", | ||||
|             "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz", | ||||
|             "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==", | ||||
|             "dev": true, | ||||
|             "bin": { | ||||
|                 "tsc": "bin/tsc", | ||||
|  | ||||
| @ -6,7 +6,7 @@ | ||||
|         "@trivago/prettier-plugin-sort-imports": "^4.3.0", | ||||
|         "@typescript-eslint/eslint-plugin": "^6.13.2", | ||||
|         "@typescript-eslint/parser": "^6.13.2", | ||||
|         "@wdio/cli": "^8.24.13", | ||||
|         "@wdio/cli": "^8.24.16", | ||||
|         "@wdio/local-runner": "^8.24.12", | ||||
|         "@wdio/mocha-framework": "^8.24.12", | ||||
|         "@wdio/spec-reporter": "^8.24.12", | ||||
| @ -16,7 +16,7 @@ | ||||
|         "npm-run-all": "^4.1.5", | ||||
|         "prettier": "^3.1.0", | ||||
|         "ts-node": "^10.9.1", | ||||
|         "typescript": "^5.3.2", | ||||
|         "typescript": "^5.3.3", | ||||
|         "wdio-wait-for": "^3.0.9" | ||||
|     }, | ||||
|     "scripts": { | ||||
|  | ||||
							
								
								
									
										3954
									
								
								web/package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										3954
									
								
								web/package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -45,8 +45,8 @@ | ||||
|         "@open-wc/lit-helpers": "^0.6.0", | ||||
|         "@patternfly/elements": "^2.4.0", | ||||
|         "@patternfly/patternfly": "^4.224.2", | ||||
|         "@sentry/browser": "^7.85.0", | ||||
|         "@sentry/tracing": "^7.85.0", | ||||
|         "@sentry/browser": "^7.86.0", | ||||
|         "@sentry/tracing": "^7.86.0", | ||||
|         "@webcomponents/webcomponentsjs": "^2.8.0", | ||||
|         "base64-js": "^1.5.1", | ||||
|         "chart.js": "^4.4.1", | ||||
| @ -82,11 +82,13 @@ | ||||
|         "@rollup/plugin-replace": "^5.0.5", | ||||
|         "@rollup/plugin-terser": "^0.4.4", | ||||
|         "@rollup/plugin-typescript": "^11.1.5", | ||||
|         "@storybook/addon-essentials": "^7.5.3", | ||||
|         "@storybook/addon-links": "^7.5.3", | ||||
|         "@storybook/blocks": "^7.1.1", | ||||
|         "@storybook/web-components": "^7.5.3", | ||||
|         "@storybook/web-components-vite": "^7.5.3", | ||||
|         "@storybook/addon-essentials": "^7.6.4", | ||||
|         "@storybook/addon-links": "^7.6.4", | ||||
|         "@storybook/api": "^7.6.4", | ||||
|         "@storybook/blocks": "^7.6.4", | ||||
|         "@storybook/manager-api": "^7.6.4", | ||||
|         "@storybook/web-components-vite": "^7.6.4", | ||||
|         "@storybook/web-components": "^7.6.4", | ||||
|         "@trivago/prettier-plugin-sort-imports": "^4.3.0", | ||||
|         "@types/chart.js": "^2.9.41", | ||||
|         "@types/codemirror": "5.60.15", | ||||
| @ -113,13 +115,13 @@ | ||||
|         "rollup-plugin-copy": "^3.5.0", | ||||
|         "rollup-plugin-cssimport": "^1.0.3", | ||||
|         "rollup-plugin-postcss-lit": "^2.1.0", | ||||
|         "storybook": "^7.5.3", | ||||
|         "storybook": "^7.6.4", | ||||
|         "storybook-addon-mock": "^4.3.0", | ||||
|         "ts-lit-plugin": "^2.0.1", | ||||
|         "tslib": "^2.6.2", | ||||
|         "turnstile-types": "^1.1.3", | ||||
|         "typescript": "^5.3.2", | ||||
|         "vite-tsconfig-paths": "^4.2.1" | ||||
|         "typescript": "^5.3.3", | ||||
|         "vite-tsconfig-paths": "^4.2.2" | ||||
|     }, | ||||
|     "optionalDependencies": { | ||||
|         "@esbuild/darwin-arm64": "^0.19.8", | ||||
|  | ||||
| @ -96,7 +96,7 @@ export class LibraryApplication extends AKElement { | ||||
|             this.application.metaPublisher !== "" || | ||||
|             this.application.metaDescription !== ""; | ||||
|  | ||||
|         const classes = { "pf-m-selectable pf-m-selected": this.selected }; | ||||
|         const classes = { "pf-m-selectable": this.selected, "pf-m-selected": this.selected }; | ||||
|         const styles = this.background ? { background: this.background } : {}; | ||||
|  | ||||
|         return html` <div | ||||
|  | ||||
| @ -38,7 +38,9 @@ export class LibraryPageApplicationList extends AKElement { | ||||
|     ]; | ||||
|  | ||||
|     @property({ attribute: false }) | ||||
|     apps: Application[] = []; | ||||
|     set apps(value: Application[]) { | ||||
|         this.fuse.setCollection(value); | ||||
|     } | ||||
|  | ||||
|     @property() | ||||
|     query = getURLParam<string | undefined>("search", undefined); | ||||
| @ -63,7 +65,7 @@ export class LibraryPageApplicationList extends AKElement { | ||||
|             shouldSort: true, | ||||
|             ignoreFieldNorm: true, | ||||
|             useExtendedSearch: true, | ||||
|             threshold: 0.5, | ||||
|             threshold: 0.3, | ||||
|         }); | ||||
|     } | ||||
|  | ||||
| @ -77,7 +79,6 @@ export class LibraryPageApplicationList extends AKElement { | ||||
|  | ||||
|     connectedCallback() { | ||||
|         super.connectedCallback(); | ||||
|         this.fuse.setCollection(this.apps); | ||||
|         if (!this.query) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| <?xml version="1.0"?><xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" version="1.2"> | ||||
| <?xml version="1.0" ?><xliff xmlns="urn:oasis:names:tc:xliff:document:1.2" version="1.2"> | ||||
|   <file target-language="zh-Hans" source-language="en" original="lit-localize-inputs" datatype="plaintext"> | ||||
|     <body> | ||||
|       <trans-unit id="s4caed5b7a7e5d89b"> | ||||
| @ -613,9 +613,9 @@ | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="saa0e2675da69651b"> | ||||
|         <source>The URL "<x id="0" equiv-text="${this.url}"/>" was not found.</source> | ||||
|         <target>未找到 URL "  | ||||
|         <x id="0" equiv-text="${this.url}"/>"。</target> | ||||
|         <source>The URL "<x id="0" equiv-text="${this.url}"/>" was not found.</source> | ||||
|         <target>未找到 URL "  | ||||
|         <x id="0" equiv-text="${this.url}"/>"。</target> | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s58cd9c2fe836d9c6"> | ||||
| @ -1057,8 +1057,8 @@ | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="sa8384c9c26731f83"> | ||||
|         <source>To allow any redirect URI, set this value to ".*". Be aware of the possible security implications this can have.</source> | ||||
|         <target>要允许任何重定向 URI,请将此值设置为 ".*"。请注意这可能带来的安全影响。</target> | ||||
|         <source>To allow any redirect URI, set this value to ".*". Be aware of the possible security implications this can have.</source> | ||||
|         <target>要允许任何重定向 URI,请将此值设置为 ".*"。请注意这可能带来的安全影响。</target> | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s55787f4dfcdce52b"> | ||||
| @ -1799,8 +1799,8 @@ | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="sa90b7809586c35ce"> | ||||
|         <source>Either input a full URL, a relative path, or use 'fa://fa-test' to use the Font Awesome icon "fa-test".</source> | ||||
|         <target>输入完整 URL、相对路径,或者使用 'fa://fa-test' 来使用 Font Awesome 图标 "fa-test"。</target> | ||||
|         <source>Either input a full URL, a relative path, or use 'fa://fa-test' to use the Font Awesome icon "fa-test".</source> | ||||
|         <target>输入完整 URL、相对路径,或者使用 'fa://fa-test' 来使用 Font Awesome 图标 "fa-test"。</target> | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s0410779cb47de312"> | ||||
| @ -2988,8 +2988,8 @@ doesn't pass when either or both of the selected options are equal or above the | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s76768bebabb7d543"> | ||||
|         <source>Field which contains members of a group. Note that if using the "memberUid" field, the value is assumed to contain a relative distinguished name. e.g. 'memberUid=some-user' instead of 'memberUid=cn=some-user,ou=groups,...'</source> | ||||
|         <target>包含组成员的字段。请注意,如果使用 "memberUid" 字段,则假定该值包含相对可分辨名称。例如,'memberUid=some-user' 而不是 'memberUid=cn=some-user,ou=groups,...'</target> | ||||
|         <source>Field which contains members of a group. Note that if using the "memberUid" field, the value is assumed to contain a relative distinguished name. e.g. 'memberUid=some-user' instead of 'memberUid=cn=some-user,ou=groups,...'</source> | ||||
|         <target>包含组成员的字段。请注意,如果使用 "memberUid" 字段,则假定该值包含相对可分辨名称。例如,'memberUid=some-user' 而不是 'memberUid=cn=some-user,ou=groups,...'</target> | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s026555347e589f0e"> | ||||
| @ -3781,8 +3781,8 @@ doesn't pass when either or both of the selected options are equal or above the | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s7b1fba26d245cb1c"> | ||||
|         <source>When using an external logging solution for archiving, this can be set to "minutes=5".</source> | ||||
|         <target>使用外部日志记录解决方案进行存档时,可以将其设置为 "minutes=5"。</target> | ||||
|         <source>When using an external logging solution for archiving, this can be set to "minutes=5".</source> | ||||
|         <target>使用外部日志记录解决方案进行存档时,可以将其设置为 "minutes=5"。</target> | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s44536d20bb5c8257"> | ||||
| @ -3791,8 +3791,8 @@ doesn't pass when either or both of the selected options are equal or above the | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s3bb51cabb02b997e"> | ||||
|         <source>Format: "weeks=3;days=2;hours=3,seconds=2".</source> | ||||
|         <target>格式:"weeks=3;days=2;hours=3,seconds=2"。</target> | ||||
|         <source>Format: "weeks=3;days=2;hours=3,seconds=2".</source> | ||||
|         <target>格式:"weeks=3;days=2;hours=3,seconds=2"。</target> | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s04bfd02201db5ab8"> | ||||
| @ -3988,10 +3988,10 @@ doesn't pass when either or both of the selected options are equal or above the | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="sa95a538bfbb86111"> | ||||
|         <source>Are you sure you want to update <x id="0" equiv-text="${this.objectLabel}"/> "<x id="1" equiv-text="${this.obj?.name}"/>"?</source> | ||||
|         <source>Are you sure you want to update <x id="0" equiv-text="${this.objectLabel}"/> "<x id="1" equiv-text="${this.obj?.name}"/>"?</source> | ||||
|         <target>您确定要更新  | ||||
|         <x id="0" equiv-text="${this.objectLabel}"/>"  | ||||
|         <x id="1" equiv-text="${this.obj?.name}"/>" 吗?</target> | ||||
|         <x id="0" equiv-text="${this.objectLabel}"/>"  | ||||
|         <x id="1" equiv-text="${this.obj?.name}"/>" 吗?</target> | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="sc92d7cfb6ee1fec6"> | ||||
| @ -5077,7 +5077,7 @@ doesn't pass when either or both of the selected options are equal or above the | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="sdf1d8edef27236f0"> | ||||
|         <source>A "roaming" authenticator, like a YubiKey</source> | ||||
|         <source>A "roaming" authenticator, like a YubiKey</source> | ||||
|         <target>像 YubiKey 这样的“漫游”身份验证器</target> | ||||
|          | ||||
|       </trans-unit> | ||||
| @ -5412,10 +5412,10 @@ doesn't pass when either or both of the selected options are equal or above the | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s2d5f69929bb7221d"> | ||||
|         <source><x id="0" equiv-text="${prompt.name}"/> ("<x id="1" equiv-text="${prompt.fieldKey}"/>", of type <x id="2" equiv-text="${prompt.type}"/>)</source> | ||||
|         <source><x id="0" equiv-text="${prompt.name}"/> ("<x id="1" equiv-text="${prompt.fieldKey}"/>", of type <x id="2" equiv-text="${prompt.type}"/>)</source> | ||||
|         <target> | ||||
|         <x id="0" equiv-text="${prompt.name}"/>("  | ||||
|         <x id="1" equiv-text="${prompt.fieldKey}"/>",类型为  | ||||
|         <x id="0" equiv-text="${prompt.name}"/>("  | ||||
|         <x id="1" equiv-text="${prompt.fieldKey}"/>",类型为  | ||||
|         <x id="2" equiv-text="${prompt.type}"/>)</target> | ||||
|          | ||||
|       </trans-unit> | ||||
| @ -5464,7 +5464,7 @@ doesn't pass when either or both of the selected options are equal or above the | ||||
|          | ||||
|       </trans-unit> | ||||
|       <trans-unit id="s1608b2f94fa0dbd4"> | ||||
|         <source>If set to a duration above 0, the user will have the option to choose to "stay signed in", which will extend their session by the time specified here.</source> | ||||
|         <source>If set to a duration above 0, the user will have the option to choose to "stay signed in", which will extend their session by the time specified here.</source> | ||||
|         <target>如果设置时长大于 0,用户可以选择“保持登录”选项,这将使用户的会话延长此处设置的时间。</target> | ||||
|          | ||||
|       </trans-unit> | ||||
| @ -7970,7 +7970,7 @@ Bindings to groups/users are checked against the user of the event.</source> | ||||
|   <target>成功创建用户并添加到组 <x id="0" equiv-text="${this.group.name}"/></target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s824e0943a7104668"> | ||||
|   <source>This user will be added to the group "<x id="0" equiv-text="${this.targetGroup.name}"/>".</source> | ||||
|   <source>This user will be added to the group "<x id="0" equiv-text="${this.targetGroup.name}"/>".</source> | ||||
|   <target>此用户将会被添加到组 &quot;<x id="0" equiv-text="${this.targetGroup.name}"/>&quot;。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s62e7f6ed7d9cb3ca"> | ||||
| @ -7983,51 +7983,67 @@ Bindings to groups/users are checked against the user of the event.</source> | ||||
| </trans-unit> | ||||
| <trans-unit id="scda8dc24b561e205"> | ||||
|   <source>There was an error in the application.</source> | ||||
|   <target>应用程序中存在一个错误。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sdaca9c2c0361ed3a"> | ||||
|   <source>Review the application.</source> | ||||
|   <target>检查此应用程序。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sb50000a8fada5672"> | ||||
|   <source>There was an error in the provider.</source> | ||||
|   <target>提供程序中存在一个错误。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s21f95eaf151d4ce3"> | ||||
|   <source>Review the provider.</source> | ||||
|   <target>检查此提供程序。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s9fd39a5cb20b4e61"> | ||||
|   <source>There was an error</source> | ||||
|   <target>存在一个错误</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s7a6b3453209e1066"> | ||||
|   <source>There was an error creating the application, but no error message was sent. Please review the server logs.</source> | ||||
|   <target>创建应用程序时存在一个错误,但未发送错误消息。请检查服务器日志。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s1a711c19cda48375"> | ||||
|   <source>Configure LDAP Provider</source> | ||||
|   <target>配置 LDAP 提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s9368e965b5c292ab"> | ||||
|   <source>Configure OAuth2/OpenId Provider</source> | ||||
|   <target>配置 OAuth2/OpenID 提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sf5cbccdc6254c8dc"> | ||||
|   <source>Configure Proxy Provider</source> | ||||
|   <target>配置代理提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sf6d46bb442b77e91"> | ||||
|   <source>AdditionalScopes</source> | ||||
|   <target>额外的作用域</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s2c8c6f89089b31d4"> | ||||
|   <source>Configure Radius Provider</source> | ||||
|   <target>配置 Radius 提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sfe906cde5dddc041"> | ||||
|   <source>Configure SAML Provider</source> | ||||
|   <target>配置 SAML 提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sb3defbacd01ad972"> | ||||
|   <source>Property mappings used for user mapping.</source> | ||||
|   <target>用于用户映射的属性映射。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s7ccce0ec8d228db6"> | ||||
|   <source>Configure SCIM Provider</source> | ||||
|   <target>配置 SCIM 提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sd7728d2b6e1d25e9"> | ||||
|   <source>Property mappings used for group creation.</source> | ||||
|   <target>用于创建组的属性映射。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s7513372fe60f6387"> | ||||
|   <source>Event volume</source> | ||||
|   <target>事件容量</target> | ||||
| </trans-unit> | ||||
|     </body> | ||||
|   </file> | ||||
|  | ||||
| @ -7619,14 +7619,6 @@ Bindings to groups/users are checked against the user of the event.</source> | ||||
|   <source>Your application has been saved</source> | ||||
|   <target>您的应用程序已保存</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sf60f1e5b76897c93"> | ||||
|   <source>In the Application:</source> | ||||
|   <target>在应用程序中:</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s7ce65cf482b7bff0"> | ||||
|   <source>In the Provider:</source> | ||||
|   <target>在提供程序中:</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s67d858051b34c38b"> | ||||
|   <source>Method's display Name.</source> | ||||
|   <target>方法的显示名称。</target> | ||||
| @ -7988,6 +7980,70 @@ Bindings to groups/users are checked against the user of the event.</source> | ||||
| <trans-unit id="s52bdc80690a9a8dc"> | ||||
|   <source>When enabled, the stage will always accept the given user identifier and continue.</source> | ||||
|   <target>启用时,此阶段总是会接受指定的用户 ID 并继续。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="scda8dc24b561e205"> | ||||
|   <source>There was an error in the application.</source> | ||||
|   <target>应用程序中存在一个错误。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sdaca9c2c0361ed3a"> | ||||
|   <source>Review the application.</source> | ||||
|   <target>检查此应用程序。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sb50000a8fada5672"> | ||||
|   <source>There was an error in the provider.</source> | ||||
|   <target>提供程序中存在一个错误。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s21f95eaf151d4ce3"> | ||||
|   <source>Review the provider.</source> | ||||
|   <target>检查此提供程序。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s9fd39a5cb20b4e61"> | ||||
|   <source>There was an error</source> | ||||
|   <target>存在一个错误</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s7a6b3453209e1066"> | ||||
|   <source>There was an error creating the application, but no error message was sent. Please review the server logs.</source> | ||||
|   <target>创建应用程序时存在一个错误,但未发送错误消息。请检查服务器日志。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s1a711c19cda48375"> | ||||
|   <source>Configure LDAP Provider</source> | ||||
|   <target>配置 LDAP 提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s9368e965b5c292ab"> | ||||
|   <source>Configure OAuth2/OpenId Provider</source> | ||||
|   <target>配置 OAuth2/OpenID 提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sf5cbccdc6254c8dc"> | ||||
|   <source>Configure Proxy Provider</source> | ||||
|   <target>配置代理提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sf6d46bb442b77e91"> | ||||
|   <source>AdditionalScopes</source> | ||||
|   <target>额外的作用域</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s2c8c6f89089b31d4"> | ||||
|   <source>Configure Radius Provider</source> | ||||
|   <target>配置 Radius 提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sfe906cde5dddc041"> | ||||
|   <source>Configure SAML Provider</source> | ||||
|   <target>配置 SAML 提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sb3defbacd01ad972"> | ||||
|   <source>Property mappings used for user mapping.</source> | ||||
|   <target>用于用户映射的属性映射。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s7ccce0ec8d228db6"> | ||||
|   <source>Configure SCIM Provider</source> | ||||
|   <target>配置 SCIM 提供程序</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="sd7728d2b6e1d25e9"> | ||||
|   <source>Property mappings used for group creation.</source> | ||||
|   <target>用于创建组的属性映射。</target> | ||||
| </trans-unit> | ||||
| <trans-unit id="s7513372fe60f6387"> | ||||
|   <source>Event volume</source> | ||||
|   <target>事件容量</target> | ||||
| </trans-unit> | ||||
|     </body> | ||||
|   </file> | ||||
|  | ||||
							
								
								
									
										8
									
								
								website/package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										8
									
								
								website/package-lock.json
									
									
									
										generated
									
									
									
								
							| @ -35,7 +35,7 @@ | ||||
|                 "@docusaurus/types": "3.0.1", | ||||
|                 "@types/react": "^18.2.42", | ||||
|                 "prettier": "3.1.0", | ||||
|                 "typescript": "~5.3.2" | ||||
|                 "typescript": "~5.3.3" | ||||
|             }, | ||||
|             "engines": { | ||||
|                 "node": ">=20" | ||||
| @ -16240,9 +16240,9 @@ | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/typescript": { | ||||
|             "version": "5.3.2", | ||||
|             "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.2.tgz", | ||||
|             "integrity": "sha512-6l+RyNy7oAHDfxC4FzSJcz9vnjTKxrLpDG5M2Vu4SHRVNg6xzqZp6LYSR9zjqQTu8DU/f5xwxUdADOkbrIX2gQ==", | ||||
|             "version": "5.3.3", | ||||
|             "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz", | ||||
|             "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==", | ||||
|             "bin": { | ||||
|                 "tsc": "bin/tsc", | ||||
|                 "tsserver": "bin/tsserver" | ||||
|  | ||||
| @ -54,7 +54,7 @@ | ||||
|         "@docusaurus/types": "3.0.1", | ||||
|         "@types/react": "^18.2.42", | ||||
|         "prettier": "3.1.0", | ||||
|         "typescript": "~5.3.2" | ||||
|         "typescript": "~5.3.3" | ||||
|     }, | ||||
|     "engines": { | ||||
|         "node": ">=20" | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Ken Sternberg
					Ken Sternberg