Difference between revisions of "BCAT services"

From Nintendo Switch Brew
Jump to navigation Jump to search
Line 3: Line 3:
 
= bcat:a, bcat:m, bcat:u, bcat:s =
 
= bcat:a, bcat:m, bcat:u, bcat:s =
 
These are "nn::bcat::detail::ipc::IServiceCreator".
 
These are "nn::bcat::detail::ipc::IServiceCreator".
 +
 +
These were added with [2.0.0+].
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 14: Line 16:
 
| 2 || CreateDeliveryCacheStorageServiceWithApplicationId
 
| 2 || CreateDeliveryCacheStorageServiceWithApplicationId
 
|-
 
|-
| [?-2.3.0] 3 ||  
+
| [2.0.0-2.3.0] 3 ||  
 
|-
 
|-
| [?-2.3.0] 4 ||  
+
| [2.0.0-2.3.0] 4 ||  
 
|}
 
|}
  
Line 23: Line 25:
 
== IBcatService ==
 
== IBcatService ==
 
This is "nn::bcat::detail::ipc::IBcatService".
 
This is "nn::bcat::detail::ipc::IBcatService".
 +
 +
This was added with [2.0.0+].
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 44: Line 48:
 
| 30100 || SetPassphrase
 
| 30100 || SetPassphrase
 
|-
 
|-
| [?-2.3.0] 30101 ||  
+
| [2.0.0-2.3.0] 30101 ||  
 
|-
 
|-
| [?-2.3.0] 30102 ||  
+
| [2.0.0-2.3.0] 30102 ||  
 
|-
 
|-
 
| 30200 || [3.0.0+] RegisterDeliveryTask
 
| 30200 || [3.0.0+] RegisterDeliveryTask
Line 92: Line 96:
 
=== IDeliveryCacheProgressService ===
 
=== IDeliveryCacheProgressService ===
 
This is "nn::bcat::detail::ipc::IDeliveryCacheProgressService".
 
This is "nn::bcat::detail::ipc::IDeliveryCacheProgressService".
 +
 +
This was added with [2.0.0+].
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 104: Line 110:
 
== IDeliveryCacheStorageService ==
 
== IDeliveryCacheStorageService ==
 
This is "nn::bcat::detail::ipc::IDeliveryCacheStorageService".
 
This is "nn::bcat::detail::ipc::IDeliveryCacheStorageService".
 +
 +
This was added with [2.0.0+].
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 118: Line 126:
 
=== IDeliveryCacheFileService ===
 
=== IDeliveryCacheFileService ===
 
This is "nn::bcat::detail::ipc::IDeliveryCacheFileService".
 
This is "nn::bcat::detail::ipc::IDeliveryCacheFileService".
 +
 +
This was added with [2.0.0+].
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 134: Line 144:
 
=== IDeliveryCacheDirectoryService ===
 
=== IDeliveryCacheDirectoryService ===
 
This is "nn::bcat::detail::ipc::IDeliveryCacheDirectoryService".
 
This is "nn::bcat::detail::ipc::IDeliveryCacheDirectoryService".
 +
 +
This was added with [2.0.0+].
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 172: Line 184:
 
= <nowiki>news:a, news:c, news:m, news:p, news:v</nowiki> =
 
= <nowiki>news:a, news:c, news:m, news:p, news:v</nowiki> =
 
These are <nowiki>"nn::news::detail::ipc::IServiceCreator"</nowiki>.
 
These are <nowiki>"nn::news::detail::ipc::IServiceCreator"</nowiki>.
 +
 +
