2017-03-11 19:54:51 +01:00
---
title: downloadFile
description: Asynchronously downloads file from cloud. Updates updateFileProgress will notify about download progress. Update updateFile will notify about successful download
---
## Method: downloadFile
[Back to methods index ](index.md )
2017-06-06 18:39:21 +02:00
YOU CANNOT USE THIS METHOD IN MADELINEPROTO
2017-03-11 19:54:51 +01:00
Asynchronously downloads file from cloud. Updates updateFileProgress will notify about download progress. Update updateFile will notify about successful download
### Params:
| Name | Type | Required | Description |
|----------|:-------------:|:--------:|------------:|
|file\_id|[int](../types/int.md) | Yes|Identifier of file to download|
### Return type: [Ok](../types/Ok.md)
### Example:
```
$MadelineProto = new \danog\MadelineProto\API();
2017-04-10 13:49:32 +02:00
if (isset($token)) { // Login as a bot
2017-06-19 18:56:47 +02:00
$MadelineProto->bot_login($token);
2017-03-11 19:54:51 +01:00
}
2017-04-10 13:49:32 +02:00
if (isset($number)) { // Login as a user
2017-03-11 19:54:51 +01:00
$sentCode = $MadelineProto->phone_login($number);
echo 'Enter the code you received: ';
$code = '';
for ($x = 0; $x < $sentCode['type']['length']; $x++) {
$code .= fgetc(STDIN);
}
$MadelineProto->complete_phone_login($code);
}
$Ok = $MadelineProto->downloadFile(['file_id' => int, ]);
```
2017-07-23 16:11:02 +02:00
Or, if you're using [PWRTelegram ](https://pwrtelegram.xyz ):
### As a bot:
POST/GET to `https://api.pwrtelegram.xyz/botTOKEN/madeline`
Parameters:
* method - downloadFile
2017-07-23 16:33:46 +02:00
* params - {"file_id": int, }
2017-07-23 16:11:02 +02:00
2017-07-23 16:34:36 +02:00
2017-07-23 16:11:02 +02:00
### As a user:
POST/GET to `https://api.pwrtelegram.xyz/userTOKEN/downloadFile`
Parameters:
file_id - Json encoded int
```
2017-03-11 19:54:51 +01:00
Or, if you're into Lua:
```
Ok = downloadFile({file_id=int, })
```