# App Storage Statistics > **NOTE**
> > - The initial APIs of this module are supported since API version 8. Newly added APIs will be marked with a superscript to indicate their earliest API version. > - API version 9 is a canary version for trial use. The APIs of this version may be unstable. Obtains storage space information, including the space of built-in and plug-in memory cards, space occupied by different types of data, and space of application data. ## Modules to Import ```js import storagestatistics from "@ohos.storageStatistics"; ``` ## storagestatistics.getTotalSizeOfVolume getTotalSizeOfVolume(volumeUuid: string): Promise<number> Asynchronously obtains the total size of the specified volume. This API uses a promise to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory| Description| | ---------- | ------ | ---- | ---- | | volumeUuid | string | Yes | UUID of the volume.| - Return value | Type | Description | | --------------------- | ---------------- | | Promise<number> | Promise used to return the total size of the volume.| - Example ```js let uuid = ""; storagestatistics.getTotalSizeOfVolume(uuid).then(function(number){ console.info("getTotalSizeOfVolume successfully:"+ number); }).catch(function(err){ console.info("getTotalSizeOfVolume failed with error:"+ err); }); ``` ## storagestatistics.getTotalSizeOfVolume getTotalSizeOfVolume(volumeUuid: string, callback:AsyncCallback<number>):void Asynchronously obtains the total size of the specified volume. This API uses a callback to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory| Description | | ---------- | ------------------------------------ | ---- | -------------------------- | | volumeUuid | string | Yes | UUID of the volume. | | callback | callback:AsyncCallback<number> | Yes | Callback invoked to return the total size of the volume.| - Example ```js let uuid = ""; storagestatistics.getTotalSizeOfVolume(uuid, function(error, number){ // Do something. console.info("getTotalSizeOfVolume successfully:"+ number); }); ``` ## storagestatistics.getFreeSizeOfVolume getFreeSizeOfVolume(volumeUuid: string): Promise<number> Asynchronously obtains the available space of the specified volume. This API uses a promise to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory| Description| | ---------- | ------ | ---- | ---- | | volumeUuid | string | Yes | UUID of the volume.| - Return value | Type | Description | | --------------------- | ------------------ | | Promise<number> | Promise used to return the available space of the volume.| - Example ```js let uuid = ""; storagestatistics.getFreeSizeOfVolume(uuid).then(function(number){ console.info("getFreeSizeOfVolume successfully:"+ number); }).catch(function(err){ console.info("getFreeSizeOfVolume failed with error:"+ err); }); ``` ## storagestatistics.getFreeSizeOfVolume getFreeSizeOfVolume(volumeUuid: string, callback:AsyncCallback<number>):void Asynchronously obtains the available space of the specified volume. This API uses a callback to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory| Description | | ---------- | ------------------------------------ | ---- | ---------------------------- | | volumeUuid | string | Yes | UUID of the volume. | | callback | callback:AsyncCallback<number> | Yes | Callback invoked to return the available space of the volume.| - Example ```js let uuid = ""; storagestatistics.getFreeSizeOfVolume(uuid, function(error, number){ // Do something. console.info("getFreeSizeOfVolume successfully:"+ number); }); ``` ## storagestatistics.getBundleStats9+ getBundleStats(packageName: string): Promise<BundleStats> Asynchronously obtains space information of an application. This API uses a promise to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory| Description | | ----------- | ------ | ---- | -------- | | packageName | string | Yes | Bundle name of the application.| - Return value | Type | Description | | ------------------------------------------ | -------------------------- | | Promise<[Bundlestats](#bundlestats)> | Promise used to return the space information obtained.| - Example ```js let packageName = ""; storagestatistics.getBundleStats(packageName).then(function(BundleStats){ console.info("getBundleStats successfully:"+ JSON.stringify(BundleStats)); }).catch(function(err){ console.info("getBundleStats failed with error:"+ err); }); ``` ## storagestatistics.getBundleStats9+ getBundleStats(packageName: string, callback: AsyncCallback<BundleStats>): void Asynchronously obtains space information of an application. This API uses a callback to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory| Description | | -------- | --------------------------------------------------------- | ---- | ------------------------------------ | | packageName | string | Yes | Bundle name of the application.| | callback | callback:AsyncCallback<[Bundlestats](#bundlestats)> | Yes | Callback invoked to return the space information obtained.| - Example ```js let packageName = ""; storagestatistics.getBundleStats(packageName, function(error, BundleStats){ // Do something. console.info("getBundleStats successfully:"+ JSON.stringify(BundleStats)); }); ``` ## storagestatistics.getCurrentBundleStats9+ getCurrentBundleStats(): Promise Asynchronously obtains space information of the current third-party application. This API uses a promise to return the result. **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics - Return value | Type | Description | | ------------------------------------------ | -------------------------- | | Promise<[Bundlestats](#bundlestats)> | Promise used to return the space information obtained. | - Example ```js let bundleStats = await storageStatistics.getCurrentBundleStats(); console.info("getCurrentBundleStats successfully:"+ JSON.stringify(bundleStats)); ``` ## storagestatistics.getCurrentBundleStats9+ getCurrentBundleStats(callback: AsyncCallback): void Asynchronously obtains space information of the current third-party application. This API uses a callback to return the result. **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics - Parameters | Name | Type | Mandatory | Description | | -------- | --------------------------------------------------------- | ---- | ------------------------------------ | | callback | callback:AsyncCallback<[BundleStats](#bundlestats)> | Yes | Callback invoked to return the space information obtained. | - Example ```js storagestatistics.getCurrentBundleStats(function(error, bundleStats){ // Do something. console.info("getCurrentBundleStats successfully:"+ JSON.stringify(bundleStats)); }); ``` ## BundleStats9+ **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics - Attributes | Name | Type | Description | | --------- | ------ | -------------- | | appSize | number | Size of the application. | | cacheSize | number | Cache size of the application. | | dataSize | number | Total data size of the application.| ## storagestatistics.getTotalSize9+ getTotalSize(): Promise Obtains the total space of the built-in memory card. This API uses a promise to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Return value | Type | Description | | --------------------- | ------------------ | | Promise<number> | Promise used to return the total space of the built-in memory card. | - Example ```js let number = await storageStatistics.getTotalSize(); console.info("getTotalSize successfully:"+ JSON.stringify(number)); ``` ## storagestatistics.getTotalSize9+ getTotalSize(callback: AsyncCallback): void Obtains the total space of the built-in memory card. This API uses a callback to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory | Description | | -------- | ------------------------------------ | ---- | ------------------------ | | callback | callback:AsyncCallback<number> | Yes | Callback invoked to return the total space of the built-in memory card.| - Example ```js storagestatistics.getTotalSize(function(error, number){ // Do something. console.info("getTotalSize successfully:"+ JSON.stringify(number)); }); ``` ## storagestatistics.getFreeSize9+ getFreeSize(): Promise Obtains the available space of the built-in memory card. This API uses a promise to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Return value | Type | Description | | --------------------- | ------------------ | | Promise<number> | Promise used to return the available space of the built-in memory card.| - Example ```js let number = await storageStatistics.getFreeSize(); console.info("getFreeSize successfully:"+ JSON.stringify(number)); ``` ## storagestatistics.getFreeSize9+ getFreeSize(callback: AsyncCallback): void Obtains the available space of the built-in memory card. This API uses a callback to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory| Description | | -------- | ------------------------------------ | ---- | ------------------------- | | callback | callback:AsyncCallback<number> | Yes | Callback invoked to return the available space of the built-in memory card.| - Example ```js storagestatistics.getFreeSize(function(error, number){ // Do something. console.info("getFreeSize successfully:"+ JSON.stringify(number)); }); ``` ## storagestatistics.getSystemSize9+ getSystemSize(): Promise<number> Asynchronously obtains the system space. This API uses a promise to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Return value | Type | Description | | --------------------- | ---------------- | | Promise<number> | Promise used to return the system space obtained.| - Example ```js storagestatistics.getSystemSize().then(function(number){ console.info("getSystemSize successfully:"+ number); }).catch(function(err){ console.info("getSystemSize failed with error:"+ err); }); ``` ## storagestatistics.getSystemSize9+ getSystemSize(callback:AsyncCallback<number>):void Asynchronously obtains the system space. This API uses a callback to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory| Description | | ---------- | ------------------------------------ | ---- | -------------------------- | | callback | callback:AsyncCallback<number> | Yes | Callback used to return the system space obtained.| - Example ```js storagestatistics.getSystemSize(function(error, number){ // Do something. console.info("getSystemSize successfully:"+ number); }); ``` ## storagestatistics.getUserStorageStats9+ getUserStorageStats(userId?: string): Promise<StorageStats> Asynchronously obtains the space occupied by each type of user data. This API uses a promise to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory| Description| | ---------- | ------ | ---- | ---- | | userId | string | No | User ID.
-  Set this parameter to the ID of the user to be queried.
-  If no value is specified, information about the current user is queried.| - Return value | Type | Description | | --------------------- | ---------------- | | Promise<[StorageStats](#StorageStats)> | Promise used to return the information obtained.| - Example ```js let userId = ""; storagestatistics.getUserStorageStats(userId).then(function(StorageStats){ console.info("getUserStorageStats successfully:"+ JSON.stringify(StorageStats)); }).catch(function(err){ console.info("getUserStorageStats failed with error:"+ err); }); ``` ## storagestatistics.getUserStorageStats9+ getUserStorageStats(userId?: string, callback:AsyncCallback<StorageStats>):void Asynchronously obtains the space occupied by each type of user data. This API uses a callback to return the result. **Required permissions**: ohos.permission.STORAGE_MANAGER **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics **System API**: This is a system API and cannot be called by third-party applications. - Parameters | Name | Type | Mandatory| Description | | ---------- | ------------------------------------ | ---- | -------------------------- | | userId | string | No | User ID.
-  Set this parameter to the ID of the user to be queried.
-  If no value is specified, information about the current user is queried. | | callback | callback:AsyncCallback<[StorageStats](#StorageStats)> | Yes | Callback invoked to return the information obtained.| - Example ```js storagestatistics.getUserStorageStats(userId, function(error, StorageStats){ // Do something. console.info("getUserStorageStats successfully:"+ JSON.stringify(StorageStats)); }); ``` ## StorageStats9+ **System capability**: SystemCapability.FileManagement.StorageService.SpatialStatistics - Attributes | Name | Type | Description | | --------- | ------ | -------------- | | total | number | Total space of the built-in memory card. | | audio | number | Space occupied by audio data. | | video | number | Space occupied by video data.| | image | number | Space occupied by image data. | | file | number | Space occupied by files. | | app | number | Space occupied by application data.|