aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKate <26026535+provokateurin@users.noreply.github.com>2024-05-11 16:27:13 +0200
committerGitHub <noreply@github.com>2024-05-11 16:27:13 +0200
commitb0429e7ef48b261f91786f3d0b011e57c8736ac1 (patch)
tree477c262a4f0664c1cff5074c7b3edfd623802efc
parent4dc73b3354946e065ea72b8d2554038d3fea699d (diff)
parentaff7798fc1d22302c1ab920c81b4f4b8613f3289 (diff)
downloadnextcloud-server-b0429e7ef48b261f91786f3d0b011e57c8736ac1.tar.gz
nextcloud-server-b0429e7ef48b261f91786f3d0b011e57c8736ac1.zip
Merge pull request #45270 from nextcloud/refactor/provisioning_api/type-scopes
-rw-r--r--apps/provisioning_api/lib/ResponseDefinitions.php30
-rw-r--r--apps/provisioning_api/openapi-full.json40
-rw-r--r--apps/provisioning_api/openapi.json40
-rw-r--r--lib/private/Accounts/AccountProperty.php3
-rw-r--r--lib/public/Accounts/IAccountProperty.php2
5 files changed, 73 insertions, 42 deletions
diff --git a/apps/provisioning_api/lib/ResponseDefinitions.php b/apps/provisioning_api/lib/ResponseDefinitions.php
index 07777f1f35f..9912fbe586a 100644
--- a/apps/provisioning_api/lib/ResponseDefinitions.php
+++ b/apps/provisioning_api/lib/ResponseDefinitions.php
@@ -35,30 +35,32 @@ namespace OCA\Provisioning_API;
* used?: float|int,
* }
*
+ * @psalm-type Provisioning_APIUserDetailsScope = 'v2-private'|'v2-local'|'v2-federated'|'v2-published'|'private'|'contacts'|'public'
+ *
* @psalm-type Provisioning_APIUserDetails = array{
* additional_mail: string[],
- * additional_mailScope?: string[],
+ * additional_mailScope?: Provisioning_APIUserDetailsScope[],
* address: string,
- * addressScope?: string,
- * avatarScope?: string,
+ * addressScope?: Provisioning_APIUserDetailsScope,
+ * avatarScope?: Provisioning_APIUserDetailsScope,
* backend: string,
* backendCapabilities: array{
* setDisplayName: bool,
* setPassword: bool
* },
* biography: string,
- * biographyScope?: string,
+ * biographyScope?: Provisioning_APIUserDetailsScope,
* display-name: string,
* displayname: string,
- * displaynameScope?: string,
+ * displaynameScope?: Provisioning_APIUserDetailsScope,
* email: ?string,
- * emailScope?: string,
+ * emailScope?: Provisioning_APIUserDetailsScope,
* enabled?: bool,
* fediverse: string,
- * fediverseScope?: string,
+ * fediverseScope?: Provisioning_APIUserDetailsScope,
* groups: string[],
* headline: string,
- * headlineScope?: string,
+ * headlineScope?: Provisioning_APIUserDetailsScope,
* id: string,
* language: string,
* lastLogin: int,
@@ -66,20 +68,20 @@ namespace OCA\Provisioning_API;
* manager: string,
* notify_email: ?string,
* organisation: string,
- * organisationScope?: string,
+ * organisationScope?: Provisioning_APIUserDetailsScope,
* phone: string,
- * phoneScope?: string,
+ * phoneScope?: Provisioning_APIUserDetailsScope,
* profile_enabled: string,
- * profile_enabledScope?: string,
+ * profile_enabledScope?: Provisioning_APIUserDetailsScope,
* quota: Provisioning_APIUserDetailsQuota,
* role: string,
- * roleScope?: string,
+ * roleScope?: Provisioning_APIUserDetailsScope,
* storageLocation?: string,
* subadmin: string[],
* twitter: string,
- * twitterScope?: string,
+ * twitterScope?: Provisioning_APIUserDetailsScope,
* website: string,
- * websiteScope?: string,
+ * websiteScope?: Provisioning_APIUserDetailsScope,
* }
*
* @psalm-type Provisioning_APIGroupDetails = array{
diff --git a/apps/provisioning_api/openapi-full.json b/apps/provisioning_api/openapi-full.json
index 522375a966b..2b219416c8d 100644
--- a/apps/provisioning_api/openapi-full.json
+++ b/apps/provisioning_api/openapi-full.json
@@ -162,17 +162,17 @@
"additional_mailScope": {
"type": "array",
"items": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
}
},
"address": {
"type": "string"
},
"addressScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"avatarScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"backend": {
"type": "string"
@@ -196,7 +196,7 @@
"type": "string"
},
"biographyScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"display-name": {
"type": "string"
@@ -205,14 +205,14 @@
"type": "string"
},
"displaynameScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"email": {
"type": "string",
"nullable": true
},
"emailScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"enabled": {
"type": "boolean"
@@ -221,7 +221,7 @@
"type": "string"
},
"fediverseScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"groups": {
"type": "array",
@@ -233,7 +233,7 @@
"type": "string"
},
"headlineScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"id": {
"type": "string"
@@ -259,19 +259,19 @@
"type": "string"
},
"organisationScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"phone": {
"type": "string"
},
"phoneScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"profile_enabled": {
"type": "string"
},
"profile_enabledScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"quota": {
"$ref": "#/components/schemas/UserDetailsQuota"
@@ -280,7 +280,7 @@
"type": "string"
},
"roleScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"storageLocation": {
"type": "string"
@@ -295,13 +295,13 @@
"type": "string"
},
"twitterScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"website": {
"type": "string"
},
"websiteScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
}
}
},
@@ -372,6 +372,18 @@
]
}
}
+ },
+ "UserDetailsScope": {
+ "type": "string",
+ "enum": [
+ "v2-private",
+ "v2-local",
+ "v2-federated",
+ "v2-published",
+ "private",
+ "contacts",
+ "public"
+ ]
}
}
},
diff --git a/apps/provisioning_api/openapi.json b/apps/provisioning_api/openapi.json
index 3119a813832..ee48da07658 100644
--- a/apps/provisioning_api/openapi.json
+++ b/apps/provisioning_api/openapi.json
@@ -162,17 +162,17 @@
"additional_mailScope": {
"type": "array",
"items": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
}
},
"address": {
"type": "string"
},
"addressScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"avatarScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"backend": {
"type": "string"
@@ -196,7 +196,7 @@
"type": "string"
},
"biographyScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"display-name": {
"type": "string"
@@ -205,14 +205,14 @@
"type": "string"
},
"displaynameScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"email": {
"type": "string",
"nullable": true
},
"emailScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"enabled": {
"type": "boolean"
@@ -221,7 +221,7 @@
"type": "string"
},
"fediverseScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"groups": {
"type": "array",
@@ -233,7 +233,7 @@
"type": "string"
},
"headlineScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"id": {
"type": "string"
@@ -259,19 +259,19 @@
"type": "string"
},
"organisationScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"phone": {
"type": "string"
},
"phoneScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"profile_enabled": {
"type": "string"
},
"profile_enabledScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"quota": {
"$ref": "#/components/schemas/UserDetailsQuota"
@@ -280,7 +280,7 @@
"type": "string"
},
"roleScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"storageLocation": {
"type": "string"
@@ -295,13 +295,13 @@
"type": "string"
},
"twitterScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
},
"website": {
"type": "string"
},
"websiteScope": {
- "type": "string"
+ "$ref": "#/components/schemas/UserDetailsScope"
}
}
},
@@ -372,6 +372,18 @@
]
}
}
+ },
+ "UserDetailsScope": {
+ "type": "string",
+ "enum": [
+ "v2-private",
+ "v2-local",
+ "v2-federated",
+ "v2-published",
+ "private",
+ "contacts",
+ "public"
+ ]
}
}
},
diff --git a/lib/private/Accounts/AccountProperty.php b/lib/private/Accounts/AccountProperty.php
index 207dc1d139d..456d04f356f 100644
--- a/lib/private/Accounts/AccountProperty.php
+++ b/lib/private/Accounts/AccountProperty.php
@@ -32,6 +32,9 @@ use OCP\Accounts\IAccountManager;
use OCP\Accounts\IAccountProperty;
class AccountProperty implements IAccountProperty {
+ /**
+ * @var IAccountManager::SCOPE_*
+ */
private string $scope;
private string $locallyVerified = IAccountManager::NOT_VERIFIED;
diff --git a/lib/public/Accounts/IAccountProperty.php b/lib/public/Accounts/IAccountProperty.php
index 82a83e8948a..2374c7b272d 100644
--- a/lib/public/Accounts/IAccountProperty.php
+++ b/lib/public/Accounts/IAccountProperty.php
@@ -50,6 +50,7 @@ interface IAccountProperty extends \JsonSerializable {
* @since 15.0.0
*
* @param string $scope
+ * @psalm-param IAccountManager::SCOPE_* $scope
* @return IAccountProperty
* @throws InvalidArgumentException (since 22.0.0)
*/
@@ -89,6 +90,7 @@ interface IAccountProperty extends \JsonSerializable {
* @since 15.0.0
*
* @return string
+ * @psalm-return IAccountManager::SCOPE_*
*/
public function getScope(): string;