mirror of
https://github.com/Bayselonarrend/OpenIntegrations.git
synced 2025-01-06 03:54:27 +02:00
1a6dd86410
Теперь не номер версии нужно менять только в 1С - в остальных местах поменяется сам; не нужно больше определять список модулей в Convert и список библиотек в CLI parse - в конверт подтянется из комментария в bsl, а в CLIP - из OS (как уже делается в доках)
174 lines
7.9 KiB
Plaintext
174 lines
7.9 KiB
Plaintext
// Расположение OS: ./OInt/core/Modules/OPI_GoogleWorkspace.os
|
|
// Библиотека: Google Workspace
|
|
// Команда CLI: google
|
|
|
|
// MIT License
|
|
|
|
// Copyright (c) 2023 Anton Tsitavets
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
// of this software and associated documentation files (the "Software"), to deal
|
|
// in the Software without restriction, including without limitation the rights
|
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
// copies of the Software, and to permit persons to whom the Software is
|
|
// furnished to do so, subject to the following conditions:
|
|
|
|
// The above copyright notice and this permission notice shall be included in all
|
|
// copies or substantial portions of the Software.
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
// SOFTWARE.
|
|
|
|
// https://github.com/Bayselonarrend/OpenIntegrations
|
|
|
|
// BSLLS:LatinAndCyrillicSymbolInWord-off
|
|
// BSLLS:IncorrectLineBreak-off
|
|
|
|
// Раскомментировать, если выполняется OneScript
|
|
#Использовать "../../tools"
|
|
|
|
#Область ПрограммныйИнтерфейс
|
|
|
|
// Сформировать ссылку получения кода
|
|
// Возвращает URL для авторизации в браузере
|
|
//
|
|
// Параметры:
|
|
// ClientID - Строка - Client ID - id
|
|
// Calendar - Булево - разрешение на методы Calendar - calendar
|
|
// Drive - Булево - разрешение на методы Drive - drive
|
|
// Sheets - Булево - разрешение на методы Sheets - sheets
|
|
//
|
|
// Возвращаемое значение:
|
|
// Строка - Ссылка получения кода
|
|
Функция СформироватьСсылкуПолученияКода(Знач ClientID
|
|
, Знач Calendar = Истина
|
|
, Знач Drive = Истина
|
|
, Знач Sheets = Истина) Экспорт
|
|
|
|
OPI_ПреобразованиеТипов.ПолучитьСтроку(ClientID);
|
|
OPI_ПреобразованиеТипов.ПолучитьБулево(Calendar);
|
|
OPI_ПреобразованиеТипов.ПолучитьБулево(Sheets);
|
|
OPI_ПреобразованиеТипов.ПолучитьБулево(Drive);
|
|
|
|
URL = "https://accounts.google.com/o/oauth2/auth";
|
|
|
|
ПараметрыURL = Новый Структура;
|
|
ПараметрыURL.Вставить("response_type", "code");
|
|
ПараметрыURL.Вставить("client_id" , ClientID);
|
|
ПараметрыURL.Вставить("redirect_uri" , "http://localhost");
|
|
ПараметрыURL.Вставить("access_type" , "offline");
|
|
ПараметрыURL.Вставить("scope" , ПолучитьСписокРазрешений(Calendar, Drive, Sheets));
|
|
|
|
URL = URL + OPI_Инструменты.ПараметрыЗапросаВСтроку(ПараметрыURL);
|
|
|
|
Возврат URL;
|
|
|
|
КонецФункции
|
|
|
|
// Получить токен по коду
|
|
// Получает токен по коду из авторизации в бразуере
|
|
//
|
|
// Параметры:
|
|
// ClientID - Строка - Client ID - id
|
|
// ClientSecret - Строка - Client secret - secret
|
|
// Code - Строка - Code из браузера - code
|
|
//
|
|
// Возвращаемое значение:
|
|
// Соответствие Из КлючИЗначение - сериализованный JSON ответа от Google
|
|
Функция ПолучитьТокенПоКоду(Знач ClientID, Знач ClientSecret, Знач Code) Экспорт
|
|
|
|
OPI_ПреобразованиеТипов.ПолучитьСтроку(ClientID);
|
|
OPI_ПреобразованиеТипов.ПолучитьСтроку(ClientSecret);
|
|
OPI_ПреобразованиеТипов.ПолучитьСтроку(Code);
|
|
|
|
URL = "https://accounts.google.com/o/oauth2/token";
|
|
|
|
ПараметрыURL = Новый Структура;
|
|
ПараметрыURL.Вставить("grant_type" , "authorization_code");
|
|
ПараметрыURL.Вставить("client_id" , ClientID);
|
|
ПараметрыURL.Вставить("client_secret", ClientSecret);
|
|
ПараметрыURL.Вставить("redirect_uri" , "http://localhost");
|
|
ПараметрыURL.Вставить("code" , Code);
|
|
|
|
Ответ = OPI_Инструменты.Post(URL, ПараметрыURL, , Ложь);
|
|
|
|
Возврат Ответ;
|
|
|
|
КонецФункции
|
|
|
|
// Обновить токен
|
|
// Обновляет токен по Refresh token
|
|
//
|
|
// Параметры:
|
|
// ClientID - Строка - Client ID - id
|
|
// ClientSecret - Строка - Client secret - secret
|
|
// RefreshToken - Строка - Refresh token - refresh
|
|
//
|
|
// Возвращаемое значение:
|
|
// Соответствие Из КлючИЗначение - сериализованный JSON ответа от Google
|
|
Функция ОбновитьТокен(Знач ClientID, Знач ClientSecret, Знач RefreshToken) Экспорт
|
|
|
|
OPI_ПреобразованиеТипов.ПолучитьСтроку(ClientID);
|
|
OPI_ПреобразованиеТипов.ПолучитьСтроку(ClientSecret);
|
|
OPI_ПреобразованиеТипов.ПолучитьСтроку(RefreshToken);
|
|
|
|
URL = "https://accounts.google.com/o/oauth2/token";
|
|
|
|
ПараметрыURL = Новый Структура;
|
|
ПараметрыURL.Вставить("grant_type" , "refresh_token");
|
|
ПараметрыURL.Вставить("client_id" , ClientID);
|
|
ПараметрыURL.Вставить("client_secret", ClientSecret);
|
|
ПараметрыURL.Вставить("refresh_token", RefreshToken);
|
|
|
|
Ответ = OPI_Инструменты.Post(URL, ПараметрыURL, , Ложь);
|
|
|
|
Возврат Ответ;
|
|
|
|
КонецФункции
|
|
|
|
#КонецОбласти
|
|
|
|
#Область СлужебныйПрограммныйИнтерфейс
|
|
|
|
Функция ПолучитьЗаголовокАвторизации(Знач Токен) Экспорт
|
|
|
|
OPI_ПреобразованиеТипов.ПолучитьСтроку(Токен);
|
|
|
|
Заголовки = Новый Соответствие;
|
|
Заголовки.Вставить("Authorization", "Bearer " + Токен);
|
|
|
|
Возврат Заголовки;
|
|
|
|
КонецФункции
|
|
|
|
#КонецОбласти
|
|
|
|
#Область СлужебныеПроцедурыИфункции
|
|
|
|
Функция ПолучитьСписокРазрешений(Calendar, Drive, Sheets)
|
|
|
|
МассивРазрешений = Новый Массив;
|
|
|
|
Если Calendar Тогда
|
|
МассивРазрешений.Добавить("https://www.googleapis.com/auth/calendar");
|
|
КонецЕсли;
|
|
|
|
Если Drive Тогда
|
|
МассивРазрешений.Добавить("https://www.googleapis.com/auth/drive");
|
|
КонецЕсли;
|
|
|
|
Если Sheets Тогда
|
|
МассивРазрешений.Добавить("https://www.googleapis.com/auth/spreadsheets");
|
|
КонецЕсли;
|
|
|
|
Возврат СтрСоединить(МассивРазрешений, " ");
|
|
|
|
КонецФункции
|
|
|
|
#КонецОбласти
|