On [1.0.0] these are <nowiki>"nn::news::detail::ipc::INewsService"</nowiki>, see [[#INewsService]].
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 214: Line 228:
 
|-
 
|-
 
| 30500 || [8.0.0+] ? (Takes a total of 8-bytes of input, a handle, and a type-0x9 input buffer, returns an [[#IUnknown2]])
 
| 30500 || [8.0.0+] ? (Takes a total of 8-bytes of input, a handle, and a type-0x9 input buffer, returns an [[#IUnknown2]])
 +
|-
 +
| [1.0.0] 30900 || (No input, returns an [[#INewlyArrivedEventHolder]])
 +
|-
 +
| [1.0.0] 30901 || (No input, returns an [[#INewsDataService]])
 +
|-
 +
| [1.0.0] 30902 || (No input, returns an [[#INewsDatabaseService]])
 
|-
 
|-
 
| 40100 ||  
 
| 40100 ||  
Line 339: Line 359:
 
| 30500 || [6.0.0+] GetLastUploadError
 
| 30500 || [6.0.0+] GetLastUploadError
 
|-
 
|-
| 40100 || IsUserAgreementCheckEnabled
+
| 40100 || [2.0.0+] IsUserAgreementCheckEnabled
 
|-
 
|-
| 40101 || SetUserAgreementCheckEnabled
+
| 40101 || [2.0.0+] SetUserAgreementCheckEnabled
 
|-
 
|-
 
| 90100 || [6.0.0+] ReadAllReportFiles ([1.0.0-5.1.0] GetStorageUsage)
 
| 90100 || [6.0.0+] ReadAllReportFiles ([1.0.0-5.1.0] GetStorageUsage)
 +
|-
 +
| [1.0.0] 90101 ||
 +
|-
 +
| [1.0.0] 90102 ||
 
|-
 
|-
 
| [5.0.0-5.1.0] 90200 ||  
 
| [5.0.0-5.1.0] 90200 ||  

Revision as of 20:58, 16 May 2019

BCAT (Background Content Asymmetric synchronized delivery and Transmission) encompasses a set of content download/upload related services.

bcat:a, bcat:m, bcat:u, bcat:s

These are "nn::bcat::detail::ipc::IServiceCreator".

These were added with [2.0.0+].

Cmd Name
0 CreateBcatService
1 CreateDeliveryCacheStorageService
2 CreateDeliveryCacheStorageServiceWithApplicationId
[2.0.0-2.3.0] 3
[2.0.0-2.3.0] 4

Equivalent to 3DS BOSS(SpotPass). See here for BCAT-content-container.

IBcatService

This is "nn::bcat::detail::ipc::IBcatService".

This was added with [2.0.0+].

Cmd Name
10100 #RequestSyncDeliveryCache
10101 [5.0.0+] RequestSyncDeliveryCacheWithDirectoryName
10200 [5.0.0+] CancelSyncDeliveryCacheRequest
20100 #RequestSyncDeliveryCacheWithApplicationId
20101 [5.0.0+] RequestSyncDeliveryCacheWithApplicationIdAndDirectoryName
20300 [8.0.0+] #GetDeliveryCacheStorageUpdateNotifier
20301 [8.0.0+] #RequestSuspendDeliveryTask
30100 SetPassphrase
[2.0.0-2.3.0] 30101
[2.0.0-2.3.0] 30102
30200 [3.0.0+] RegisterDeliveryTask
30201 [3.0.0+] UnregisterDeliveryTask
30202 [3.0.0+] BlockDeliveryTask
30203 [3.0.0+] UnblockDeliveryTask
30300 [8.0.0+] RegisterSystemApplicationDeliveryTasks
90100 GetDeliveryTaskList
90200 #GetDeliveryList
90201 [3.0.0+] ClearDeliveryCacheStorage
90202 [8.0.0+] ClearDeliveryTaskSubscriptionStatus
90300 [3.0.0+] GetPushNotificationLog

RequestSyncDeliveryCache

No input/output.

[3.0.0+] Now returns an #IDeliveryCacheProgressService.

RequestSyncDeliveryCacheWithApplicationId

Takes a total of 8-bytes of input, no output.

[3.0.0+] Now takes an additional 8-bytes of input, and returns an #IDeliveryCacheProgressService.

GetDeliveryCacheStorageUpdateNotifier

Takes a total of 8-bytes of input, returns an #INotifierService.

RequestSuspendDeliveryTask

Takes a total of 8-bytes of input, returns an #IDeliveryTaskSuspensionService.

GetDeliveryList

Takes a type-0x6 output buffer, returns a total of 4-bytes of output.

[3.0.0+] Now takes a total of 8-bytes of input, and returns an additional 4-bytes of output.

IDeliveryCacheProgressService

This is "nn::bcat::detail::ipc::IDeliveryCacheProgressService".

This was added with [2.0.0+].

Cmd Name
0 GetEvent
1 GetImpl

IDeliveryCacheStorageService

This is "nn::bcat::detail::ipc::IDeliveryCacheStorageService".

This was added with [2.0.0+].

Cmd Name
0 CreateFileService
1 CreateDirectoryService
10 EnumerateDeliveryCacheDirectory

IDeliveryCacheFileService

This is "nn::bcat::detail::ipc::IDeliveryCacheFileService".

This was added with [2.0.0+].

Cmd Name
0 Open
1 Read
2 GetSize
3 GetDigest

IDeliveryCacheDirectoryService

This is "nn::bcat::detail::ipc::IDeliveryCacheDirectoryService".

This was added with [2.0.0+].

Cmd Name
0 Open
1 Read
2 GetCount

INotifierService

This is "nn::bcat::detail::ipc::INotifierService".

Added with [8.0.0+].

Cmd Name Notes
0 GetEvent

IDeliveryTaskSuspensionService

This is "nn::bcat::detail::ipc::IDeliveryTaskSuspensionService".

Added with [8.0.0+].

Cmd Name Notes
0 GetEvent

news:a, news:c, news:m, news:p, news:v

These are "nn::news::detail::ipc::IServiceCreator".

On [1.0.0] these are "nn::news::detail::ipc::INewsService", see #INewsService.

Cmd Name Notes
0 No input, returns an #INewsService.
1 No input, returns an #INewlyArrivedEventHolder.
2 No input, returns an #INewsDataService.
3 No input, returns an #INewsDatabaseService.
4 No input, returns an #IOverwriteEventHolder.

INewsService

This is "nn::news::detail::ipc::INewsService".

Cmd Name
10100
20100
30100
30101 [3.0.0+]
30110 [6.0.0+]
30200
30201 [8.0.0+]
30300
30400 [3.0.0+]
30500 [8.0.0+] ? (Takes a total of 8-bytes of input, a handle, and a type-0x9 input buffer, returns an #IUnknown2)
[1.0.0] 30900 (No input, returns an #INewlyArrivedEventHolder)
[1.0.0] 30901 (No input, returns an #INewsDataService)
[1.0.0] 30902 (No input, returns an #INewsDatabaseService)
40100
40101 [3.0.0+]
40200
40201
90100

INewlyArrivedEventHolder

This is "nn::news::detail::ipc::INewlyArrivedEventHolder".

Cmd Name
0

INewsDataService

This is "nn::news::detail::ipc::INewsDataService".

Cmd Name
0
1
2
3
1001 [6.0.0+]

INewsDatabaseService

This is "nn::news::detail::ipc::INewsDatabaseService".

Cmd Name
0
1
2
3
4
5
1000 [6.0.0+]

IOverwriteEventHolder

This is "nn::news::detail::ipc::IOverwriteEventHolder".

Cmd Name
0

IUnknown2

This was added with [8.0.0+].

Cmd Name
0
1
2
3

prepo:a, prepo:a2, prepo:m, prepo:u, prepo:s

These are "nn::prepo::detail::ipc::IPrepoService".

Cmd Name
10100 SaveReportOld ([1.0.0-5.1.0] SaveReport)
10101 SaveReportWithUserOld ([1.0.0-5.1.0] SaveReportWithUser)
10102 [6.0.0+] SaveReport
10103 [6.0.0+] SaveReportWithUser
10200 RequestImmediateTransmission
10300 GetTransmissionStatus
20100 SaveSystemReport
20101 SaveSystemReportWithUser
20200 [4.0.0+] SetOperationMode
30100 ClearStorage
30200 [6.0.0+] ClearStatistics
30300 [6.0.0+] GetStorageUsage
30400 [6.0.0+] GetStatistics
30401 [6.0.0+] GetThroughputHistory
30500 [6.0.0+] GetLastUploadError
40100 [2.0.0+] IsUserAgreementCheckEnabled
40101 [2.0.0+] SetUserAgreementCheckEnabled
90100 [6.0.0+] ReadAllReportFiles ([1.0.0-5.1.0] GetStorageUsage)
[1.0.0] 90101
[1.0.0] 90102
[5.0.0-5.1.0] 90200
[5.0.0-5.1.0] 90201
[5.0.0-5.1.0] 90300

Data reporting

The "Play Report" (prepo) service uploads system and user information to a cloud server. This includes the following fields:

sys_info
data
application_id
event_id
operation_mode
lc_recorded_at (followed by a timestamp)
nc_recorded_at (followed by a timestamp)
nsa_id
os_version

And the contents of the following file:

is_user_agreement_check_enabled.bin

All the information is periodically uploaded to the following URL:

  • https://receive-%.dg.srv.nintendo.net/post

It also checks the validity of the device's authentication token using the following URL:

  • https://dauth-%.ndas.srv.nintendo.net/v1/device_auth_token