Перейти к основному содержанию

WP Media Folder Addon: OneDrive Business Integration

1. Вход в OneDrive Business из WP Media Folder

Для подключения учетной записи OneDrive Business в WP Media Folder, перейдите в меню Настройки > WP Media Folder > Облачное и медиа выгрузка > Облачные коннекторы > OneDrive Business раздел

Сначала вы можете установить миниатюру для изображений.

Создать миниатюры изображений: Эта опция будет генерировать миниатюры изображений и сохранять их в вашем облачном аккаунте. Миниатюры изображений будут создаваться согласно WordPress Thing настройкам и использоваться при вставке изображений (для повышения производительности)

 

generate-image-thumbnail-

 

Пожалуйста, выберите ваш Тип ссылки на медиа:

  • Публичная ссылка: создать публично доступную ссылку для ваших файлов и установить соответствующие права на облачные файлы (Общая ссылка)
  • Приватная ссылка: AJAX ссылка, скрыть облачную ссылку, чтобы сохранить оригинальные права доступа к вашему файлу 

 

media-link-type

 

Затем вы можете подключить учетную запись OneDrive Business в автоматическом или ручном режиме:

Автоматический режим

С этого момента вы можете сэкономить много времени, подключаясь к серверу OneDrive. На OneDrive Business разделе нажмите на Connect OneDrive Business кнопку.

 

connect-auto-onedrive-business

 

Затем выполните следующие шаги, чтобы завершить подключение.

 

connected-auto-onedrive-business

 

Это так быстро, верно? Да, мы знаем это. :) 

 

Ручной режим

С учётными данными из предыдущего шага, в разделе OneDrive Business, вставьте следующее в поля формы:

  • Идентификатор клиента
  • Секрет клиента

 

credentials-copy-business

 

После этого вы сохраняете конфигурацию и нажимаете Connect OneDrive Business кнопку.

 

connect-onedrive-business

 

Вам потребуется подтвердить авторизацию доступа, чтобы предоставить доступ к WordPress Thing; просто нажмите Да в новом окне.

 

авторизация‑приложения

 

Подключение должно быть успешным ☺ Если оно успешно, вы можете создавать папки и подпапки в OneDrive Business и в WP Media Folder — всё будет синхронизировано автоматически!

2. Как это работает? Что я могу сделать с OneDrive Business?

Как это работает? 

WP Media Folder создаст корневую папку на вашем OneDrive Business с именем сайта.

 

редактировать-onedrive-business-из-wordpress thing

 

Все папки и подпапки, добавленные в WP Media Folder OneDrive Business, будут синхронизированы в этой папке (WP Media Folder - {sitename}). И наоборот, все ваши медиа из этого корневой папки на OneDrive Business будут синхронизированы в вашу медиатеку на WordPress Thing.

 

Какие направления синхронизации?

Это работает в обоих направлениях! Вы можете добавить файл в OneDrive Business и увидеть его в WP Media Folder, либо добавить файл в WP Media Folder и увидеть его в OneDrive Business. Это также означает, что вы можете управлять файлами WP Media Folder с вашего компьютера, используя программное обеспечение синхронизации OneDrive.

Интеграция WP Media Folder с OneDrive Business позволяет выполнять 3 типа действий с вашими медиа‑файлами:

  • Импортировать медиа OneDrive Business в WP Media Folder (работает автоматически после подключения)
  • Импортировать медиа OneDrive Business в медиатеку WordPress Thing

 

Импортировать-Медиа-OneDrive-бизнес

 

  • Вставьте медиа OneDrive Business непосредственно в ваш контент. В этом случае медиа будет загружено в ваш контент из OneDrive Business, а не с вашего сервера.

 

вставить-OneDrive-бизнес-изображение

 

3. Регистрация приложения Microsoft OneDrive Business


Интеграция OneDrive Business распространяется как отдельный аддон. Вам необходимо установить этот аддон (плагин) в дополнение к WP Media Folder. Аддон также включает интеграцию с Google Drive, Google Photo, Dropbox, OneDrive Personal и Amazon S3.

Сначала вам нужен Microsoft Azure App, чтобы подключить ваш веб‑сайт к учетной записи OneDrive Business. Перейдите к https://portal.azure.com/, войдите в систему и нажмите Новая регистрация кнопку.

 

add-microsoft-app

 

В форме регистрации приложения укажите название приложения и скопируйте URL вашего сайта в поле перенаправления URL и нажмите на Регистрация кнопку.

В разделе поддерживаемых типов учетных записей следует выбрать вариант "Учетные записи в любом организационном каталоге (любой каталог Azure AD — многопользовательский) и личные учетные записи Microsoft (например, Skype, Xbox)".
 

register-app-business


 
Вы почти закончили — отсюда у вас есть ID приложения (Client ID), только пароль отсутствует. В левом меню перейдите к Сертификаты & секреты, затем нажмите на Новый клиентский секрет кнопку, чтобы создать её. После этого заполните Описание и установите Срок действия для этого.

 

new-password-1

 

Пароль (Client Secret) генерируется сразу после нажатия на Добавить кнопку; скопируйте его, потому что он вам скоро понадобится.

 

