Changes

Jump to navigation Jump to search
6,128 bytes added ,  12:17, 6 July 2017
Line 1: Line 1: −
'''Nintendo Zone''' is the successor to DS Download Stations, offering retailer exclusive content, game videos, screenshots, etc. As of February 6th 2012 demos are available for download, demos are downloaded from the eShop servers and installed to SD card. NZone demos are the same ones available on eShop, these are region-locked as trying to download them from other regions results in an error. USA Best Buy and some other retailers have NZone, this NZone seems to be significantly different from the DS(i) [http://dsibrew.org/wiki/Nintendo_Zone NZone]. Most content available at Best Buy is already available on eShop, like the screenshots/videos, game info etc. The OK Go video is available from NZone however. The OOT video on NZone server is the one from eShop launch like most of the other videos.
+
'''Nintendo Zone''' is the successor to DS Download Stations, offering retailer exclusive content, game videos, screenshots, etc. As of February 6th 2012 demos are available for download, demos are [[NIM_Services|downloaded]] from the eShop servers and installed to SD card. NZone demos are the same ones available on eShop, these are region-locked as trying to download them from other regions results in an error. The 3DS NZone is significantly different from the DS(i) [http://dsibrew.org/wiki/Nintendo_Zone NZone]. Most content available at NZone is already available on eShop, like the screenshots/videos, game info etc.
   −
Like DSi, when an open 3DS detects NZone the hidden(always accessible for USA) NZone title appears and a notification about it appears. Like DSi this title is already stored on NAND, it's just not visible until you're in range of NZone.(doesn't disappear with sdcard removed) When NZone beacons are in range, 3DS only detects NZone when not connected to Internet already. Once connected to a NZone AP, the beacon payload is cached until disconnected from the AP.
+
Like DSi, when an open 3DS detects NZone the originally hidden NZone title appears and a notification about it appears. Like DSi this title is already stored on NAND, originally this title only became accessible from home-menu once the 3DS was in a range of a NZone at least once, however at some point with a system update this title became always-accessible. When NZone beacons are in range, 3DS only detects NZone when not connected to Internet already. Once connected to a NZone AP, the beacon payload is cached until disconnected from the AP.
   −
When modified DSi nzone beacons are broadcasted with the 3DS Best Buy ApNum, DSi launcher won't blink the NZone title icon but the title will still semi-work. NZone title would connect to the server, with buttons for demos, Best Buy, and WFC config displayed, but NZone will display an error a while after selecting "Best Buy" service after a bit of loading.(probably unsupported html tags etc)
+
When modified DSi nzone beacons are broadcasted with the 3DS Best Buy ApNum, DSi launcher won't blink the NZone title icon but the title will still semi-work. The NZone application would connect to the server, with buttons for demos, Best Buy, and WFC config displayed, but NZone will display an error a while after selecting "Best Buy" service after a bit of loading.(probably unsupported html tags etc)
    
== Description ==
 
== Description ==
   −
The NZone browser interface looks very similar to the main 3DS web browser, so it's probably the same as that browser except modified.(and with video support, presumably mobiclip) The NZone beacon encryption is same as before, except some unknown fields in the cleartext was changed where 3DS will only "detect" NZone /w NZone icon blinking/enabled when the beacons' fields are set this way. DSi will not detect these beacons. 3DS can use DS(i) NZone, but only if the NZone title is already enabled. With DS(i) beacons, 3DS connects to Internet but the NZone icon will not blink. However the NZone title will still work once launched. Different URL params are sent to the to the server than DSi, sending the wrong params via curl results in old content being retrieved.
+
The NZone browser interface is similar to the regular [[Internet Browser]], the browser engine used here is completely different however. Unlike the regular [[Internet Browser]] which uses the socket/SSL services directly, the Nintendo Zone application uses the [[HTTP_Services|HTTP]] service instead.
 +
3D stereoscopic videos are supported via html "<media>" tags, for 3D videos the "mediatype" attribute is set to "3D". For 2D videos videos the "mediatype" attribute is set to "2D". This uses Mobiclip with file extension .moflex, the magic number from the first word in the video file is 0xabaa324c(little-endian).
 +
 
 +
The 3DS NZone application immediately uses [[NIMS:CheckSysupdateAvailableSOAP]] once connected to the NZone AP, if an update is available and the user selects "Cancel" in the displayed dialog, the application will stop using the wifi AP.
 +
 
 +
The user-agent used by the Nintendo Zone application is "NintendoZoneViewer/3.1". The URL parameters sent to the dsdl.* HTTPS server are the same as DSi(besides the value of the console-type parameter and the "ver" parameter value), except 3DS also sends additional headers in the request using the same data sent in the URL parameters. The zonebnr server requires three more request headers(extra URL parameters are not needed here), the first of these three headers is "ZoneUserID" where the unknown value is 16 hex-digits(8-bytes in binary). The last two headers of these additional three headers contain data which was originally sent with the dsdl server URL parameters.
 +
 
 +
The NZone beacon encryption is same as before, except some unknown fields in the cleartext was changed where 3DS will only "detect" NZone /w NZone icon blinking/enabled when the beacons' fields are set this way. DSi will not detect these beacons. 3DS can use DS(i) NZone, but only if the NZone title is already enabled. With DS(i) beacons, 3DS connects to Internet but the NZone icon will not blink. However the NZone title will still work once launched.
    
=== Beacon payload format ===
 
=== Beacon payload format ===
This seems to be identical to DS(i) NZone format except for the unknown fields, WPA2 isn't supported. 3DS NZone is not region-locked like DS(i).
+
This seems to be identical to DS(i) NZone format except for the unknown fields. 3DS NZone is not region-locked like DS(i).
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 20: Line 27:  
|  0x00
 
|  0x00
 
|  32
 
|  32
|  AP SSID.
+
|  AP SSID
 
|-
 
|-
 
| 0x20
 
| 0x20
 
| 10
 
| 10
| ApNum, required for connecting to the server. This is used by the server to determine which retailer NZone you're using. First ASCII number char in this param is region, this is also used to determine which server to connect to. Regions: 0) JPN 1) USA 2/3) EUR 4) KOR 5) CHN. This ApNum also contains the state/province in that country and storeID, but these are fixed for USA/EUR NZone deployments.(For JPN NZone those were unique per location)
+
| ApNum, required for connecting to the server. This is used by the server to determine which retailer NZone you're using. Apnum structure: 10 digits or RSSCCTTLLL. R is the decimal region, SS is the decimal ServiceID. CC is the two-letter country-code, TT is the 2-letter country state/province code, and LLL is the decimal locationID. Regions: 0) JPN 1) USA 2/3) EUR 4) KOR 5) CHN. LLL is always zero for non-JPN deployments, however in JPN this is unique per NZone hotspot location.
 
|-
 
|-
 
| 0x2a
 
| 0x2a
Line 32: Line 39:  
| 0x2c
 
| 0x2c
 
| 24
 
| 24
| Some UTF-16 ServiceName. "BestBuy"
+
| Some ServiceName, either in UTF-16 or ASCII
 
|-
 
|-
 
| 0x44
 
| 0x44
 
| 32
 
| 32
| AP crypto key, if any.
+
| AP crypto key, if any
 
|-
 
|-
 
| 0x64
 
| 0x64
 
| 1
 
| 1
| Unknown, not used by the DS(i) client. For 3DS this is 0x1, for DS(i) this is 0x0.
+
| Unknown, not used by the DS(i) client. For 3DS this value varies, for DS(i) this is 0x0.
 
|-
 
|-
 
| 0x65
 
| 0x65
 
| 1
 
| 1
| AP crypto key type: 0) Open 1) WEP-64 2) WEP-128 3) WEP-152
+
| AP crypto key type: 0) Open 1) WEP-64 2) WEP-128 3) WEP-152 4) WPA-PSK (TKIP) 5) WPA2-PSK (TKIP) 6) WPA-PSK (AES) 7) WPA2-PSK (AES) (the encryption key field contains the AP passphrase)
 
