Jump to content

Qt for HarmonyOS/qtohosextras doc/FileShare Namespace: Difference between revisions

From Qt Wiki
Created page with "<!-- Source: qtohosextras-fileshare.html --> <span id="fileshare-namespace"></span> = FileShare Namespace = <span class="small-subtitle">(QtOhosExtras::FileShare)<br /> </span> The FileShare to expose file permission API. More... <div class="table"> {| class="wikitable alignedsummary" |- | class="memItemLeft rightAlign topAlign"| Header: |..."
 
No edit summary
 
(4 intermediate revisions by the same user not shown)
Line 1: Line 1:
<!-- Source: qtohosextras-fileshare.html -->
< [[Qt for HarmonyOS/qtohosextras doc/Qt Ohos Extras C++ Classes|Qt Ohos Extras C++ Classes]]
<span id="fileshare-namespace"></span>
 
= FileShare Namespace =
= FileShare Namespace =


<span class="small-subtitle">([[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace|QtOhosExtras::FileShare]])<br />
The FileShare to expose file permission API. [[#details|More...]]
</span>
 
The [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace|FileShare]] to expose file permission API. [[#details|More...]]
 
<div class="table">


{| class="wikitable alignedsummary"
{| class="wikitable"
|-
|-
| class="memItemLeft rightAlign topAlign"| Header:
! Header:
| class="memItemRight bottomAlign"| <span class="preprocessor">#include </span>
| #include <FileShare>
|-
|-
| class="memItemLeft rightAlign topAlign"| qmake:
! qmake:
| class="memItemRight bottomAlign"| QT += ohosextras
| QT += ohosextras
|-
|-
| class="memItemLeft rightAlign topAlign"| Since:
! Since:
| class="memItemRight bottomAlign"| Qt 5.12.12
| Qt 5.12.12
|}
|}


</div>
<span id="classes"></span>
<span id="classes"></span>
== Classes ==
== Classes ==


<div class="table">
{| class="wikitable" style="width:100%"
 
{| class="wikitable alignedsummary"
|-
|-
| class="memItemLeft rightAlign topAlign"| class
| class || '''[[Qt for HarmonyOS/qtohosextras doc/ActionResult Class|ActionResult]]'''
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]]'''
|-
|-
| class="memItemLeft rightAlign topAlign"| class
| class || '''[[Qt for HarmonyOS/qtohosextras doc/CheckResult Class|CheckResult]]'''
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/CheckResult_Class|CheckResult]]'''
|-
|-
| class="memItemLeft rightAlign topAlign"| class
| class || '''[[Qt for HarmonyOS/qtohosextras doc/PathPolicy Class|PathPolicy]]'''
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicy_Class|PathPolicy]]'''
|-
|-
| class="memItemLeft rightAlign topAlign"| class
| class || '''[[Qt for HarmonyOS/qtohosextras doc/PathPolicyCheckResult Class|PathPolicyCheckResult]]'''
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicyCheckResult_Class|PathPolicyCheckResult]]'''
|-
|-
| class="memItemLeft rightAlign topAlign"| class
| class || '''[[Qt for HarmonyOS/qtohosextras doc/PathPolicyErrorInfo Class|PathPolicyErrorInfo]]'''
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicyErrorInfo_Class|PathPolicyErrorInfo]]'''
|}
|}


</div>
<span id="types"></span>
<span id="types"></span>
== Types ==
== Types ==


<div class="table">
{| class="wikitable" style="width:100%"
 
{| class="wikitable alignedsummary"
|-
|-
| class="memItemLeft rightAlign topAlign"| enum
| enum || '''[[#OperationMode-enum|OperationMode]]''' { Read, Write }
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#OperationMode-enum|OperationMode]]''' { Read, Write }
|-
|-
| class="memItemLeft rightAlign topAlign"| flags
| flags || '''[[#OperationMode-enum|OperationModes]]'''
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#OperationMode-enum|OperationModes]]'''
|-
|-
| class="memItemLeft rightAlign topAlign"| enum
| enum || '''[[#PathPolicyError-enum|PathPolicyError]]''' { Unknown, PersistenceForbidden, InvalidMode, InvalidPath, PermissionNotPersisted }
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#PathPolicyError-enum|PathPolicyError]]''' { Unknown, PersistenceForbidden, InvalidMode, InvalidPath, PermissionNotPersisted }
|}
|}


