Backup and restore using ubports-installer



  • @AlainW94 Like this ?
    SWAP.img android-data system-data system.img ubuntu.img user-data



  • @Lakotaubp Yes perfect ! what device is this ?



  • @AlainW94 OnePlus one



  • SWAP.img      lost+found    system.img    user-data
    android-data  system-data   ubuntu.img
    

    Bq M10fhd



  • Nexus 7

    SWAP.img        audio           data            nfc             system-data
    adb             backup          drm             property        system.img
    android-data    bootchart       local           qcks            tombstones
    app             bugreports      lost+found      resource-cache  ubuntu.img
    app-asec        cam_socket1     media           security        user
    app-lib         cam_socket2     mediadrm        ss              user-data
    app-private     dalvik-cache    misc            system
    
    


  • @Lakotaubp Many thanks ! it seems that the backup tool will work for at least those devices (Nexus 7, One Plus, Bq M10, Meizu Pro 5)



  • @AlainW94 Nexus 5

    ~ # ls /data
    SWAP.img      android-data  system-data   system.img    ubuntu.img    user-data
    ~ # 
    
    

    Tried MX4 twice but got device off line message also OP3 no connection but guess that is to be expected at present.



  • @AlainW94 that is a very awesome functionality for the UT phone! Thank you for your work Alain! I also own a Pro5 so looking forward to use such a useful utility. I feel the day my UT phone will become my daily driver again is always closer and closer, thank to committed Community people as you are 🙂



  • Hello, some answers:

    1. the 2 folders /data/user-data and /data/system-data are available on all devices and are the only ones you need to back up. They do not need mounting, but are real folders. You need to be careful with the symlinks though, as they are invalid if the normal OS is not active. So you might get backup errors during this process

    2. The feature is great and much anticipated. Just want to know if the target could be either PC or sd card. Some users might want to have the backup on the internal SD card (and later on the UT recovery could utilize this also to backup/restore, just would need baking it into the code there)

    3. Please get in contact with @NeoTheThird if you didnt do it already, he is the maintainer for the installer and you should coordinate any big features like this with him, to get aligned with his plans for the installer.

    Thanks and happy coding!


  • Administrators

    Hey @AlainW94,

    maintainer of the installer here 👋

    Kudos on how far you've come already, that's really cool! This is very similar to what we had planned in this issue. The commands there should work pretty much on every device with enough storage. Could you maybe open a PR soon, so we can coordinate the code to not conflict with the other things we have planned in the installer?

    Some notes:

    • You might want to avoid streaming output of adb commands to tar directly to the disk of your machine, but rather tar on the device. Even though it'll take up some space on the device, it'll be worth the added stability. Adb is very unreliable when it comes to exit codes and what buffer to write to. You don't want it to silently write "waiting for devices" to your precious backup file and corrupting it without you knowing.
    • You'll need to implement adb pull in the promise-android-tools module. It'd be great if you could open a pr for that rather sooner than later.
    • This is not a small undertaking, so in try to aim to get your changes in early wherever possible to avoid merge conflicts going forward. You might for example want to get your pull animation in now already.
    • Avoid device-specific hacks and workarounds in the installer code. You'll have heard about the config file format introduced in 0.3.x-beta, which aims to pave the way to make the installer code device- and os-agnostic. I could imagine adding another field like actions[], which holds steps like this, to the entry in operating_systems. We might even want to introduce some braking changes to the file strucutre to do this really right.

    Hope i did not overwhelm you, just excited for community contributions to my pet project XD

    If you need any help, hints or pointers, please let me know.

    Thank you!



  • Hi @Flohack: My reply to your answers :

    1. Please try on a Meizu Pro5, if you have the same recovery.img than me, you will see that thoses folders aren't mounted by default, the /data folder is empty. But ok for the other devices.

    2.Thanks ! For now I only write the code to backup on the computer and restore from the computer. Again because I only have a Pro5 as ubuntu phone and while in recovery, the sd card isn't mounted. But this can be done in the code for other devices.

    1. Ok perfect, thanks for the contact ! I'll do that.

    thanks to you for your hint @Flohack



  • Hello @NeoTheThird ! Thanks for being in the game now !
    I would like to open a PR but I have some difficulties to do so, can you give me some hint please ?

    1- I have to admit it, that's a good point, for now I didn't have any issue while doing the backup like this (almost 8 times) but you right, we don't know what could happens during the backup or restore operation (for example with a defective usb cable).

    2- yes, this is how I did, I tried as much as possible to respect your software architecture.

    3 - Yes of course, but need some help witch github, I cannot create a new branch to commit my changes.

    4 - Oh, I didn't know about that config file, I will take a look, thanks!

    I really want to help the community but not by doing wrong things so any hint are welcome.

    Thanks to you !



  • @AlainW94 for working with our repos you typically just fork the project, then push your branch you want to submit and create a pull request from that branch to our base. Thats kinda "workaround" for not being allowed write access to our repos.



  • @AlainW94 regarding the unmounted data partition, how could the installer work on that device then @NeoTheThird ? Do we mount data specifically? I dont have a Pro 5, in fact there are not so many people who own one.



  • @Flohack Many thanks ! this is what I did after reading on it on google.



  • @Flohack own 4 of them and can confirm that is it like that on the 4. have we access to the recovery;img for the pro5 ? if yes I can modify it to have the partitions mounted at startup in the recovery.



  • @AlainW94 No the recovery is the old one from Canonical times, Pro 5, MX 4 and all BQ devices do not have an open tree and we cannot change anything there...



  • @Flohack Ok so we will have to deal with it in the installer


  • Administrators

    Awesome, saw you opened a PR here, i'll give you a code review with some pointers. Really appreciate the work you put into this, i'm confident we can get it done fairly soon 🙂



  • @AlainW94 It should be dealt already with, otherwise how would the installer install anything into /data??


Log in to reply