|
|
(6 intermediate revisions by 3 users not shown) |
Line 10: |
Line 10: |
| | forlinux = 1 | | | forlinux = 1 |
| }} | | }} |
| '''cleaninty''' is a PC tool used to communicate with Nintendo's [[wikipedia:SOAP|SOAP]] servers. For a 3DS, these servers deal with managing eShop accounts, downloading eShop titles, and system transfers. It is also the tool used for what is informally known as a "SOAP Transfer". | | '''cleaninty''' is a PC tool used to communicate with Nintendo's [[wikipedia:SOAP|SOAP]] servers. For a 3DS, these servers deal with managing eShop accounts, downloading eShop titles, and system transfers. It is also the tool used for what is informally known as a "SOAP transfer". |
|
| |
|
| == Overview == | | == Overview == |
| | SOAP transfers involve complex functionality. As a result, the following explanation has been divided into two versions: a simplified user-end version, and the technical version. |
| | <br>If you do not care about the technical side of things, you may skip that part, and will still be able to understand how to use cleaninty itself. |
|
| |
|
| There are two pieces of data a 3DS that give it a unique ID to Nintendo's eShop servers: its serial number and its [[3DS:System files|<code>otp.bin</code>]]. If these are copied out of the console and used somewhere else, they can be used to imitate the console - meaning Nintendo's servers can act on commands without the console doing anything on its end.<br> | | <tabber> |
| However, the files cannot communicate on their own, and a connection to Nintendo's servers that acts identically to a console is still needed. This part is where cleaninty comes in. | | |-|Simplified Explanation= |
| | There are two pieces of data in a 3DS that let it talk to Nintendo's eShop servers with a unique ID: its serial number and its [[3DS:System files|<code>otp.bin</code>]]. If these are copied out of the console and used somewhere else, they can be used to imitate the console - meaning Nintendo's servers can act on commands without the console doing anything on its end.<br> |
| | However, the files cannot communicate on their own, and a connection to Nintendo's servers that acts identically to a console is still needed. This is the part cleaninty handles. |
|
| |
|
| The reason this allows for changing eShop regions easily, and at infinite range, are as follows: | | The reason this allows for changing eShop regions easily, and at infinite range, are as follows: |
| * '''Ease of Use''': Tickets for both system software & purchased apps are stored on Nintendo's servers, and some of these tickets are 'sticky' - they refuse to be deleted when trying to delete the console's eShop account. (The most common sticky tickets are from preinstalled games and the [[3dbrew:StreetPass Mii Plaza|Mii Plaza 3.x]] update.) The only way to remove these tickets is to transfer them to another console, and cleaninty is able to move ''only'' the tickets with a single command. | | * '''Ease of Use''': 'Records' of all purchased apps are stored on Nintendo's servers, and some of these records are tied to a separate account that existed before the concept of NNIDs was added - these tickets cannot be removed by normal means, and their presence blocks the console from registering to any other eShop region. (The most common of these tickets is the [[3dbrew:StreetPass Mii Plaza|Mii Plaza 3.x]] update.) The only way to remove these tickets is to transfer them to another console, and cleaninty is able to move ''only'' the legacy account's records by being extremely precise with what commands are and aren't used in the process. |
| * '''Infinite Range:''' System transfers are effectively divided into two parts: the content transfer (done entirely on consoles), and the NNID/title transfer (done entirely on servers).<br>On an actual console, these two must be done at the same time - but if cleaninty sends the commands for a server transfer, it doesn't start a content transfer and thus the consoles do not have to be next to each other. (Technically, this also means a [[3DS:MMM|Manual Movable Transfer]] is the exact opposite of a SOAP transfer.) | | * '''Infinite Range:''' System transfers are effectively divided into three parts: the local content transfer, the NNID transfer, and the legacy account transfer.<br>The local content transfer is the important part here, as on an actual console, these three must be done at the same time - but if cleaninty sends the commands for a legacy account transfer, it doesn't start the content transfer, and thus the consoles do not have to be next to each other. (Technically, this also means a [[3DS:MM|Movable Moveover]] is the exact opposite of a SOAP transfer.) |
| | |
| | |-|Technical Explanation= |
| | First, some background info: there are two accounts for the eShop. |
| | |
| | <ol> |
| | <li>Legacy DeviceID-based accounts, which were in use starting from the first system version but are mostly unused now. |
| | <li>NNID-based accounts, which were introduced by system firmware v7.0 and remain as the main account type. |
| | </ol> |
| | |
| | Additionally, it should be mentioned that there are four main parts of the 3DS eShop's servers that are related to SOAP operations. Connecting to most of them requires the use of two cerificates from the console(s) to verify it's a real console, those certificates being [[3dbrew:ClCertA|ClCertA]] and [[3dbrew:CTCert|CTCert]]. (The needed data from CTCert is stored inside the console's <code>otp.bin</code> [[3dbrew:OTP Registers|from offsets 0x20 to 0x80]].) |
| | |
| | <ol> |
| | <li>ECS: Handles management of NNID accounts and tickets. Requires certificates. |
| | <li>IAS: Handles management of legacy accounts, and has IVS as a sub-service for identity verification (including a stored copy of movable.sed). |
| | <li>CAS: Outputs lists of title metadata, country-related info, and valid currency management options. Requires certificates. |
| | <li>NUS: Downloads of games, updates and system titles. Does '''not''' require certificates for system titles, but does require them for games and updates. |
| | </ol> |
| | |
| | NUS and CAS are not relevant to this specifically, but it is worth knowing about them in general. |
| | |
| | More detailed information on this subject can be found on [https://yifan.lu/2015/04/22/opening-up-cardboard-crafting-an-american-new-3ds-non-xl/ this page.] |
| | |
| | ---- |
| | |
| | The issue that makes system transfers required at all is that legacy accounts are still used in some specific edge cases, when they shouldn't be. |
| | |
| | Specifically, certain titles are not linked to the NNID when purchased/downloaded (the exact cause is still unknown, but a leading theory is that it's because they were delisted from the eShop), and as such, those titles' tickets will instead attach to the legacy account and stay there. The titles that do this will be called '''legacy titles''' for the remainder of this explanation. |
| | |
| | Since the legacy account is meant to be entirely out of use, legacy titles are far harder to remove than 'normal' ones - an NNID can be moved anywhere with relative ease because ECS just throws ownership over and lets the console do proper region checks later, but IAS has significantly more checks with the legacy account. |
| | |
| | Specifically, if there are still titles on the legacy account, then a specific call to IVS to create a new eShop account will fail because it will refuse to mismatch the legacy account's region with its titles. |
| | <br>In this scenario, trying to do a normal system transfer to fix eShop works if done before region changing. But attempting to system transfer after the region change will also fail, because the console(s) detect that they're region changed at the firmware level before it even starts. |
| | <br> And on top of that, the average user does not have a second console to system transfer to in the first place. This is where cleaninty comes in. |
| | |
| | Specifically, cleaninty's role is to create a PC-based connection to Nintendo's servers using the same certificates that validate a normal connection, and then give the user extremely fine precision over which commands they do or don't want to use. Additionally, since it only uses the consoles' files and only talks to the servers, the physical consoles do not have to be present for any part of the process. |
| | |
| | Using this PC-based connection, it is entirely possible to pick and choose in a very specific way that bypasses normal requirements, using two consoles (the "donor" and "recipient"): |
| | |
| | First, the donor must already have a blank legacy account (either through luck or through its own SOAP transfer). This allows it to perform <code>EShopRegionChange</code> freely without restrictions, as there are no legacy titles holding it back. |
| | Once the donor has a blank account, it can <code>EShopRegionChange</code> to match the recipient's eShop account region, and then proceed to take the recipient's account through a <code>SysTransfer</code>. |
| | <br>The reason this works is because when cleaninty does the <code>SysTransfer</code>, the command is run in isolation - so it will not check the consoles' firmware regions, make no requests to ECS, and immediately move the account only after checking they're the same region '''without touching anything else'''. |
| | |
| | Once the legacy account is moved, the recipient will create a new blank account when it next opens the eShop - and in turn, because the new account is made entirely from scratch, this new account's region will match the console's firmware even if it's region-changed. This gives the 'recipient' working eShop access and the ability to change its own region freely - and as the eShop has closed all new purchases and delisted titles cannot be redownloaded from the eShop, it should not be possible for it to receive legacy titles a second time, meaning this fix is effectively permanent. |
| | |
| | Also note that the donor also remains 'free' when this happens, as the transferred legacy titles vanish at some point along the way instead of being properly moved to its account. This means that a donor can be used infinite times, the only limit being the seven-day cooldown between each individual <code>SysTransfer</code>. |
| | |
| | </tabber> |
|
| |
|
|
| |
|
| == Features == | | == Features == |
|
| |
|
| When the required constants have been supplied through <code>SetupConstants</code> and you have the unique data (<code>otp.bin</code> and either <code>SecureInfo.bin</code> or the serial number) of a console, cleaninty can act as that console and do the following: | | When the required constants have been supplied through <code>SetupConstants</code> and you have the unique data (<code>otp.bin</code> and either <code>SecureInfo_A</code> or the serial number) of a console, cleaninty can act as that console and do the following: |
|
| |
|
| * <code>GenJson</code>: Compiles the console's data into a single JSON file. This JSON is required for all other commands except <code>RecoverIVS</code>. | | * <code>GenJson</code>: Compiles the console's data into a single JSON file. This JSON is required for all other commands except <code>RecoverIVS</code>. |
| * <code>CheckReg</code>: Obtains the console's eShop status, eShop region, and any titles attached to its eShop account, then updates the JSON file if any differences in the data are found. | | * <code>CheckReg</code>: Obtains the console's eShop status, eShop region, and any titles attached to its eShop account, then updates the JSON file with the new data. |
| * <code>SysTransfer</code>: Moves the eShop titles of the source console to the target console. This is the secondary part of what is known informally as a "SOAP Transfer". | | * <code>SysTransfer</code>: Moves the eShop titles of the source console to the target console. This is the only needed command for a SOAP transfer if the console has legacy tickets. |
| ** A successful use of this command triggers a 7-day cooldown on system transfers for both consoles, the same as a full system transfer. | | ** A successful use of this command triggers a 7-day cooldown on system transfers for both consoles, the same as a full system transfer. |
| * <code>NNIDTransfer</code>: <u>(Still experimental. Use with caution.)</u> Moves only the NNIDs of the source console to the target console. This is not affected by system transfer cooldowns and does not trigger one. | | * <code>NNIDTransfer</code>: <u>(Still experimental. Use with caution.)</u> Moves only the NNIDs of the source console to the target console. This is not affected by system transfer cooldowns and does not trigger a cooldown. |
| * <code>LastTransfer</code>: Provides the date&time of the given console's last system transfer, the number of transfers it has ever done, and the time at which the current transfer cooldown will expire if there is one active. | | * <code>LastTransfer</code>: Provides the date&time of the given console's last system transfer, the number of transfers it has ever done, and the time at which the current transfer cooldown will expire if there is one active. |
| * <code>GetIVS</code>: Downloads the console's <code>movable.sed</code> from the SOAP servers, if the servers have a stored copy. | | * <code>GetIVS</code>: Downloads the console's stored copy of <code>movable.sed</code> from the SOAP servers, if they have one. |
| * <code>SetIVS</code>: Uploads the chosen JSON's stored <code>movable.sed</code> to the SOAP servers. This will overwrite the current stored movable. | | * <code>SetIVS</code>: Uploads the chosen JSON's stored <code>movable.sed</code> to the SOAP servers. This will overwrite the current stored movable. |
| * <code>RecoverIVS</code>: Tries to recover a console's <code>movable.sed</code> from only its raw <code>otp.bin</code> and eShop region data. | | * <code>RecoverIVS</code>: Tries to recover a console's <code>movable.sed</code> using only its raw <code>otp.bin</code> and eShop region data. |
| * <code>EShopDelete</code>: Deletes the target console's eShop account. | | * <code>EShopDelete</code>: Deletes the target console's eShop account. This is the secondary part of a SOAP transfer if the console has no legacy tickets, as the console will then automatically register an account in the correct region when it next accesses the eShop. |
| * <code>EShopRegionChange</code>: Attempts to delete and then recreate the target console's eShop account for the entered region. This is the main part of a "SOAP Transfer", but after a successful SysTransfer the console will do this automatically when it next connects to the eShop. | | * <code>EShopRegionChange</code>: Attempts to delete and then recreate the target console's eShop account for the entered region. This is the main part of a SOAP transfer if the console has no legacy tickets, but an <code>EShopDelete</code> should still be done afterward. |
| * <code>ETickets</code>/<code>ETicketDownload</code>/<code>ETikTitleDownload</code>: Lists all owned eShop tickets / downloads all tickets / downloads the titles attached to all tickets, respectively, from the given console's eShop account. | | * <code>ETickets</code>/<code>ETicketDownload</code>/<code>ETikTitleDownload</code>: Lists all owned eShop tickets / downloads all tickets / downloads the titles attached to all tickets, respectively, from the given console's eShop account. |
|
| |
|
Line 45: |
Line 96: |
|
| |
|
|
| |
|
| Regardless of your OS, you will need a 3DS with both custom firmware and [[3DS:GodMode9|GodMode9]] installed to dump the vast majority of the files required to do <code>SetupConstants</code> using [https://raw.githubusercontent.com/luigoalma/cleaninty/master/gm9scripts/ExtractSystemElements.gm9 ExtractSystemElements.gm9]. A guide to legally deriving the only constant ''not'' dumped via this method, the [[wikipedia:Advanced_Encryption_Standard|AES]] Constant "C", can be found [https://3ds.goombi.fr/convertMii/0x31.html on this page]. | | Regardless of your OS, you will need a 3DS with both custom firmware and [[3DS:GodMode9|GodMode9]] installed to dump all of the files required to do <code>SetupConstants</code>. The vast majority of them are dumped using [https://raw.githubusercontent.com/luigoalma/cleaninty/master/gm9scripts/ExtractSystemElements.gm9 ExtractSystemElements.gm9], but the the [[wikipedia:Advanced_Encryption_Standard|AES]] Constant "C" is found using the full set of instructions [https://3ds.goombi.fr/convertMii/0x31.html on this page]. |
| {{critical|The AES Constant, along with all other constants used by cleaninty, are copyrighted data. Obtaining them from your own console(s) is fine, but '''do not''' share the constants with anyone else.}} | | {{critical|The AES Constant, along with all other constants used by cleaninty, are copyrighted data. Obtaining them from your own console(s) is fine, but '''do not''' share the constants with anyone else.}} |
| | {{info|These constants are the same on all consoles. Once one set is dumped, you will not need to redump in the future unless you lose access to them.}} |
| === Windows === | | === Windows === |
|
| |
|
Line 71: |
Line 123: |
|
| |
|
| == Usage == | | == Usage == |
| {{critical|Make sure the files for all consoles you compile into a json are accurate before using them in cleaninty, or else the commands may affect a different console than they "should be". | | {{critical|Make sure the files for all consoles you compile into a json are accurate before using them in cleaninty, or else the commands may affect a different console than they "should be" affecting (or simply fail outright). |
|
| |
|
| The easiest way to do this is by checking the serial sticker(s) on the console against the copy of the serial in [[3dbrew:Nandrw/sys/SecureInfo_A|SecureInfo_A]], and if none of the stickers agree with the SecureInfo, also check against the copy in [[3dbrew:Twln/sys/log/inspect.log|inspect.log]].}} | | The easiest way to do this is by checking the serial sticker(s) on the console against the copy of the serial in [[3dbrew:Nandrw/sys/SecureInfo_A|SecureInfo_A]].<br> |
| | If none of the stickers agree with the SecureInfo, also check against the copy in [[3dbrew:Twln/sys/log/inspect.log|inspect.log]] and make sure its listed MAC Address matches the one within firmware by booting the console normally and going into '''System Settings -> Internet Settings -> Other Information -> Confirm MAC Address'''.}} |
|
| |
|
| There is no graphical interface for cleaninty. All commands are ran through the command line. | | There is no graphical interface for cleaninty. All commands are ran through the command line. |
Line 87: |
Line 140: |
| # <code>cleaninty ctr CheckReg -C soap_target.json</code> | | # <code>cleaninty ctr CheckReg -C soap_target.json</code> |
| #* The CheckReg commands are not necessary if you are already certain the donor and target have the same region. | | #* The CheckReg commands are not necessary if you are already certain the donor and target have the same region. |
| # <code>cleaninty ctr EShopRegionChange -C soap_target.json -r (new eShop region - required) -c (country in chosen region - required if region is not JPN/KOR/CHN) -l (language in chosen region - optional)</code> | | # <code>cleaninty ctr EShopRegionChange -C soap_target.json -r (eShop region) -c (eShop country - not required if region is JPN/KOR/CHN)</code> |
| #* If this succeeds, '''stop here'''. The next command is only needed if this one fails. | | #* You can use any region/country for this command other than the one listed in the <code>soap_target.json</code>'s <code>CheckReg</code>. |
| # <code>cleaninty ctr SysTransfer -s soap_target.json -t soap_donor.json</code>
| | # Depending on whether the EShopRegionChange was successful or not, only do '''one''' of the following commands. |
| | <tabber> |
| | |-|Succeeded= |
| | <ol> |
| | <li value="7"><code>cleaninty ctr EShopDelete -C soap_target.json</code></li> |
| | </ol> |
| | |
| | |-|Failed= |
| | <ol> |
| | <li value="7"><code>cleaninty ctr SysTransfer -s soap_target.json -t soap_donor.json</code></li> |
| | </ol> |
| | </tabber> |
| | |
|
| |
|
| === Autosoap script === | | === Autosoap script === |
| | |
| | {{warning|Although this script is far simpler to use than manually inputting commands, errors may still occur during edge cases. Knowledge of the command line will still likely be required to debug if this occurs.}} |
|
| |
|
| If you are inexperienced with the command line or just don't want to type the commands manually every time, there is a {{GitHub|StarlitSkies/autosoap|SOAP bash script}} made by StarlitSkies that heavily simplifies the process. | | If you are inexperienced with the command line or just don't want to type the commands manually every time, there is a {{GitHub|StarlitSkies/autosoap|SOAP bash script}} made by StarlitSkies that heavily simplifies the process. |
| <br>The only downside is that if cleaninty has a nonstandard error, the script will be unable to tell you the exact text of the error - meaning you will need to revert back to manual commands anyway in order to debug.
| |
|
| |
|
| Read the instructions on its page for setup and usage. | | Read the instructions on its page for setup and usage. |
|
| |
|
| [[Category:Nintendo 3DS guides]] | | [[Category:Nintendo 3DS guides]] |