|-
 
|-
 
| 0x66
 
| 0x66
 
| 1
 
| 1
| Unknown flags, for 3DS this is 0x1e, for DS(i) this is 0x3. Bits 0 and 1 don't seem to be used by the client. The DS(i) client uses bit2 unknown what for though.
+
| Bit 0: Enables Nintendo Zone content on DS(i)<br>Bit 1: Enables friend list and online gaming<br>Bit 4: Enables Nintendo Zone Viewer on 3DS<br>Bit 7: Blocks the Nintendo eShop<br>Bits 2, 3, 5, 6: Unknown
 
|-
 
|-
 
| 0x67
 
| 0x67
| 5
+
| 1
| Padding.
+
| Bit 0: Blocks the internet browser<br>Bits 1 to 7: Unknown
 +
|-
 +
| 0x68
 +
| 4
 +
| Padding
 
|-
 
|-
 
| 0x6c
 
| 0x6c
 
| 2
 
| 2
| Unknown, with 3DS this is zero but for DS(i) this was 0x428.
+
| Unknown, seems to be always 0x428
 
|-
 
|-
 
| 0x6e
 
| 0x6e
 
| 2
 
| 2
| CRC16 over the whole payload excluding CRC offset, initval is 0.
+
| CRC16 over the whole payload excluding CRC offset, initval is 0
 
