1
0
mirror of https://github.com/Bayselonarrend/OpenIntegrations.git synced 2024-12-21 01:50:24 +02:00
OpenIntegrations/docs/en/md/Instructions/Yandex_Disk.md

2.6 KiB

id sidebar_class_name
YandexDisk YandexDisk

<img src={require('../../static/img/APIs/YandexDisk.png').default} width='64px' />

Yandex Disk

This section is dedicated to the library for working with Yandex Disk API. On this page, all the steps necessary to start working are described

Getting started

To start working, you need to obtain an access token for the disk:

  1. Go to app creation page

BF

  1. Enter the service name, select Web services as the platform. You can specify any Redirect URI or select the Insert debugging URL option - it will not be needed for working with the library.

BF

  1. In the Data Access field, add permissions as shown in the screenshot below, then click Create Application

BF

  1. Save ClientID and ClientSecret from the application page

BF

  1. Call the function OPI_YandexID.GetConfirmationCode(), passing ClientID as a parameter. It will return a response from the Yandex server, which will contain the fields: - user_code - you will need to enter in the browser - device_code - you will need to pass to another function - verification_url - the URL that needs to be opened in the browser
    json title="The result of the function GetConfirmationCode(), if convert it to JSON" { "verification_url": "https://ya.ru/device", "user_code": "gjehyruw", "interval": 5, "expires_in": 300, "device_code": "12207cafec1b40ad8d0052af3faf0d12" }

  2. Open the URL from verification_url in the browser. Most likely, it will be https://ya.ru/device. In the field that appears, enter the user_code from step 5

BF

  1. After entering the code in step 6, call the function OPI_YandexID.ConvertCodeToToken(), passing ClientID and ClientSecret from step 4, as well as device_code from step 5. Save the obtained access_token and refresh_token
{
 "token_type": "bearer",
 "refresh_token": "1:Tj6nD2vgE2L8jwSm:YgWjQXPv6_y3e07GW70ig2AOyEXoRVsKKpApGHq2EOg7pfx0MKrXiCrfLBFtzgQawdawdwadad3Sasa9z2H0vSeZKNmZmA",
 "expires_in": 31535956,
 "access_token": "y0_AgAAAABWxxdkAAs0QgAAAAD59cawdawdwadadVKIiwGK__crw"
}

access_token is used in all other functions of the library, and with the help of refresh_token, it can be refreshed when its lifespan is nearing the end (using the function RefreshToken())