new-password-business

 

Duplicate entry '49263e4176ff53f5ff1efff72d6df4fb-ru' for key 'bk24_linguise_urls.hash_translation' (500 Whoops, looks like something went wrong.)

mysqli_sql_exception

HTTP 500 Whoops, looks like something went wrong.

Duplicate entry '49263e4176ff53f5ff1efff72d6df4fb-ru' for key 'bk24_linguise_urls.hash_translation'

Exception

mysqli_sql_exception

Show exception properties
mysqli_sql_exception {#896
  #sqlstate: "23000"
}
  1. foreach ($urls as $translation => $source) {
  2. $elements[] = '("'.mysqli_real_escape_string($this->_database, Request::getInstance()->getLanguage()).'", "'.mysqli_real_escape_string($this->_database, $source).'", "'.mysqli_real_escape_string($this->_database, $translation).'", "'.md5($source).'", "'.md5($translation).'")';
  3. }
  4. $query .= implode(',', $elements);
  5. $query .= ' ON DUPLICATE KEY UPDATE source=VALUES(source), translation=VALUES(translation), hash_source=VALUES(hash_source), hash_translation=VALUES(hash_translation)';
  6. $this->_database->query($query);
  7. }
  8. public function removeUrls($urls)
  9. {
  10. $query = 'DELETE FROM '.mysqli_real_escape_string($this->_database, $this->_database_table_urls).' WHERE (hash_source) IN ';
  1. foreach ($urls as $translation => $source) {
  2. $elements[] = '("'.mysqli_real_escape_string($this->_database, Request::getInstance()->getLanguage()).'", "'.mysqli_real_escape_string($this->_database, $source).'", "'.mysqli_real_escape_string($this->_database, $translation).'", "'.md5($source).'", "'.md5($translation).'")';
  3. }
  4. $query .= implode(',', $elements);
  5. $query .= ' ON DUPLICATE KEY UPDATE source=VALUES(source), translation=VALUES(translation), hash_source=VALUES(hash_source), hash_translation=VALUES(hash_translation)';
  6. $this->_database->query($query);
  7. }
  8. public function removeUrls($urls)
  9. {
  10. $query = 'DELETE FROM '.mysqli_real_escape_string($this->_database, $this->_database_table_urls).' WHERE (hash_source) IN ';
  1. public function saveUrls($urls) {
  2. if (empty($urls)) {
  3. return;
  4. }
  5. return $this->_database->saveUrls($urls);
  6. }
  7. public function removeUrls($urls) {
  8. if (empty($urls)) {
  9. return;
  1. if (isset($result->url_translations)) {
  2. Defer::getInstance()->defer(function() use ($result) {
  3. $new_urls = $result->url_translations;
  4. $new_urls = get_object_vars($new_urls);
  5. Database::getInstance()->saveUrls((array)$new_urls);
  6. });
  7. }
  8. if (isset($result->urls_untranslated)) {
  9. Defer::getInstance()->defer(function() use ($result) {
Translation->Linguise\Script\Core\{closure}()
  1. }
  2. public function finalize()
  3. {
  4. foreach ($this->_actions as $action) {
  5. call_user_func($action['function'], $action['args']);
  6. }
  7. }
  8. }
  1. Helper::prepareDataDir();
  2. // Finalize defer actions on shutdown
  3. // @codeCoverageIgnoreStart
  4. register_shutdown_function(function() {
  5. Defer::getInstance()->finalize();
  6. Database::getInstance()->close();
  7. });
  8. // @codeCoverageIgnoreEnd
  9. }
Processor->Linguise\Script\Core\{closure}()

Stack Trace

mysqli_sql_exception
mysqli_sql_exception:
Duplicate entry '49263e4176ff53f5ff1efff72d6df4fb-ru' for key 'bk24_linguise_urls.hash_translation'

  at /var/www/staging.joomunited.com/public_html/plugins/system/linguise/vendor/linguise/script-php/src/Databases/Mysql.php:170
  at mysqli->query()
     (/var/www/staging.joomunited.com/public_html/plugins/system/linguise/vendor/linguise/script-php/src/Databases/Mysql.php:170)
  at Linguise\Script\Core\Databases\Mysql->saveUrls()
     (/var/www/staging.joomunited.com/public_html/plugins/system/linguise/vendor/linguise/script-php/src/Database.php:232)
  at Linguise\Script\Core\Database->saveUrls()
     (/var/www/staging.joomunited.com/public_html/plugins/system/linguise/vendor/linguise/script-php/src/Translation.php:119)
  at Linguise\Script\Core\Translation->Linguise\Script\Core\{closure}()
  at call_user_func()
     (/var/www/staging.joomunited.com/public_html/plugins/system/linguise/vendor/linguise/script-php/src/Defer.php:42)
  at Linguise\Script\Core\Defer->finalize()
     (/var/www/staging.joomunited.com/public_html/plugins/system/linguise/vendor/linguise/script-php/src/Processor.php:31)
  at Linguise\Script\Core\Processor->Linguise\Script\Core\{closure}()