|}
 
|}
   Line 66: Line 77:     
=== Hotspot.conf format ===
 
=== Hotspot.conf format ===
The list of NZone hotspots is loaded from "conf:/hotspot.conf" by the AC system applet, where "conf:" is the 000400DB00010502 content archive. This is a CSV file, with LF-style newlines. All of the information stored in the NZone beacon is also stored in this file for each hotspot.
+
The list of NZone hotspots is loaded from "conf:/hotspot.conf" by the AC system applet, where "conf:" is the 000400DB00010502 [[NCCH#CFA|CFA]] archive. This is a CSV file, with LF-style newlines. All of the information stored in the NZone beacon is also stored in this file for each hotspot. This file can list a max of 100 hotspots.(As of title version v1024, hotspot.conf lists 52 hotspots) This format can be parsed by [https://github.com/yellows8/hotspotconf-tool hotspotconf-tool].
   −
Beginning the CSV file is the Interval record and field. Following that is the hotspot records on one line, and the fields for each hotspot on individual lines. Some fields are Base64-encoded, for those the '*' character is used instead of '=' for terminating the Base64 string.
+
Beginning the CSV file is the Interval record and field. Following that is the hotspot records on one line, and the fields for each hotspot on individual lines. Some fields are Base64-encoded, for those the Base64 padding character '*' is used instead of '='.
    
IsBrowser, IsShop, and IsGame might determine whether the [[Internet Browser]], [[eShop]], and games' online multi-player may be used.
 
IsBrowser, IsShop, and IsGame might determine whether the [[Internet Browser]], [[eShop]], and games' online multi-player may be used.
   −
==== Tags ====
+
==== Records ====
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
Tag name
+
Record name
Tag data max len
+
Field max len
Tag data
+
Field data
 
|-
 
|-
 
| Interval
 
| Interval
 
| Arbitrary
 
| Arbitrary
| Decimal interval, unknown
+
| Decimal interval, unknown (usually 20)
 
|-
 
|-
 
| ServiceName
 
| ServiceName
Line 96: Line 107:  
|-
 
|-
 
| SecurityKey
 
| SecurityKey
| 0x40
+
| 0x40 (after decode)
| Hotspot Base64-encoded encryption key
+
| Hotspot Base64-encoded encryption key. For encryption type7, WPA2-PSK is used, however unlike the NZone beacon this is the 0x20-byte WPA-PSK.
 
|-
 
|-
 
| SecurityMode
 
| SecurityMode
Line 130: Line 141:  
| 1
 
| 1
 
| Decimal hotspot flag, can be either 1 or 0
 
| Decimal hotspot flag, can be either 1 or 0
 +
|-
 +
| IsZone
 +
| 1
 +
| Decimal hotspot flag, can be either 1 or 0. This field was added for newer NZone hotspot.conf versions.
 
|}
 
|}
    
=== Hotspots ===
 