</div>
<span id="functions"></span>
<span id="functions"></span>
== Functions ==
== Functions ==


<div class="table">
{| class="wikitable" style="width:100%"
 
{| class="wikitable alignedsummary"
|-
|-
| class="memItemLeft rightAlign topAlign"| QSharedPointer
| QSharedPointer<QtOhosExtras::FileShare::ActionResult> || '''[[#activatePermission|activatePermission]]'''(const QList<QtOhosExtras::FileShare::PathPolicy> &''policies'')
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#activatePermission|activatePermission]]'''(const QList &amp;''policies'')
|-
|-
| class="memItemLeft rightAlign topAlign"| QSharedPointer
| QSharedPointer<QtOhosExtras::FileShare::CheckResult> || '''[[#checkPersistent|checkPersistent]]'''(const QList<QtOhosExtras::FileShare::PathPolicy> &''policies'')
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#checkPersistent|checkPersistent]]'''(const QList &amp;''policies'')
|-
|-
| class="memItemLeft rightAlign topAlign"| QSharedPointer
| QSharedPointer<QtOhosExtras::FileShare::ActionResult> || '''[[#deactivatePermission|deactivatePermission]]'''(const QList<QtOhosExtras::FileShare::PathPolicy> &''policies'')
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#deactivatePermission|deactivatePermission]]'''(const QList &amp;''policies'')
|-
|-
| class="memItemLeft rightAlign topAlign"| QSharedPointer
| QSharedPointer<QtOhosExtras::FileShare::ActionResult> || '''[[#persistPermission|persistPermission]]'''(const QList<QtOhosExtras::FileShare::PathPolicy> &''policies'')
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#persistPermission|persistPermission]]'''(const QList &amp;''policies'')
|-
|-
| class="memItemLeft rightAlign topAlign"| const QMetaObject *
| const QMetaObject * || '''[[#qt_getEnumMetaObject|qt_getEnumMetaObject]]'''(QtOhosExtras::FileShare::OperationMode)
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#qt_getEnumMetaObject|qt_getEnumMetaObject]]'''(''QtOhosExtras::FileShare::OperationMode'')
|-
|-
| class="memItemLeft rightAlign topAlign"| const char *
| const char * || '''[[#qt_getEnumName|qt_getEnumName]]'''(QtOhosExtras::FileShare::OperationMode)
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#qt_getEnumName|qt_getEnumName]]'''(''QtOhosExtras::FileShare::OperationMode'')
|-
|-
| class="memItemLeft rightAlign topAlign"| QSharedPointer
| QSharedPointer<QtOhosExtras::FileShare::ActionResult> || '''[[#revokePermission|revokePermission]]'''(const QList<QtOhosExtras::FileShare::PathPolicy> &''policies'')
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#revokePermission|revokePermission]]'''(const QList &amp;''policies'')
|-
|-
| class="memItemLeft rightAlign topAlign"| QFlags
| QFlags<OperationModes::enum_type> || '''[[#operator-7c|operator\|]]'''(OperationModes::enum_type ''f1'', OperationModes::enum_type ''f2'')
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#operator-7c|operator|]]'''(OperationModes::enum_type ''f1'', OperationModes::enum_type ''f2'')
|-
|-
| class="memItemLeft rightAlign topAlign"| QFlags
| QFlags<OperationModes::enum_type> || '''[[#operator-7c-1|operator\|]]'''(OperationModes::enum_type ''f1'', QFlags<OperationModes::enum_type> ''f2'')
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#operator-7c-1|operator|]]'''(OperationModes::enum_type ''f1'', QFlags ''f2'')
|-
|-
| class="memItemLeft rightAlign topAlign"| QIncompatibleFlag
| QIncompatibleFlag || '''[[#operator-7c-2|operator\|]]'''(OperationModes::enum_type ''f1'', int ''f2'')
| class="memItemRight bottomAlign"| '''[[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#operator-7c-2|operator|]]'''(OperationModes::enum_type ''f1'', int ''f2'')
|}
|}


 
== Detailed Description ==
</div>
<span id="details"></span>
 
<div class="descr">


<span id="details"></span>
<span id="details"></span>
== Detailed Description ==
The FileShare to expose file permission API.
 
The [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace|FileShare]] to expose file permission API.


