1000 FAQ, 500 tutoriales y vídeos explicativos. ¡Aquí sólo hay soluciones!
Importar datos a kDrive desde iCloud
Esta guía detalla cómo importar datos iCloud utilizando rClone en kDrive Infomaniak.
COMPATIBILIDAD my kSuite ✗ | my kSuite+ ✗ ✔= Oferta compatible | ✗= No disponible |
Prólogo
- Como Apple no ofrece una API como sus competidores, una solución para recuperar los documentos de un iCloud Drive es instalar la app kDrive macOS para sincronizar la carpeta icloud que debe estar en tu biblioteca. La guía a continuación ofrece una alternativa sólida.
- kDrive soporta la carga de streaming de rclone a través de WebDAV, hasta 50 Go (extensible a 100 Go) para evitar abusos, con gestión automática de errores si se supera el límite sin especificar previamente el tamaño a través de
Content-Length
.
1. Configurar rclone para acceder a los drives
Instalación de rclone en tu ordenador
Existe una versión de rclone con interfaz gráfica (GUI) pero también es posible hacerlo mediante la línea de comandos (CLI):
- Instale rclone desde una aplicación de tipo
Terminal
en tu dispositivo, escribiendo el siguiente comando completo:sudo -v ; curl https://rclone.org/install.sh | sudo bash
- Introduzca la contraseña de su sesión en su ordenador para comenzar la instalación:
- Consulte la guía oficial de instalación si es necesario.
Configuración del disco remoto (iCloud) en rclone
- Una vez instalado rclone, ingrese el comando
rclone config
.- Consulte el guía oficial de configuración si es necesario.
- Luego, elija configurar una nueva importación remota respondiendo
n
paraNew remote
. - Nombra el disco remoto, por ejemplo
appledrive
: - Luego, elija el tipo de disco a importar respondiendo
iclouddrive
que corresponde a iCloud Drive entre las opciones propuestas. - Indique a rclone el
apple_id
ingresando tu Apple ID (generalmente una dirección de correo electrónico). - Elige usar tu propia contraseña vinculada a la cuenta Apple ID (
y
). - Introduzca su contraseña dos veces cuando se le solicite:
- Responda “No”
n
a la pregunta sobre la “configuración avanzada”. - Una ventana en su dispositivo debe abrirse para advertirle de una conexión remota; autorícela:
- Se debe abrir una ventana en su dispositivo con un código de autenticación de dos factores; cópielo:
- Pega el código cuando rclone te lo pide.
- Responda “Sí”
y
a la última pregunta si toda la información presentada es correcta.
Configuración del disco de destino (kDrive) en rclone
Es posible actuar directamente sobre el archivo de configuración de rclone pegando tu configuración kDrive en el formato, por ejemplo:
[kDrive]
type = webdav
url = https://kDrive_ID_HERE.connect.kdrive.infomaniak.com/
vendor = other
user = user@email.com
pass = PASSWORD_HERE_OR_APP_PASSWORD_IF_2FA
Pero aquí está cómo proceder paso a paso, como en la configuración anterior:
- Siempre en la terminal, ingrese
n
para una nueva configuración de disco y escriba el nombrekDrive
para reconocer su disco de destino: - Luego, elija el tipo de disco a importar respondiendo
webdav
que corresponde a una configuración WebDAV entre las opciones propuestas. - Ingrese la siguiente información:
url
= el acceso directo a kDrive (consulte este otro guía sobre el ID kDrive para la URL de conexión)vendor
= rclone (la opción n°6)user
= correo electrónico de conexión a la cuenta de usuario Infomaniak
- Responda “Sí”
y
a la pregunta sobre la contraseña y luego ingrese la contraseña:- contraseña de aplicación en caso de autenticación doble activada o la de su cuenta de usuario Infomaniak si no ha activado la 2FA.
- Deje vacío el
bearer_token
y luego responda “No”n
a la pregunta sobre la “configuración avanzada”. - Responda “Sí”
y
a la última pregunta y sus 2 discos se mostrarán:
2. Copiar los datos de iCloud a kDrive
Requisitos previos
- Consulte las opciones disponibles en la guía oficial antes de iniciar una importación.
Ejemplo de comando para iniciar una copia de sus datos de iCloud a la raíz de su kDrive:
sudo rclone copy appledrive: kDrive:
¡Esto iniciará instantáneamente la copia de tus carpetas, subcarpetas y contenidos de iCloud al dossier personal de tu kDrive Infomaniak!
Detalles sobre las fechas de sus fotos exportadas
Si exportas tus fotos desde iCloud a kDrive Infomaniak, ten cuidado con las metadatos de fechas. Durante la exportación, las fechas de creación de los archivos pueden ser modificadas y reemplazadas por la fecha de exportación en lugar de la fecha original de la toma de la foto.
Aquí tienes un script para usuarios avanzados que permite restaurar los metadatos correctos de tus archivos a partir de la información EXIF (se recomienda procesar lotes de 7000 fotos como máximo para evitar fallos):
- Descargue ExifTool https://exiftool.org/index.html (Paquete macOS).
- Instale la aplicación permitiendo su apertura de antemano si es necesario:
- Abra Script Editor (ubicado en su carpeta Aplicaciones > Utilidades):
- Haga clic en Nuevo documento.
- Pegue y pegue el largo script propuesto a continuación en la ventana de Script Editor.
- Haga clic en Ejecutar para iniciar el script, se abrirá una ventana:
- Selecciona la carpeta a analizar.
- Deje luego que el script se ejecute, modificará las fechas o escribirá los errores en un archivo
errors.txt
en el escritorio.
El script para copiar y pegar por completo:
-- replace file date with EXIF creation date or date from name after the first dash -
tell application "Finder"
set FolderPath to choose folder with prompt "Select the folder containing the files to update"
my processFolder(FolderPath)
end tell
on processFolder(aFolder)
tell application "Finder"
-- process files:
set fileList to files of aFolder
repeat with eachFile in fileList
-- process a single file
set theFile to eachFile
set AppleScript's text item delimiters to {""}
set fileName to name of eachFile --get the file name
set eachFile to eachFile as string --file path
set hasDate to true --initialize date found flag
try
--get date if available
set photoDate to do shell script "/usr/local/bin/exiftool -DateTimeOriginal " & quoted form of POSIX path of eachFile
if photoDate is "" then set photoDate to do shell script "/usr/local/bin/exiftool -CreationDate " & quoted form of POSIX path of eachFile
if photoDate is "" then set photoDate to do shell script "/usr/local/bin/exiftool -CreateDate " & quoted form of POSIX path of eachFile
if photoDate is "" then
set hasDate to false --check if date was found
end if
on error
set hasDate to false -- error retrieving date
set photoDate to ""
end try
if length of photoDate > 20 then
--format extracted date
set x to (length of photoDate) - 33
set OriginalDate to text -x thru -1 of photoDate
set formattedDate to text 1 thru 5 of OriginalDate
set theYear to formattedDate
set formattedDate to formattedDate & text 7 thru 8 of OriginalDate
set theMonth to text 7 thru 8 of OriginalDate
set formattedDate to formattedDate & text 10 thru 11 of OriginalDate
set theDay to text 10 thru 11 of OriginalDate
set formattedDate to formattedDate & text 13 thru 14 of OriginalDate
set theHour to text 13 thru 14 of OriginalDate
set formattedDate to formattedDate & text 16 thru 17 of OriginalDate
set theMinute to text 16 thru 17 of OriginalDate
set formattedDate to formattedDate & "." & text 19 thru 20 of OriginalDate
set theSecond to text 19 thru 20 of OriginalDate
set newName to theYear & "-" & theMonth & "-" & theDay & " " & theHour & "." & theMinute & "." & theSecond
set testValue to formattedDate as string --check if found date is 000
if testValue is " 000000000000.00" then
set hasDate to false
else
-- set file date to original EXIF date and write to log
do shell script "touch -t " & formattedDate & " " & quoted form of POSIX path of eachFile
set logFile to open for access ((path to desktop folder as text) & "Date Found.txt") as text with write permission
write "Original date found for file: " & OriginalDate & " " & eachFile & return to logFile starting at eof
close access logFile
end if
end if
if hasDate is false then
-- get date from file name after first dash
set nb to ""
set nameDate to ""
set fileName to fileName as string
set savedDelimiters to AppleScript's text item delimiters --save delimiters
set AppleScript's text item delimiters to {"-"} --split on "-"
set nb to offset of "-" in fileName
if nb is not 0 then
set AppleScript's text item delimiters to savedDelimiters --restore delimiters
set nameDate to characters (nb + 1) thru (nb + 8) of fileName as string
set nameDate to nameDate & "1200.00"
set cmd1 to "/usr/local/bin/exiftool -datetimeoriginal=" & nameDate & " " & quoted form of POSIX path of eachFile
set cmd2 to "/usr/local/bin/exiftool -createdate=" & nameDate & " " & quoted form of POSIX path of eachFile
end if
try
-- write date from name to EXIF
do shell script cmd1
do shell script cmd2
do shell script "touch -t " & nameDate & " " & quoted form of POSIX path of eachFile
do shell script "rm " & quoted form of POSIX path of (eachFile & "_original")
on error
-- if date from name is invalid, log the error
set logFile to open for access ((path to desktop folder as text) & "Date Error.txt") as text with write permission
write "No valid date found in file name: " & eachFile & return to logFile starting at eof
close access logFile
end try
end if
end repeat
-- process folders:
set folderList to folders of aFolder
repeat with eachSubfolder in folderList
-- process a subfolder
my processFolder(eachSubfolder)
end repeat
end tell
end processFolder
tell application "Finder"
display dialog "Done! All files processed." buttons {"Close"}
end tell