=== Hotspots ===
Hotspots not listed in hotspot.conf can only be used via NZone beacons.
+
Hotspots not listed in hotspot.conf can only be used via NZone beacons. The below flags is the combined "IsXXX" fields from hotspot.conf, excluding IsSetToFW. The below hotspot.conf version specifies what title version that hotspot was added to the list, if at all.("Unknown" indicates that the hotspot is present in v1024, but it's unknown whether it was in the previous version.)
 +
 
 +
==== Hotspot list from NZone hotspot.conf ====
 
{| class="wikitable"
 
{| class="wikitable"
! SSID !! Security !! Region || ServiceName !! Listed in hotspot.conf
+
! SSID !! Security !! Region/country || ServiceName !! Flags !! Hotspot.conf version
 +
|-
 +
| wifine || None || JPN  || [http://wifine.jp/ Wifine] || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| NintendoSpotPass1 || None || EUR || Nintendo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| NintendoSpotPass2 || None || EUR || Nintendo || 1, 0, 0, 0, 1 || Unknown
 +
|-
 +
| attwifi || None || USA || AT&T || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| SIMON WiFi || None || USA || Simon Malls || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| noasp01 || None || USA || NOA (Nintendo events) || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| noasp02 || None || USA || NOA (Nintendo events) || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| Telekom || None || EUR (Germany) || Telekom || 1, 0, 0, 0, 1 || Unknown
 +
|-
 +
| Telekom_ICE || None || EUR (Germany) || Telekom || 1, 0, 0, 0, 1 || Unknown
 +
|-
 +
| Guglielmo || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| ASTRO || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| Banca Sella WiFi Clienti || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| confindustria || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| Grand || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| Guglielmo Rimini WiFi || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| GuglielmoDallaRosaPrati || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| Hotels || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| L.Bettolo || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| LecceWireless || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| P.zza Nicoloso || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| PortoDiTrieste || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| Comune-Na Piazze WIFI || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| WiFi_Stampa || None || IT || Guglielmo || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| KPN || None || EUR (NL) || KPN || 1, 1, 0, 1, 1 || Unknown
 +
|-
 +
| METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 +
|-
 +
| MCDONALDS || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 +
|-
 +
| AREA_by_METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 
|-
 
|-
| Wayport_Access || None || USA || McDonalds || Yes
+
| PATaPAIN_by_METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 
|-
 
|-
| attwifi || None || USA || AT&T || Yes
+
| CASINO_by_METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 
|-
 
|-
| BestBuy || None || USA  || BestBuy || No
+
| all_seasons_by_METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 
|-
 
|-
| Boingo Hotspot || None || USA || Boingo || Yes
+
| ADAGIO_by_METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 
|-
 
|-
| SIMON WiFi || None || USA || Simon Malls || Yes
+
| PULLMAN_by_METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 
|-
 
|-
| ibahn || None || USA || iBAHN || Yes
+
| Best_Western_by_METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 
|-
 
|-
| noasp01 || None || USA || NOA (Nintendo events) || Yes
+
| CreditAgricole_by_METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 
|-
 
|-
| noasp02 || None || USA || NOA (Nintendo events) || Yes
+
| IBIS_by_METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 
|-
 
|-
| noasp03 || None || USA || NOA (Nintendo event at GDC) || No
+
| MERCURE_by_METEOR || None || FR || Meteor || 1, 0, 0, 0, 1 || Unknown
 
|-
 
|-
| BELLWIFI@MCDONALDS || None || USA (Canada) || Bell || Yes
+
| Telefonica || None || ES || Telefonica || 1, 0, 0, 1, 1 || Unknown
 
|-
 
|-
| [http://webapp.7spot.jp/howtoconnect.html 7SPOT] || None || JPN || 7-11 || No (LAN-only hostname used)
+
| GOWEXWiFi || None || ES || Gowex || 1, 0, 0, 1, 1 || Unknown
 
|-
 
|-
| [http://www.tsutaya.co.jp/tc/game/deds/about.html TSUTAYA] || None || JPN || TSUTAYA || No
+
| OurenseWiFi || None || ES || Gowex || 1, 0, 0, 1, 1 || Unknown
 
|-
 
|-
| wifine || None || JPN  || [http://wifine.jp/ Wifine] || Yes
+
| RED_LIBRE_AVILES_WILOC || None || ES || Gowex || 1, 0, 0, 1, 1 || Unknown
 
|-
 
|-
| FREESPOT || None || JPN  || FREESPOT || Yes
+
| GIJON WIFI || None || ES || Gowex || 1, 0, 0, 1, 1 || Unknown
 
|-
 
|-
| NintendoSpotPass1 || None || EUR || Nintendo || Yes
+
| 01MIERESWIFI || None || ES || Gowex || 1, 0, 0, 1, 1 || Unknown
 
|-
 
|-
| NintendoSpotPass2 || None || EUR || Nintendo || Yes
+
| 01EibarWifi || None || ES || Gowex || 1, 0, 0, 1, 1 || Unknown
 
|-
 
|-
| [http://www.free-hotspot.com/ free-hotspot.com] || None || EUR || free-hotspot.com || Yes
+
| WIFIBUR || None || ES || Gowex || 1, 0, 0, 1, 1 || Unknown
 
|-
 
|-
| [https://www.thecloud.net/free-wifi/support/faqs/ WiFi Zone - The Cloud] || None || EUR || [https://www.thecloud.net/ The Cloud] || Yes
+
| ValladolidWiFi || None || ES || Gowex || 1, 0, 0, 1, 1 || Unknown
 
|-
 
|-
| [https://www.thecloud.net/free-wifi/support/faqs/ Mycloud] || None || EUR || [https://www.thecloud.net/ The Cloud] || Yes
+
| 01PuertoDelRosarioWiFi || None || ES || Gowex || 1, 0, 0, 1, 1 || Unknown
 
|-
 
|-
| [https://www.thecloud.net/free-wifi/support/faqs/ WLAN Zone - The Cloud] || None || EUR || [https://www.thecloud.net/ The Cloud] || Yes
+
| PT-WIFI || None || PT || PTWiFi || 1, 0, 0, 0, 1 || Unknown
 +
|-
 +
| FON_ZON_FREE_INTERNET || None || PT || ZON || 1, 0, 0, 0, 1 || Unknown
 +
|-
 +
| [https://www.thecloud.net/free-wifi/support/faqs/ WiFi Zone - The Cloud] || None || EUR (GB) || [https://www.thecloud.net/ The Cloud] || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| [https://www.thecloud.net/free-wifi/support/faqs/ Mycloud] || None || EUR (GB) || [https://www.thecloud.net/ The Cloud] || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| [https://www.thecloud.net/free-wifi/support/faqs/ WLAN Zone - The Cloud] || None || EUR (GB) || [https://www.thecloud.net/ The Cloud] || 1, 0, 0, 0, 1 || Unknown
 +
|-
 +
| [https://www.thecloud.net/free-wifi/support/faqs/ _The Cloud] || None || EUR (GB) || [https://www.thecloud.net/ The Cloud] || ? || After v1024
 +
|-
 +
| FREESPOT || None || JPN  || FREESPOT || 1, 1, 1, 1, 1 || Unknown
 +
|-
 +
| [http://www.tsutaya.co.jp/tc/game/deds/about.html TSUTAYA] || None || JPN || TSUTAYA || ? || Unknown
 +
|-
 +
| Wayport_Access || None || USA || McDonalds || ? || After v1024
 +
|-
 +
| Boingo Hotspot || None || USA || Boingo || ? || Unknown
 +
|-
 +
| ibahn || None || USA || iBAHN || ? || Unknown
 +
|-
 +
| BELLWIFI@MCDONALDS || None || USA (Canada) || Bell || ? || After v1024
 +
|-
 +
| [http://www.free-hotspot.com/ free-hotspot.com] || None || EUR || free-hotspot.com || ? || After v1024
 +
|-
 +
| Bestbuy || WPA2-PSK || USA || Bestbuy || || After v1024
 +
|}
 +
 
 +
See also [http://yls8.mtheall.com/ninupdates/3ds_nzonehotspots.php this].
 +
 
 +
==== NZone hotspots only accessible via NZone beacons ====
 +
{| class="wikitable"
 +
! SSID !! Security !! Region/country || ServiceName || Notes
 +
|-
 +
| noasp03 || None || USA || NOA (Nintendo event at GDC) ||
 +
|-
 +
| BestBuy || None || USA  || BestBuy ||
 +
|-
 +
| [http://webapp.7spot.jp/howtoconnect.html 7SPOT] || None || JPN || 7-11 || A LAN-only hostname used is for the retailer's site linked to from the NZone server.
 
|}
 
|}
 +
 +
The above hotspots can only be accessed by broadcasting NZone beacons which contain the encrypted Nintendo tag data.
 +
 +
==== Hotspot Notes ====
    
* These can be configured on you own router/laptop/phone to identify as a Nintendo Zone.
 
* These can be configured on you own router/laptop/phone to identify as a Nintendo Zone.
16

edits

Navigation menu