This API uses file system paths, which differ from the URIs used internally by HarmonyOS. For example, the path <code>/data/storage/el1/bundle/entry/resources/resfile/test.txt</code> will be converted to the URI <code>file://com.your.example/data/storage/el1/bundle/entry/resources/resfile/test.txt</code> , where <code>com.your.example</code> is app bundle name.
This API uses file system paths, which differ from the URIs used internally by HarmonyOS. For example, the path <code>/data/storage/el1/bundle/entry/resources/resfile/test.txt</code> will be converted to the URI <code>file://com.your.example/data/storage/el1/bundle/entry/resources/resfile/test.txt</code> , where <code>com.your.example</code> is app bundle name.
Line 129: Line 77:
To learn more about file paths and URIs in HarmonyOS, see [https://developer.huawei.com/consumer/en/doc/harmonyos-guides-V5/app-sandbox-directory-V5 sandbox documentation].
To learn more about file paths and URIs in HarmonyOS, see [https://developer.huawei.com/consumer/en/doc/harmonyos-guides-V5/app-sandbox-directory-V5 sandbox documentation].


'''Warning:''' This API relies on the underlying OHOS implementation. The following functions: [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#persistPermission|persistPermission]](), [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#revokePermission|revokePermission]](), [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#activatePermission|activatePermission]](), [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#deactivatePermission|deactivatePermission]](), and [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#checkPersistent|checkPersistent]]() may be unavailable on some devices. Additionally, there may be limitations on the maximum number of policies, and certain permissions may need to be explicitly granted to the application.
'''Warning:''' This API relies on the underlying OHOS implementation. The following functions: [[#persistPermission|persistPermission()]], [[#revokePermission|revokePermission()]], [[#activatePermission|activatePermission()]], [[#deactivatePermission|deactivatePermission()]], and [[#checkPersistent|checkPersistent()]] may be unavailable on some devices. Additionally, there may be limitations on the maximum number of policies, and certain permissions may need to be explicitly granted to the application.


For more details and limitations, refer to the [https://developer.huawei.com/consumer/en/doc/harmonyos-guides-V14/native-fileshare-guidelines-V14 API documentation].
For more details and limitations, refer to the [https://developer.huawei.com/consumer/en/doc/harmonyos-guides-V14/native-fileshare-guidelines-V14 API documentation].


</div>
<div class="classes">
<span id="classes-1"></span>
== Classes ==
<span id="class-actionresult"></span>
=== class [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]] ===
The [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]] class encapsulates the result of all file requested access permission actions. [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class#details|More...]]
<span id="class-checkresult"></span>
=== class [[Qt_for_HarmonyOS/qtohosextras_doc/CheckResult_Class|CheckResult]] ===
The [[Qt_for_HarmonyOS/qtohosextras_doc/CheckResult_Class|CheckResult]] class encapsulates the result of all requested file access permission checks. [[Qt_for_HarmonyOS/qtohosextras_doc/CheckResult_Class#details|More...]]
<span id="class-pathpolicy"></span>
=== class [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicy_Class|PathPolicy]] ===
The [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicy_Class|PathPolicy]] struct encapsulates information required to request file access permissions for a specified path. [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicy_Class#details|More...]]
<span id="class-pathpolicycheckresult"></span>
=== class [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicyCheckResult_Class|PathPolicyCheckResult]] ===
The [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicyCheckResult_Class|PathPolicyCheckResult]] struct contains the result of a file permission check request for a specified path, indicating whether access is granted or denied. [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicyCheckResult_Class#details|More...]]
<span id="class-pathpolicyerrorinfo"></span>
=== class [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicyErrorInfo_Class|PathPolicyErrorInfo]] ===
The [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicyErrorInfo_Class|PathPolicyErrorInfo]] struct contains the result of a file access permission request for a specified path. [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicyErrorInfo_Class#details|More...]]
</div>
<div class="types">
<span id="type-documentation"></span>
== Type Documentation ==
== Type Documentation ==


<span id="OperationMode-enum"></span>
=== <span id="OperationMode-enum"></span>enum FileShare::OperationMode ===
=== <span id="OperationMode-enum"></span>enum FileShare::<span class="name">OperationMode</span><br />
=== <span id="OperationModes-flags"></span>flags FileShare::OperationModes ===
flags FileShare::<span class="name">OperationModes</span> ===


Defines permissions on path. See [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#fileshare_operationmode FileShare_OperationMode]. The flags can be combined using bitwise operations.
Defines permissions on path. See [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#fileshare_operationmode FileShare_OperationMode]. The flags can be combined using bitwise operations.


<div class="table">
{| class="wikitable"
 
! Constant !! Value !! Description
{| class="wikitable valuelist"
|- class="odd" valign="top"
! class="tblConst"| Constant
! class="tblval"| Value
! class="tbldscr"| Description
|-
|-
| class="topAlign"| <code>QtOhosExtras::FileShare::Read</code>
| <code>QtOhosExtras::FileShare::Read</code> || <code>1 << 0</code> || Read on path
| class="topAlign tblval"| <code>1 &lt;&lt; 0</code>
| class="topAlign"| Read on path
|-
|-
| class="topAlign"| <code>QtOhosExtras::FileShare::Write</code>
| <code>QtOhosExtras::FileShare::Write</code> || <code>1 << 1</code> || Write on path
| class="topAlign tblval"| <code>1 &lt;&lt; 1</code>
| class="topAlign"| Write on path
|}
|}


</div>
This enum was introduced or modified in Qt 5.12.12.
This enum was introduced or modified in Qt 5.12.12.


The OperationModes type is a typedef for [[../qtcore/qflags.html|QFlags]]. It stores an OR combination of OperationMode values.
The OperationModes type is a typedef for QFlags<OperationMode>. It stores an OR combination of OperationMode values.


'''See also''' [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicy_Class|PathPolicy]].
'''See also:''' [[Qt for HarmonyOS/qtohosextras doc/PathPolicy Class|PathPolicy]].


<span id="PathPolicyError-enum"></span>
=== <span id="PathPolicyError-enum"></span>enum FileShare::PathPolicyError ===
=== <span id="PathPolicyError-enum"></span>enum FileShare::<span class="name">PathPolicyError</span> ===


Defines permission policy error codes. See [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#fileshare_policyerrorcode FileShare_PolicyErrorCode].
Defines permission policy error codes. See [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#fileshare_policyerrorcode FileShare_PolicyErrorCode].


<div class="table">
{| class="wikitable"
 
! Constant !! Value !! Description
{| class="wikitable valuelist"
|- class="odd" valign="top"
! class="tblConst"| Constant
! class="tblval"| Value
! class="tbldscr"| Description
|-
|-
| class="topAlign"| <code>QtOhosExtras::FileShare::Unknown</code>
| <code>QtOhosExtras::FileShare::Unknown</code> || 0 || Error type is unknown or not recognized
| class="topAlign tblval"| <code>0</code>
| class="topAlign"| Error type is unknown or not recognized
|-
|-
| class="topAlign"| <code>QtOhosExtras::FileShare::PersistenceForbidden</code>
| <code>QtOhosExtras::FileShare::PersistenceForbidden</code> || 1 || The permission on the path cannot be persisted
| class="topAlign tblval"| <code>1</code>
| class="topAlign"| The permission on the path cannot be persisted
|-
|-
| class="topAlign"| <code>QtOhosExtras::FileShare::InvalidMode</code>
| <code>QtOhosExtras::FileShare::InvalidMode</code> || 2 || Invalid operation mode
| class="topAlign tblval"| <code>2</code>
| class="topAlign"| Invalid operation mode
|-
|-
| class="topAlign"| <code>QtOhosExtras::FileShare::InvalidPath</code>
| <code>QtOhosExtras::FileShare::InvalidPath</code> || 3 || Invalid path
| class="topAlign tblval"| <code>3</code>
| class="topAlign"| Invalid path
|-
|-
| class="topAlign"| <code>QtOhosExtras::FileShare::PermissionNotPersisted</code>
| <code>QtOhosExtras::FileShare::PermissionNotPersisted</code> || 4 || The permission is not persisted
| class="topAlign tblval"| <code>4</code>
| class="topAlign"| The permission is not persisted
|}
|}


</div>
This enum was introduced or modified in Qt 5.12.12.
This enum was introduced or modified in Qt 5.12.12.


'''See also''' [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicyErrorInfo_Class|PathPolicyErrorInfo]].
'''See also:''' [[Qt for HarmonyOS/qtohosextras doc/PathPolicyErrorInfo Class|PathPolicyErrorInfo]].


== Function Documentation ==


</div>
=== <span id="activatePermission"></span>QSharedPointer<ActionResult> FileShare::activatePermission(const QList<PathPolicy> &''policies'') ===
<div class="func">


<span id="function-documentation"></span>
Activates file or folder permissions from ''policies''. The success of the action can be determined from [[ActionResult_Class|ActionResult]].
== Function Documentation ==


<span id="activatePermission"></span>
This function calls [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#oh_fileshare_activatepermission OH_FileShare_ActivatePermission]. Each time an application is started, its persistent permissions have not been loaded to the memory. Use this function to make a persistent permission active after the application is started. If the activation fails because the permission has not been persisted, use [[#persistPermission|persistPermission()]] first.
=== activatePermission ===


<syntaxhighlight lang="cpp">
To deactivate an active permission, use [[#deactivatePermission|deactivatePermission()]].
QSharedPointer<QtOhosExtras::FileShare::ActionResult> FileShare::activatePermission(const QList<QtOhosExtras::FileShare::PathPolicy> &''policies'')
</syntaxhighlight>


Activates file or folder permissions from ''policies''. The success of the action can be determined from [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]].
'''See also:''' [[ActionResult_Class|ActionResult]], [[PathPolicy_Struct|PathPolicy]], [[#persistPermission|persistPermission()]], and [[#deactivatePermission|deactivatePermission()]].


This function calls [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#oh_fileshare_activatepermission OH_FileShare_ActivatePermission]. Each time an application is started, its persistent permissions have not been loaded to the memory. Use this function to make a persistent permission active after the application is started. If the activation fails because the permission has not been persisted, use [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#persistPermission|persistPermission]]() first.
=== <span id="checkPersistent"></span>QSharedPointer<CheckResult> FileShare::checkPersistent(const QList<PathPolicy> &''policies'') ===


To deactivate an active permission, use [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#deactivatePermission|deactivatePermission]]().
Checks if file or folder permissions from ''policies'' have persistent permissions. The result check for each file or folder can be determined from [[CheckResult_Class|CheckResult]]. CheckResult::PathPolicyCheckResult::result will be set to <code>true</code> for each file or folder only for succesufull check and persistent permission found, <code>false</code> otherwise.


'''See also''' [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]], [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicy_Class|PathPolicy]], [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#persistPermission|persistPermission]](), and [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#deactivatePermission|deactivatePermission]]().
This function calls [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#oh_fileshare_checkpersistentpermission OH_FileShare_CheckPersistentPermission].


<span id="checkPersistent"></span>
To persist permission, use [[#persistPermission|persistPermission()]].
=== checkPersistent ===


<syntaxhighlight lang="cpp">
'''See also:''' [[CheckResult_Class|CheckResult]], [[Qt for HarmonyOS/qtohosextras doc/PathPolicy Class|PathPolicy]], and [[#persistPermission|persistPermission()]].
QSharedPointer<QtOhosExtras::FileShare::CheckResult> FileShare::checkPersistent(const QList<QtOhosExtras::FileShare::PathPolicy> &''policies'')
</syntaxhighlight>


Checks if file or folder permissions from ''policies'' have persistent permissions. The result check for each file or folder can be determined from [[Qt_for_HarmonyOS/qtohosextras_doc/CheckResult_Class|CheckResult]]. CheckResult::PathPolicyCheckResult::result will be set to <code>true</code> for each file or folder only for succesufull check and persistent permission found, <code>false</code> otherwise.
=== <span id="deactivatePermission"></span>QSharedPointer<ActionResult> FileShare::deactivatePermission(const QList<PathPolicy> &''policies'') ===


This function calls [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#oh_fileshare_checkpersistentpermission OH_FileShare_CheckPersistentPermission].
Deactivates file or folder permissions from ''policies''. The success of the action can be determined from [[ActionResult_Class|ActionResult]].


To persist permission, use [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#persistPermission|persistPermission]]().
This function calls [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#oh_fileshare_deactivatepermission OH_FileShare_DeactivatePermission].


'''See also''' [[Qt_for_HarmonyOS/qtohosextras_doc/CheckResult_Class|CheckResult]], [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicy_Class|PathPolicy]], and [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#persistPermission|persistPermission]]().
To activate permission, use [[#activatePermission|activatePermission()]].


<span id="deactivatePermission"></span>
'''See also:''' [[ActionResult_Class|ActionResult]], [[PathPolicy_Struct|PathPolicy]], and [[#activatePermission|activatePermission()]].
=== deactivatePermission ===


<syntaxhighlight lang="cpp">
=== <span id="persistPermission"></span>QSharedPointer<ActionResult> FileShare::persistPermission(const QList<PathPolicy> &''policies'') ===
QSharedPointer<QtOhosExtras::FileShare::ActionResult> FileShare::deactivatePermission(const QList<QtOhosExtras::FileShare::PathPolicy> &''policies'')
</syntaxhighlight>


Deactivates file or folder permissions from ''policies''. The success of the action can be determined from [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]].
Persists file or folder permissions from ''policies''. The success of the action can be determined from [[ActionResult_Class|ActionResult]].


This function calls [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#oh_fileshare_deactivatepermission OH_FileShare_DeactivatePermission].
This function calls [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#oh_fileshare_persistpermission OH_FileShare_PersistPermission]. persistPermission() stores persistence data in the system database. After persistPermission() call, permissions are not yet active. Use [[#activatePermission|activatePermission()]] to activate permissions. persistPermission() must be called at least once before [[#activatePermission|activatePermission()]].


To activate permission, use [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#activatePermission|activatePermission]]().
To revoke a persistent permission, use [[#revokePermission|revokePermission()]].


'''See also''' [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]], [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicy_Class|PathPolicy]], and [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#activatePermission|activatePermission]]().
'''See also:''' [[ActionResult_Class|ActionResult]], [[Qt for HarmonyOS/qtohosextras doc/PathPolicy Class|PathPolicy]], [[#revokePermission|revokePermission()]], and [[#activatePermission|activatePermission()]].


<span id="persistPermission"></span>
=== <span id="qt_getEnumMetaObject"></span>const QMetaObject *FileShare::qt_getEnumMetaObject(QtOhosExtras::FileShare::OperationMode) ===
=== persistPermission ===


<syntaxhighlight lang="cpp">
QSharedPointer<QtOhosExtras::FileShare::ActionResult> FileShare::persistPermission(const QList<QtOhosExtras::FileShare::PathPolicy> &''policies'')
</syntaxhighlight>


Persists file or folder permissions from ''policies''. The success of the action can be determined from [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]].


This function calls [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#oh_fileshare_persistpermission OH_FileShare_PersistPermission]. persistPermission() stores persistence data in the system database. After persistPermission() call, permissions are not yet active. Use [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#activatePermission|activatePermission]]() to activate permissions. persistPermission() must be called at least once before [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#activatePermission|activatePermission]]().
=== <span id="qt_getEnumName"></span>const char *FileShare::qt_getEnumName(QtOhosExtras::FileShare::OperationMode) ===


To revoke a persistent permission, use [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#revokePermission|revokePermission]]().


'''See also''' [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]], [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicy_Class|PathPolicy]], [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#revokePermission|revokePermission]](), and [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#activatePermission|activatePermission]]().


<span id="qt_getEnumMetaObject"></span>
=== <span id="revokePermission"></span>QSharedPointer<ActionResult> FileShare::revokePermission(const QList<PathPolicy> &''policies'') ===
=== <span id="qt_getEnumMetaObject"></span>const <span class="type">[[../qtcore/qmetaobject.html|QMetaObject]]</span> *FileShare::<span class="name">qt_getEnumMetaObject</span>(''QtOhosExtras::FileShare::OperationMode'') ===


<span id="qt_getEnumName"></span>
Revokes file or folder permissions from ''policies''. The success of the action can be determined from [[ActionResult_Class|ActionResult]].
=== <span id="qt_getEnumName"></span>const <span class="type">char</span> *FileShare::<span class="name">qt_getEnumName</span>(''QtOhosExtras::FileShare::OperationMode'') ===


<span id="revokePermission"></span>
This function calls [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#oh_fileshare_revokepermission OH_FileShare_RevokePermission].
=== revokePermission ===


<syntaxhighlight lang="cpp">
To persist permission, use [[#persistPermission|persistPermission()]].
QSharedPointer<QtOhosExtras::FileShare::ActionResult> FileShare::revokePermission(const QList<QtOhosExtras::FileShare::PathPolicy> &''policies'')
</syntaxhighlight>


Revokes file or folder permissions from ''policies''. The success of the action can be determined from [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]].
'''See also:''' [[ActionResult_Class|ActionResult]], [[Qt for HarmonyOS/qtohosextras doc/PathPolicy Class|PathPolicy]], and [[#persistPermission|persistPermission()]].


This function calls [https://developer.huawei.com/consumer/en/doc/harmonyos-references-V5/file_share-V5#oh_fileshare_revokepermission OH_FileShare_RevokePermission].
=== <span id="operator-7c"></span>QFlags<OperationModes::enum_type> FileShare::operator|(OperationModes::enum_type ''f1'', OperationModes::enum_type ''f2'') ===


To persist permission, use [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#persistPermission|persistPermission]]().


'''See also''' [[Qt_for_HarmonyOS/qtohosextras_doc/ActionResult_Class|ActionResult]], [[Qt_for_HarmonyOS/qtohosextras_doc/PathPolicy_Class|PathPolicy]], and [[Qt_for_HarmonyOS/qtohosextras_doc/FileShare_Namespace#persistPermission|persistPermission]]().


<span id="operator-7c"></span>
=== <span id="operator-7c-1"></span>QFlags<OperationModes::enum_type> FileShare::operator|(OperationModes::enum_type ''f1'', QFlags<OperationModes::enum_type> ''f2'') ===
=== Function ===


<syntaxhighlight lang="cpp">
QFlags<OperationModes::enum_type> FileShare::operator|(OperationModes::enum_type ''f1'', OperationModes::enum_type ''f2'')
</syntaxhighlight>


<span id="operator-7c-1"></span>
=== Function ===


<syntaxhighlight lang="cpp">
=== <span id="operator-7c-2"></span>QIncompatibleFlag FileShare::operator|(OperationModes::enum_type ''f1'', int ''f2'') ===
QFlags<OperationModes::enum_type> FileShare::operator|(OperationModes::enum_type ''f1'', QFlags<OperationModes::enum_type> ''f2'')
</syntaxhighlight>


<span id="operator-7c-2"></span>
=== <span id="operator-7c-2"></span><span class="type">[[../qtcore/qincompatibleflag.html|QIncompatibleFlag]]</span> FileShare::<span class="name">operator|</span>(<span class="type">OperationModes::enum_type</span> ''f1'', <span class="type">int</span> ''f2'') ===




</div>
[[Category:Qt for HarmonyOS]]

Latest revision as of 08:12, 29 January 2026

< Qt Ohos Extras C++ Classes

FileShare Namespace

The FileShare to expose file permission API. More...

Header: #include <FileShare>
qmake: QT += ohosextras
Since: Qt 5.12.12

Classes

class ActionResult
class CheckResult
class PathPolicy
class PathPolicyCheckResult
class PathPolicyErrorInfo

Types

enum OperationMode { Read, Write }
flags OperationModes
enum PathPolicyError { Unknown, PersistenceForbidden, InvalidMode, InvalidPath, PermissionNotPersisted }

Functions

QSharedPointer<QtOhosExtras::FileShare::ActionResult> activatePermission(const QList<QtOhosExtras::FileShare::PathPolicy> &policies)
QSharedPointer<QtOhosExtras::FileShare::CheckResult> checkPersistent(const QList<QtOhosExtras::FileShare::PathPolicy> &policies)
QSharedPointer<QtOhosExtras::FileShare::ActionResult> deactivatePermission(const QList<QtOhosExtras::FileShare::PathPolicy> &policies)
QSharedPointer<QtOhosExtras::FileShare::ActionResult> persistPermission(const QList<QtOhosExtras::FileShare::PathPolicy> &policies)
const QMetaObject * qt_getEnumMetaObject(QtOhosExtras::FileShare::OperationMode)
const char * qt_getEnumName(QtOhosExtras::FileShare::OperationMode)
QSharedPointer<QtOhosExtras::FileShare::ActionResult> revokePermission(const QList<QtOhosExtras::FileShare::PathPolicy> &policies)
QFlags<OperationModes::enum_type> operator\|(OperationModes::enum_type f1, OperationModes::enum_type f2)
QFlags<OperationModes::enum_type> operator\|(OperationModes::enum_type f1, QFlags<OperationModes::enum_type> f2)
QIncompatibleFlag operator\|(OperationModes::enum_type f1, int f2)

Detailed Description

The FileShare to expose file permission API.

This API uses file system paths, which differ from the URIs used internally by HarmonyOS. For example, the path

/data/storage/el1/bundle/entry/resources/resfile/test.txt

will be converted to the URI

file://com.your.example/data/storage/el1/bundle/entry/resources/resfile/test.txt

, where

com.your.example

is app bundle name.

To learn more about file paths and URIs in HarmonyOS, see sandbox documentation.

Warning: This API relies on the underlying OHOS implementation. The following functions: persistPermission(), revokePermission(), activatePermission(), deactivatePermission(), and checkPersistent() may be unavailable on some devices. Additionally, there may be limitations on the maximum number of policies, and certain permissions may need to be explicitly granted to the application.

For more details and limitations, refer to the API documentation.

Type Documentation

enum FileShare::OperationMode

flags FileShare::OperationModes

Defines permissions on path. See FileShare_OperationMode. The flags can be combined using bitwise operations.

Constant Value Description
QtOhosExtras::FileShare::Read
1 << 0
Read on path
QtOhosExtras::FileShare::Write
1 << 1
Write on path

This enum was introduced or modified in Qt 5.12.12.

The OperationModes type is a typedef for QFlags<OperationMode>. It stores an OR combination of OperationMode values.

See also: PathPolicy.

enum FileShare::PathPolicyError

Defines permission policy error codes. See FileShare_PolicyErrorCode.

Constant Value Description
QtOhosExtras::FileShare::Unknown
0 Error type is unknown or not recognized
QtOhosExtras::FileShare::PersistenceForbidden
1 The permission on the path cannot be persisted
QtOhosExtras::FileShare::InvalidMode
2 Invalid operation mode
QtOhosExtras::FileShare::InvalidPath
3 Invalid path
QtOhosExtras::FileShare::PermissionNotPersisted
4 The permission is not persisted

This enum was introduced or modified in Qt 5.12.12.

See also: PathPolicyErrorInfo.

Function Documentation

QSharedPointer<ActionResult> FileShare::activatePermission(const QList<PathPolicy> &policies)

Activates file or folder permissions from policies. The success of the action can be determined from ActionResult.

This function calls OH_FileShare_ActivatePermission. Each time an application is started, its persistent permissions have not been loaded to the memory. Use this function to make a persistent permission active after the application is started. If the activation fails because the permission has not been persisted, use persistPermission() first.

To deactivate an active permission, use deactivatePermission().

See also: ActionResult, PathPolicy, persistPermission(), and deactivatePermission().

QSharedPointer<CheckResult> FileShare::checkPersistent(const QList<PathPolicy> &policies)

Checks if file or folder permissions from policies have persistent permissions. The result check for each file or folder can be determined from CheckResult. CheckResult::PathPolicyCheckResult::result will be set to

true

for each file or folder only for succesufull check and persistent permission found,

false

otherwise.

This function calls OH_FileShare_CheckPersistentPermission.

To persist permission, use persistPermission().

See also: CheckResult, PathPolicy, and persistPermission().

QSharedPointer<ActionResult> FileShare::deactivatePermission(const QList<PathPolicy> &policies)

Deactivates file or folder permissions from policies. The success of the action can be determined from ActionResult.

This function calls OH_FileShare_DeactivatePermission.

To activate permission, use activatePermission().

See also: ActionResult, PathPolicy, and activatePermission().

QSharedPointer<ActionResult> FileShare::persistPermission(const QList<PathPolicy> &policies)

Persists file or folder permissions from policies. The success of the action can be determined from ActionResult.

This function calls OH_FileShare_PersistPermission. persistPermission() stores persistence data in the system database. After persistPermission() call, permissions are not yet active. Use activatePermission() to activate permissions. persistPermission() must be called at least once before activatePermission().

To revoke a persistent permission, use revokePermission().

See also: ActionResult, PathPolicy, revokePermission(), and activatePermission().

const QMetaObject *FileShare::qt_getEnumMetaObject(QtOhosExtras::FileShare::OperationMode)

const char *FileShare::qt_getEnumName(QtOhosExtras::FileShare::OperationMode)

QSharedPointer<ActionResult> FileShare::revokePermission(const QList<PathPolicy> &policies)

Revokes file or folder permissions from policies. The success of the action can be determined from ActionResult.

This function calls OH_FileShare_RevokePermission.

To persist permission, use persistPermission().

See also: ActionResult, PathPolicy, and persistPermission().

QFlags<OperationModes::enum_type> FileShare::operator|(OperationModes::enum_type f1, OperationModes::enum_type f2)

QFlags<OperationModes::enum_type> FileShare::operator|(OperationModes::enum_type f1, QFlags<OperationModes::enum_type> f2)

QIncompatibleFlag FileShare::operator|(OperationModes::enum_type f1, int f2)