#include "stdafx.h" #include "..\Common\Consoles_App.h" #include "..\User.h" #include "..\..\Minecraft.Client\Minecraft.h" #include "..\..\Minecraft.Client\MinecraftServer.h" #include "..\..\Minecraft.Client\PlayerList.h" #include "..\..\Minecraft.Client\ServerPlayer.h" #include "..\..\Minecraft.World\Level.h" #include "..\..\Minecraft.World\LevelSettings.h" #include "..\..\Minecraft.World\BiomeSource.h" #include "..\..\Minecraft.World\LevelType.h" #include "..\..\Orbis\Network\SonyCommerce_Orbis.h" #include "..\..\Minecraft.World\StringHelpers.h" #include "Network/Orbis_NPToolkit.h" #include "Orbis\Network\SonyRemoteStorage_Orbis.h" #include #include "..\..\Common\Network\Sony\SonyRemoteStorage.h" #include #include #define ORBIS_COMMERCE_ENABLED CConsoleMinecraftApp app; CConsoleMinecraftApp::CConsoleMinecraftApp() : CMinecraftApp() { memset(&m_ThumbnailBuffer,0,sizeof(ImageFileBuffer)); memset(&m_SaveImageBuffer,0,sizeof(ImageFileBuffer)); // memset(&m_ScreenshotBuffer,0,sizeof(ImageFileBuffer)); memset(&ProductCodes,0,sizeof(PRODUCTCODES)); m_bVoiceChatAndUGCRestricted=false; m_bDisplayFullVersionPurchase=false; // #ifdef _DEBUG_MENUS_ENABLED // debugOverlayCreated = false; // #endif m_ProductListA=NULL; m_pRemoteStorage = new SonyRemoteStorage_Orbis; m_bSaveDataDialogRunning = false; m_bOptionsSaveDataDialogRunning=false; m_bPatchAvailableDialogRunning = false; } void CConsoleMinecraftApp::SetRichPresenceContext(int iPad, int contextId) { ProfileManager.SetRichPresenceContextValue(iPad,CONTEXT_GAME_STATE,contextId); } char *CConsoleMinecraftApp::GetProductCode() { return ProductCodes.chProductCode; } char *CConsoleMinecraftApp::GetSaveFolderPrefix() { return ProductCodes.chSaveFolderPrefix; } char *CConsoleMinecraftApp::GetCommerceCategory() { return ProductCodes.chCommerceCategory; } char *CConsoleMinecraftApp::GetTexturePacksCategoryID() { return ProductCodes.chTexturePackID; } char *CConsoleMinecraftApp::GetUpgradeKey() { return ProductCodes.chUpgradeKey; } EProductSKU CConsoleMinecraftApp::GetProductSKU() { return ProductCodes.eProductSKU; } bool CConsoleMinecraftApp::IsJapaneseSKU() { return ProductCodes.eProductSKU == e_sku_SCEJ; } bool CConsoleMinecraftApp::IsEuropeanSKU() { return ProductCodes.eProductSKU == e_sku_SCEE; } bool CConsoleMinecraftApp::IsAmericanSKU() { return ProductCodes.eProductSKU == e_sku_SCEA; } // char *CConsoleMinecraftApp::GetSKUPostfix() // { // return ProductCodes.chSkuPostfix; // } SONYDLC *CConsoleMinecraftApp::GetSONYDLCInfo(char *pchTitle) { wstring wstrTemp=convStringToWstring(pchTitle); AUTO_VAR(it, m_SONYDLCMap.find(wstrTemp)); if(it == m_SONYDLCMap.end()) { app.DebugPrintf("Couldn't find DLC info for %s\n", pchTitle); assert(0); return NULL; } return it->second; } SONYDLC *CConsoleMinecraftApp::GetSONYDLCInfoFromKeyname(char *pchKeyName) { for(AUTO_VAR(it, m_SONYDLCMap.begin()); it != m_SONYDLCMap.end(); ++it) { SONYDLC *pDLCInfo=(*it).second; if(strcmp(pDLCInfo->chDLCKeyname,pchKeyName)==0) { return pDLCInfo; } } return NULL; } #define WRAPPED_READFILE(hFile,lpBuffer,nNumberOfBytesToRead,lpNumberOfBytesRead,lpOverlapped) {if(ReadFile(hFile,lpBuffer,nNumberOfBytesToRead,lpNumberOfBytesRead,lpOverlapped)==FALSE) { return FALSE;}} BOOL CConsoleMinecraftApp::ReadProductCodes() { char chDLCTitle[64]; // 4J-PB - Read the file containing the product codes. This will be different for the SCEE/SCEA/SCEJ builds //HANDLE file = CreateFile("orbis/DLCImages/TP01_360x360.png", GENERIC_READ, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); HANDLE file = CreateFile("orbis/PS4ProductCodes.bin", GENERIC_READ, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); if( file == INVALID_HANDLE_VALUE ) { DWORD error = GetLastError(); app.DebugPrintf("Failed to open ProductCodes.bin with error code %d (%x)\n", error, error); return FALSE; } DWORD dwHigh=0; DWORD dwFileSize = GetFileSize(file,&dwHigh); if(dwFileSize!=0) { DWORD bytesRead; WRAPPED_READFILE(file,ProductCodes.chProductCode,PRODUCT_CODE_SIZE,&bytesRead,NULL); WRAPPED_READFILE(file,ProductCodes.chSaveFolderPrefix,SAVEFOLDERPREFIX_SIZE,&bytesRead,NULL); WRAPPED_READFILE(file,ProductCodes.chCommerceCategory,COMMERCE_CATEGORY_SIZE,&bytesRead,NULL); WRAPPED_READFILE(file,ProductCodes.chTexturePackID,SCE_NP_COMMERCE2_CATEGORY_ID_LEN,&bytesRead,NULL); WRAPPED_READFILE(file,ProductCodes.chUpgradeKey,UPGRADE_KEY_SIZE,&bytesRead,NULL); WRAPPED_READFILE(file,ProductCodes.chSkuPostfix,SKU_POSTFIX_SIZE,&bytesRead,NULL); app.DebugPrintf("ProductCodes.chProductCode %s\n",ProductCodes.chProductCode); app.DebugPrintf("ProductCodes.chSaveFolderPrefix %s\n",ProductCodes.chSaveFolderPrefix); app.DebugPrintf("ProductCodes.chCommerceCategory %s\n",ProductCodes.chCommerceCategory); app.DebugPrintf("ProductCodes.chTexturePackID %s\n",ProductCodes.chTexturePackID); app.DebugPrintf("ProductCodes.chUpgradeKey %s\n",ProductCodes.chUpgradeKey); app.DebugPrintf("ProductCodes.chSkuPostfix %s\n",ProductCodes.chSkuPostfix); // DLC unsigned int uiDLC; WRAPPED_READFILE(file,&uiDLC,sizeof(int),&bytesRead,NULL); for(unsigned int i=0;ichDLCKeyname,sizeof(char)*uiVal,&bytesRead,NULL); WRAPPED_READFILE(file,&uiVal,sizeof(int),&bytesRead,NULL); WRAPPED_READFILE(file,chDLCTitle,sizeof(char)*uiVal,&bytesRead,NULL); app.DebugPrintf("DLC title %s\n",chDLCTitle); WRAPPED_READFILE(file,&pDLCInfo->eDLCType,sizeof(int),&bytesRead,NULL); WRAPPED_READFILE(file,&uiVal,sizeof(int),&bytesRead,NULL); WRAPPED_READFILE(file,pDLCInfo->chDLCPicname,sizeof(char)*uiVal,&bytesRead,NULL); WRAPPED_READFILE(file,&pDLCInfo->iFirstSkin,sizeof(int),&bytesRead,NULL); WRAPPED_READFILE(file,&pDLCInfo->iConfig,sizeof(int),&bytesRead,NULL); // push this into a vector wstring wstrTemp=convStringToWstring(chDLCTitle); m_SONYDLCMap[wstrTemp]=pDLCInfo; } CloseHandle(file); } if(strcmp(ProductCodes.chProductCode, "CUSA00265") == 0) ProductCodes.eProductSKU = e_sku_SCEE; else if(strcmp(ProductCodes.chProductCode, "CUSA00744") == 0) ProductCodes.eProductSKU = e_sku_SCEA; else if(strcmp(ProductCodes.chProductCode, "CUSA00283") == 0) ProductCodes.eProductSKU = e_sku_SCEJ; else { // unknown product ID assert(0); } return TRUE; } void CConsoleMinecraftApp::StoreLaunchData() { } void CConsoleMinecraftApp::ExitGame() { } void CConsoleMinecraftApp::FatalLoadError() { assert(0); } void CConsoleMinecraftApp::CaptureSaveThumbnail() { RenderManager.CaptureThumbnail(&m_ThumbnailBuffer,&m_SaveImageBuffer); } void CConsoleMinecraftApp::GetSaveThumbnail(PBYTE *ppbThumbnailData,DWORD *pdwThumbnailSize,PBYTE *ppbDataImage,DWORD *pdwSizeImage) { // on a save caused by a create world, the thumbnail capture won't have happened if(m_ThumbnailBuffer.Allocated()) { if( ppbThumbnailData ) { *ppbThumbnailData= new BYTE [m_ThumbnailBuffer.GetBufferSize()]; *pdwThumbnailSize=m_ThumbnailBuffer.GetBufferSize(); memcpy(*ppbThumbnailData,m_ThumbnailBuffer.GetBufferPointer(),*pdwThumbnailSize); } m_ThumbnailBuffer.Release(); } else { if( ppbThumbnailData ) { // use the default image StorageManager.GetDefaultSaveThumbnail(ppbThumbnailData,pdwThumbnailSize); } } if(m_SaveImageBuffer.Allocated()) { if( ppbDataImage ) { *ppbDataImage= new BYTE [m_SaveImageBuffer.GetBufferSize()]; *pdwSizeImage=m_SaveImageBuffer.GetBufferSize(); memcpy(*ppbDataImage,m_SaveImageBuffer.GetBufferPointer(),*pdwSizeImage); } m_SaveImageBuffer.Release(); } else { if( ppbDataImage ) { // use the default image StorageManager.GetDefaultSaveImage(ppbDataImage,pdwSizeImage); } } } void CConsoleMinecraftApp::ReleaseSaveThumbnail() { } void CConsoleMinecraftApp::GetScreenshot(int iPad,PBYTE *pbData,DWORD *pdwSize) { } int CConsoleMinecraftApp::GetLocalTMSFileIndex(WCHAR *wchTMSFile,bool bFilenameIncludesExtension,eFileExtensionType eEXT) { return -1; } int CConsoleMinecraftApp::LoadLocalDLCImages() { // 4J-PB - Any local graphic files for the Minecraft Store? unordered_map*pDLCInfoA=app.GetSonyDLCMap(); for( AUTO_VAR(it, pDLCInfoA->begin()); it != pDLCInfoA->end(); it++ ) { SONYDLC * pDLCInfo=(*it).second; LoadLocalDLCImage(pDLCInfo); } return 0; } void CConsoleMinecraftApp::FreeLocalDLCImages() { // 4J-PB - Any local graphic files for the Minecraft Store? unordered_map*pDLCInfoA=app.GetSonyDLCMap(); for( AUTO_VAR(it, pDLCInfoA->begin()); it != pDLCInfoA->end(); it++ ) { SONYDLC * pDLCInfo=(*it).second; if(pDLCInfo->dwImageBytes!=0) { free(pDLCInfo->pbImageData); pDLCInfo->dwImageBytes=0; pDLCInfo->pbImageData=NULL; } } } int CConsoleMinecraftApp::LoadLocalDLCImage(SONYDLC *pDLCInfo) { // load the local file char pchFilename[64]; sprintf(pchFilename,"orbis/DLCImages/%s_360x360.png",pDLCInfo->chDLCPicname); // 4J-PB - Read the file containing the product codes. This will be different for the SCEE/SCEA/SCEJ builds HANDLE hFile = CreateFile(pchFilename, GENERIC_READ, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); if( hFile == INVALID_HANDLE_VALUE ) { app.DebugPrintf("Failed to open %s\n", pchFilename); return FALSE; } DWORD dwHigh=0; pDLCInfo->dwImageBytes = GetFileSize(hFile,&dwHigh); if(pDLCInfo->dwImageBytes!=0) { DWORD dwBytesRead; pDLCInfo->pbImageData=(PBYTE)malloc(pDLCInfo->dwImageBytes); if(ReadFile(hFile,pDLCInfo->pbImageData,pDLCInfo->dwImageBytes,&dwBytesRead,NULL)==FALSE) { // failed free(pDLCInfo->pbImageData); pDLCInfo->dwImageBytes=0; } } CloseHandle(hFile); return 0; } int CConsoleMinecraftApp::LoadLocalTMSFile(char *chTMSFile) { return -1; } int CConsoleMinecraftApp::LoadLocalTMSFile(WCHAR *wchTMSFile) { return -1; } int CConsoleMinecraftApp::LoadLocalTMSFile(WCHAR *wchTMSFile, eFileExtensionType eExt) { return -1; } void CConsoleMinecraftApp::FreeLocalTMSFiles(eTMSFileType eType) { } void CConsoleMinecraftApp::TemporaryCreateGameStart() { ////////////////////////////////////////////////////////////////////////////////////////////// From CScene_Main::OnInit app.setLevelGenerationOptions(NULL); // From CScene_Main::RunPlayGame Minecraft *pMinecraft=Minecraft::GetInstance(); app.ReleaseSaveThumbnail(); ProfileManager.SetLockedProfile(0); pMinecraft->user->name = L"Orbis"; app.ApplyGameSettingsChanged(0); ////////////////////////////////////////////////////////////////////////////////////////////// From CScene_MultiGameJoinLoad::OnInit MinecraftServer::resetFlags(); // From CScene_MultiGameJoinLoad::OnNotifyPressEx app.SetTutorialMode( false ); app.SetCorruptSaveDeleted(false); ////////////////////////////////////////////////////////////////////////////////////////////// From CScene_MultiGameCreate::CreateGame app.ClearTerrainFeaturePosition(); wstring wWorldName = L"TestWorld"; StorageManager.ResetSaveData(); StorageManager.SetSaveTitle(wWorldName.c_str()); bool isFlat = false; int64_t seedValue = BiomeSource::findSeed(isFlat?LevelType::lvl_flat:LevelType::lvl_normal); // 4J - was (new Random())->nextLong() - now trying to actually find a seed to suit our requirements NetworkGameInitData *param = new NetworkGameInitData(); param->seed = seedValue; param->saveData = NULL; app.SetGameHostOption(eGameHostOption_Difficulty,0); app.SetGameHostOption(eGameHostOption_FriendsOfFriends,0); app.SetGameHostOption(eGameHostOption_Gamertags,1); app.SetGameHostOption(eGameHostOption_BedrockFog,1); app.SetGameHostOption(eGameHostOption_GameType,GameType::SURVIVAL->getId()); app.SetGameHostOption(eGameHostOption_LevelType, 0 ); app.SetGameHostOption(eGameHostOption_Structures, 1 ); app.SetGameHostOption(eGameHostOption_BonusChest, 0 ); app.SetGameHostOption(eGameHostOption_PvP, 1); app.SetGameHostOption(eGameHostOption_TrustPlayers, 1 ); app.SetGameHostOption(eGameHostOption_FireSpreads, 1 ); app.SetGameHostOption(eGameHostOption_TNT, 1 ); app.SetGameHostOption(eGameHostOption_HostCanFly, 1); app.SetGameHostOption(eGameHostOption_HostCanChangeHunger, 1); app.SetGameHostOption(eGameHostOption_HostCanBeInvisible, 1 ); param->settings = app.GetGameHostOption( eGameHostOption_All ); g_NetworkManager.FakeLocalPlayerJoined(); LoadingInputParams *loadingParams = new LoadingInputParams(); loadingParams->func = &CGameNetworkManager::RunNetworkGameThreadProc; loadingParams->lpParam = (LPVOID)param; // Reset the autosave time app.SetAutosaveTimerTime(); C4JThread* thread = new C4JThread(loadingParams->func, loadingParams->lpParam, "RunNetworkGame"); thread->Run(); } // COMMERCE / DLC void CConsoleMinecraftApp::CommerceInit() { m_bCommerceCategoriesRetrieved=false; m_bCommerceProductListRetrieved=false; m_bCommerceInitialised=false; m_bProductListAdditionalDetailsRetrieved=false; #ifdef ORBIS_COMMERCE_ENABLED m_pCommerce= new SonyCommerce_Orbis; #endif m_eCommerce_State=eCommerce_State_Offline; // can only init when we have a PSN user m_ProductListRetrievedC=0; m_ProductListAdditionalDetailsC=0; m_ProductListCategoriesC=0; m_iCurrentCategory=0; m_iCurrentProduct=0; memset(m_pchSkuID,0,48); } void CConsoleMinecraftApp::CommerceTick() { #ifdef ORBIS_COMMERCE_ENABLED // only tick this if the primary user is signed in to the PSN if(ProfileManager.IsSignedInLive(0)) { switch(m_eCommerce_State) { case eCommerce_State_Offline: m_eCommerce_State=eCommerce_State_Init; break; case eCommerce_State_Init: m_eCommerce_State=eCommerce_State_Init_Pending; m_pCommerce->CreateSession(&CConsoleMinecraftApp::CommerceInitCallback, this); break; case eCommerce_State_GetCategories: m_eCommerce_State=eCommerce_State_GetCategories_Pending; // get all categories for this product m_pCommerce->GetCategoryInfo(&CConsoleMinecraftApp::CommerceGetCategoriesCallback, this, &m_CategoryInfo,app.GetCommerceCategory()); break; case eCommerce_State_GetProductList: { m_eCommerce_State=eCommerce_State_GetProductList_Pending; SonyCommerce::CategoryInfo *pCategories=app.GetCategoryInfo(); std::list::iterator iter = pCategories->subCategories.begin(); for(int i=0;iGetProductList(&CConsoleMinecraftApp::CommerceGetProductListCallback, this, &m_ProductListA[m_ProductListRetrievedC],category.categoryId); } break; case eCommerce_State_AddProductInfoDetailed: { m_eCommerce_State=eCommerce_State_AddProductInfoDetailed_Pending; // for each of the products in the categories, get the detailed info. We really only need the long description and price info. SonyCommerce::CategoryInfo *pCategories=app.GetCategoryInfo(); std::list::iterator iter = pCategories->subCategories.begin(); for(int i=0;i*pvProductList=&m_ProductListA[m_iCurrentCategory]; // 4J-PB - there may be no products in the category if(pvProductList->size()==0) { CConsoleMinecraftApp::CommerceAddDetailedProductInfoCallback(this,0); } else { assert(pvProductList->size() > m_iCurrentProduct); SonyCommerce::ProductInfo *pProductInfo=&(pvProductList->at(m_iCurrentProduct)); m_pCommerce->AddDetailedProductInfo(&CConsoleMinecraftApp::CommerceAddDetailedProductInfoCallback, this, pProductInfo,pProductInfo->productId,category.categoryId); } } break; case eCommerce_State_Checkout: m_pCommerce->CreateSession(&CConsoleMinecraftApp::CheckoutSessionStartedCallback, this); m_eCommerce_State=eCommerce_State_Checkout_WaitingForSession; break; case eCommerce_State_Checkout_SessionStarted: m_eCommerce_State=eCommerce_State_Checkout_Pending; m_pCommerce->Checkout(&CConsoleMinecraftApp::CommerceCheckoutCallback, this,m_pchSkuID); break; case eCommerce_State_RegisterDLC: { m_eCommerce_State=eCommerce_State_Online; // register the DLC info SonyCommerce::CategoryInfo *pCategories=app.GetCategoryInfo(); std::list::iterator iter = pCategories->subCategories.begin(); for(int i=0;i*pvProductList=&m_ProductListA[i]; for(int j=0;jsize();j++) { SonyCommerce::ProductInfo *pProductInfo=&(pvProductList->at(j)); // just want the final 16 characters of the product id RegisterDLCData(&pProductInfo->productId[20],0,pProductInfo->imageUrl); } iter++; } } break; case eCommerce_State_DownloadAlreadyPurchased: m_pCommerce->CreateSession(&CConsoleMinecraftApp::DownloadAlreadyPurchasedSessionStartedCallback, this); m_eCommerce_State=eCommerce_State_DownloadAlreadyPurchased_WaitingForSession; break; case eCommerce_State_DownloadAlreadyPurchased_SessionStarted: m_eCommerce_State=eCommerce_State_DownloadAlreadyPurchased_Pending; m_pCommerce->DownloadAlreadyPurchased(&CConsoleMinecraftApp::CommerceCheckoutCallback, this,m_pchSkuID); break; case eCommerce_State_UpgradeTrial: m_pCommerce->CreateSession(&CConsoleMinecraftApp::UpgradeTrialSessionStartedCallback, this); m_eCommerce_State=eCommerce_State_UpgradeTrial_WaitingForSession; break; case eCommerce_State_UpgradeTrial_SessionStarted: m_pCommerce->UpgradeTrial(&CConsoleMinecraftApp::CommerceCheckoutCallback, this); m_eCommerce_State=eCommerce_State_UpgradeTrial_Pending; break; } // 4J-PB - bit of a hack to display the full version purchase after signing in during a trial trophy popup if(m_bDisplayFullVersionPurchase && ((m_eCommerce_State==eCommerce_State_Online) || (m_eCommerce_State==eCommerce_State_Error))) { m_bDisplayFullVersionPurchase=false; ProfileManager.DisplayFullVersionPurchase(false,ProfileManager.GetPrimaryPad(),eSen_UpsellID_Full_Version_Of_Game); } } else { // was the primary player signed in and is now signed out? if(m_eCommerce_State!=eCommerce_State_Offline) { m_eCommerce_State=eCommerce_State_Offline; // clear out all the product info ClearCommerceDetails(); m_pCommerce->CloseSession(); } } #endif // ORBIS_COMMERCE_ENABLED } bool CConsoleMinecraftApp::GetCommerceCategoriesRetrieved() { return m_bCommerceCategoriesRetrieved; } bool CConsoleMinecraftApp::GetCommerceProductListRetrieved() { return m_bCommerceProductListRetrieved; } bool CConsoleMinecraftApp::GetCommerceProductListInfoRetrieved() { return m_bProductListAdditionalDetailsRetrieved; } #ifdef ORBIS_COMMERCE_ENABLED SonyCommerce::CategoryInfo *CConsoleMinecraftApp::GetCategoryInfo() { if(m_bCommerceCategoriesRetrieved==false) { return NULL; } return &m_CategoryInfo; } #endif void CConsoleMinecraftApp::ClearCommerceDetails() { #ifdef ORBIS_COMMERCE_ENABLED for(int i=0;i* pProductList=&m_ProductListA[i]; pProductList->clear(); } if(m_ProductListA!=NULL) { delete [] m_ProductListA; m_ProductListA=NULL; } m_ProductListRetrievedC=0; m_ProductListAdditionalDetailsC=0; m_ProductListCategoriesC=0; m_iCurrentCategory=0; m_iCurrentProduct=0; m_bCommerceCategoriesRetrieved=false; m_bCommerceInitialised=false; m_bCommerceProductListRetrieved=false; m_bProductListAdditionalDetailsRetrieved=false; m_CategoryInfo.subCategories.clear(); #endif // #ifdef ORBIS_COMMERCE_ENABLED } void CConsoleMinecraftApp::GetDLCSkuIDFromProductList(char * pchDLCProductID, char *pchSkuID) { #ifdef ORBIS_COMMERCE_ENABLED // find the DLC for(int i=0;i* pProductList=&m_ProductListA[i]; AUTO_VAR(itEnd, pProductList->end()); for (AUTO_VAR(it, pProductList->begin()); it != itEnd; it++) { SonyCommerce::ProductInfo Info=*it; if(strcmp(pchDLCProductID,Info.productId)==0) { memcpy(pchSkuID,Info.skuId,SCE_NP_COMMERCE2_SKU_ID_LEN); return; } } } } return; #endif // #ifdef ORBIS_COMMERCE_ENABLED } void CConsoleMinecraftApp::Checkout(char *pchSkuID) { if(m_eCommerce_State==eCommerce_State_Online) { strcpy(m_pchSkuID,pchSkuID); m_eCommerce_State=eCommerce_State_Checkout; } } void CConsoleMinecraftApp::DownloadAlreadyPurchased(char *pchSkuID) { if(m_eCommerce_State==eCommerce_State_Online) { strcpy(m_pchSkuID,pchSkuID); m_eCommerce_State=eCommerce_State_DownloadAlreadyPurchased; } } bool CConsoleMinecraftApp::UpgradeTrial() { if(m_eCommerce_State==eCommerce_State_Online) { m_eCommerce_State=eCommerce_State_UpgradeTrial; return true; } else if(m_eCommerce_State==eCommerce_State_Error) { UINT uiIDA[1]; uiIDA[0]=IDS_CONFIRM_OK; C4JStorage::EMessageResult result = ui.RequestMessageBox( IDS_PRO_UNLOCKGAME_TITLE, IDS_NO_DLCOFFERS, uiIDA,1,ProfileManager.GetPrimaryPad()); return true; } else { // commerce is busy return false; } } #ifdef ORBIS_COMMERCE_ENABLED std::vector* CConsoleMinecraftApp::GetProductList(int iIndex) { if((m_bCommerceProductListRetrieved==false) || (m_bProductListAdditionalDetailsRetrieved==false) ) { return NULL; } return &m_ProductListA[iIndex]; } #endif // #ifdef ORBIS_COMMERCE_ENABLED bool CConsoleMinecraftApp::DLCAlreadyPurchased(char *pchTitle) { #ifdef ORBIS_COMMERCE_ENABLED // purchasability flag is not return on PS4 return false; // find the DLC // for(int i=0;i* pProductList=&m_ProductListA[i]; // AUTO_VAR(itEnd, pProductList->end()); // // for (AUTO_VAR(it, pProductList->begin()); it != itEnd; it++) // { // SonyCommerce::ProductInfo Info=*it; // if(strcmp(pchTitle,Info.skuId)==0) // { // ORBIS_STUBBED; // SCE_NP_COMMERCE2_SKU_PURCHASABILITY_FLAG_OFF // // if(Info.purchasabilityFlag==SCE_NP_COMMERCE2_SKU_PURCHASABILITY_FLAG_OFF) // // { // // return true; // // } // // else // // { // // return false; // // } // } // } // } // } #endif // #ifdef ORBIS_COMMERCE_ENABLED return false; } //////////////////// // Commerce callbacks ///////////////////// void CConsoleMinecraftApp::CommerceInitCallback(LPVOID lpParam,int err) { CConsoleMinecraftApp *pClass=(CConsoleMinecraftApp *)lpParam; if(err==0) { pClass->m_eCommerce_State=eCommerce_State_GetCategories; } else { pClass->m_eCommerce_State=eCommerce_State_Error; pClass->m_ProductListCategoriesC=0; pClass->m_bCommerceCategoriesRetrieved=true; } } void CConsoleMinecraftApp::CommerceGetCategoriesCallback(LPVOID lpParam,int err) { #ifdef ORBIS_COMMERCE_ENABLED CConsoleMinecraftApp *pClass=(CConsoleMinecraftApp *)lpParam; if(err==0) { pClass->m_ProductListCategoriesC=pClass->m_CategoryInfo.countOfSubCategories; // allocate the memory for the product info for each categories if(pClass->m_CategoryInfo.countOfSubCategories>0) { pClass->m_ProductListA = (std::vector *) new std::vector [pClass->m_CategoryInfo.countOfSubCategories]; pClass->m_eCommerce_State=eCommerce_State_GetProductList; } else { pClass->m_eCommerce_State=eCommerce_State_Online; } } else { pClass->m_ProductListCategoriesC=0; pClass->m_eCommerce_State=eCommerce_State_Error; } pClass->m_bCommerceCategoriesRetrieved=true; #endif // #ifdef ORBIS_COMMERCE_ENABLED } void CConsoleMinecraftApp::CommerceGetProductListCallback(LPVOID lpParam,int err) { CConsoleMinecraftApp *pClass=(CConsoleMinecraftApp *)lpParam; if(err==0) { pClass->m_ProductListRetrievedC++; // if we have more info to get, keep going with the next call if(pClass->m_ProductListRetrievedC==pClass->m_CategoryInfo.countOfSubCategories) { // we're done, so now retrieve the additional product details for each product pClass->m_eCommerce_State=eCommerce_State_AddProductInfoDetailed; pClass->m_bCommerceProductListRetrieved=true; } else { pClass->m_eCommerce_State=eCommerce_State_GetProductList; } } else { pClass->m_eCommerce_State=eCommerce_State_Error; pClass->m_bCommerceProductListRetrieved=true; } } // void CConsoleMinecraftApp::CommerceGetDetailedProductInfoCallback(LPVOID lpParam,int err) // { // CConsoleMinecraftApp *pScene=(CConsoleMinecraftApp *)lpParam; // // if(err==0) // { // pScene->m_eCommerce_State=eCommerce_State_Idle; // //pScene->m_bCommerceProductListRetrieved=true; // } // //printf("Callback hit, error 0x%08x\n", err); // // } void CConsoleMinecraftApp::CommerceAddDetailedProductInfoCallback(LPVOID lpParam,int err) { #ifdef ORBIS_COMMERCE_ENABLED CConsoleMinecraftApp *pClass=(CConsoleMinecraftApp *)lpParam; if(err==0) { // increment the current product counter. When this gets to the end of the products, move to the next category pClass->m_iCurrentProduct++; std::vector*pvProductList=&pClass->m_ProductListA[pClass->m_iCurrentCategory]; // if there are no more products in this category, move to the next category (there may be no products in the category) if(pClass->m_iCurrentProduct>=pvProductList->size()) { // MGH - change this to a while loop so we can skip empty categories. do { pClass->m_iCurrentCategory++; }while(pClass->m_ProductListA[pClass->m_iCurrentCategory].size() == 0 && pClass->m_iCurrentCategorym_ProductListCategoriesC); pClass->m_iCurrentProduct=0; if(pClass->m_iCurrentCategory==pClass->m_ProductListCategoriesC) { // there are no more categories, so we're done pClass->m_eCommerce_State=eCommerce_State_RegisterDLC; pClass->m_bProductListAdditionalDetailsRetrieved=true; } else { // continue with the next category pClass->m_eCommerce_State=eCommerce_State_AddProductInfoDetailed; } } else { // continue with the next product pClass->m_eCommerce_State=eCommerce_State_AddProductInfoDetailed; } } else { pClass->m_eCommerce_State=eCommerce_State_Error; pClass->m_bProductListAdditionalDetailsRetrieved=true; pClass->m_iCurrentProduct=0; pClass->m_iCurrentCategory=0; } #endif //#ifdef ORBIS_COMMERCE_ENABLED } void CConsoleMinecraftApp::CommerceCheckoutCallback(LPVOID lpParam,int err) { CConsoleMinecraftApp *pClass=(CConsoleMinecraftApp *)lpParam; if(err==0) { } pClass->m_eCommerce_State=eCommerce_State_Online; } void CConsoleMinecraftApp::CheckoutSessionStartedCallback(LPVOID lpParam,int err) { CConsoleMinecraftApp *pClass=(CConsoleMinecraftApp *)lpParam; if(err==0) pClass->m_eCommerce_State=eCommerce_State_Checkout_SessionStarted; else pClass->m_eCommerce_State=eCommerce_State_Error; } void CConsoleMinecraftApp::DownloadAlreadyPurchasedSessionStartedCallback(LPVOID lpParam,int err) { CConsoleMinecraftApp *pClass=(CConsoleMinecraftApp *)lpParam; if(err==0) pClass->m_eCommerce_State=eCommerce_State_DownloadAlreadyPurchased_SessionStarted; else pClass->m_eCommerce_State=eCommerce_State_Error; } void CConsoleMinecraftApp::UpgradeTrialSessionStartedCallback(LPVOID lpParam,int err) { CConsoleMinecraftApp *pClass=(CConsoleMinecraftApp *)lpParam; if(err==0) pClass->m_eCommerce_State=eCommerce_State_UpgradeTrial_SessionStarted; else pClass->m_eCommerce_State=eCommerce_State_Error; } bool CConsoleMinecraftApp::GetTrialFromName(char *pchDLCName) { if(pchDLCName[0]=='T') { return true; } return false; } eDLCContentType CConsoleMinecraftApp::GetDLCTypeFromName(char *pchDLCName) { char chDLCType[3]; chDLCType[0]=pchDLCName[1]; chDLCType[1]=pchDLCName[2]; chDLCType[2]=0; app.DebugPrintf(6,"DLC - %s\n",pchDLCName); if(strcmp(chDLCType,"SP")==0) { return e_DLC_SkinPack; } else if(strcmp(chDLCType,"GP")==0) { return e_DLC_Gamerpics; } else if(strcmp(chDLCType,"TH")==0) { return e_DLC_Themes; } else if(strcmp(chDLCType,"AV")==0) { return e_DLC_AvatarItems; } else if(strcmp(chDLCType,"MP")==0) { return e_DLC_MashupPacks; } else if(strcmp(chDLCType,"TP")==0) { return e_DLC_TexturePacks; } else { return e_DLC_NotDefined; } } int CConsoleMinecraftApp::GetiConfigFromName(char *pchName) { char pchiConfig[5]; int iStrlen=strlen(pchName); // last four character of DLC product name are the iConfig value pchiConfig[0]=pchName[iStrlen-4]; pchiConfig[1]=pchName[iStrlen-3]; pchiConfig[2]=pchName[iStrlen-2]; pchiConfig[3]=pchName[iStrlen-1]; pchiConfig[4]=0; return atoi(pchiConfig); } int CConsoleMinecraftApp::GetiFirstSkinFromName(char *pchName) { char pchiFirstSkin[5]; int iStrlen=strlen(pchName); // last four character of DLC product name are the iConfig value // four before that are the first skin id pchiFirstSkin[0]=pchName[iStrlen-8]; pchiFirstSkin[1]=pchName[iStrlen-7]; pchiFirstSkin[2]=pchName[iStrlen-6]; pchiFirstSkin[3]=pchName[iStrlen-5]; pchiFirstSkin[4]=0; return atoi(pchiFirstSkin); } // void CConsoleMinecraftApp::SetVoiceChatAndUGCRestricted(bool bRestricted) //{ // m_bVoiceChatAndUGCRestricted=bRestricted; //} // bool CConsoleMinecraftApp::GetVoiceChatAndUGCRestricted(void) //{ // return m_bVoiceChatAndUGCRestricted; //} int CConsoleMinecraftApp::GetCommerceState() { return m_eCommerce_State; } void CConsoleMinecraftApp::SystemServiceTick() { SceSystemServiceStatus status; SceSystemServiceEvent event; int ret = sceSystemServiceGetStatus(&status); if ((ret == SCE_OK) && (status.eventNum > 0)) { for (int i = 0; i < status.eventNum; i++) { ret = sceSystemServiceReceiveEvent(&event); if (ret == SCE_OK) { switch(event.eventType) { case SCE_SYSTEM_SERVICE_EVENT_GAME_CUSTOM_DATA: { OrbisNPToolkit::getMessageData((SceNpGameCustomDataEventParam*)event.data.param); // Processing after invitation //SceNpSessionInvitationEventParam* pInvite = (SceNpSessionInvitationEventParam*)event.data.param; //SQRNetworkManager_Orbis::GetInviteDataAndProcess(pInvite); break; } case SCE_SYSTEM_SERVICE_EVENT_ON_RESUME: // Resume means that the user signed out (but came back), sensible thing to do is exit to main menu app.SetAction(0, eAppAction_ExitWorld); break; case SCE_SYSTEM_SERVICE_EVENT_SESSION_INVITATION: case SCE_SYSTEM_SERVICE_EVENT_GAME_LIVE_STREAMING_STATUS_UPDATE: break; case SCE_SYSTEM_SERVICE_EVENT_ENTITLEMENT_UPDATE: app.GetCommerce()->CheckForTrialUpgradeKey(); // clear the DLC installed and check again app.ClearDLCInstalled(); ui.HandleDLCInstalled(0); break; case SCE_SYSTEM_SERVICE_EVENT_DISPLAY_SAFE_AREA_UPDATE: case SCE_SYSTEM_SERVICE_EVENT_URL_OPEN: case SCE_SYSTEM_SERVICE_EVENT_LAUNCH_APP: default: break; } } } } } void CConsoleMinecraftApp::SaveDataDialogTick() { if(m_bOptionsSaveDataDialogRunning) { SceCommonDialogStatus status = sceSaveDataDialogUpdateStatus(); if( status == SCE_COMMON_DIALOG_STATUS_FINISHED ) { SceSaveDataDialogResult result; memset(&result, 0, sizeof(result)); int ret = sceSaveDataDialogGetResult(&result); m_bOptionsSaveDataDialogRunning = false; ret = sceSaveDataDialogTerminate(); // R4099 doesn't say we need give the user a delete dialog to create space, so we won't } } else if( m_bSaveDataDialogRunning ) { SceCommonDialogStatus status = sceSaveDataDialogUpdateStatus(); if( status == SCE_COMMON_DIALOG_STATUS_FINISHED || status == SCE_COMMON_DIALOG_STATUS_NONE ) { SceSaveDataDialogResult result; memset(&result, 0, sizeof(result)); int ret = sceSaveDataDialogGetResult(&result); m_bSaveDataDialogRunning = false; ret = sceSaveDataDialogTerminate(); UINT uiIDA[3]; uiIDA[0]=IDS_SAVE_INCOMPLETE_RETRY_SAVING; uiIDA[1]=IDS_SAVE_INCOMPLETE_DISABLE_SAVING; uiIDA[2]=IDS_SAVE_INCOMPLETE_DELETE_SAVES; int message; if( m_eSaveIncompleteType == C4JStorage::ESaveIncomplete_OutOfQuota ) { message = IDS_SAVE_INCOMPLETE_EXPLANATION_QUOTA; } else { message = IDS_SAVE_INCOMPLETE_EXPLANATION_LOCAL_STORAGE; } if( ui.RequestMessageBox( IDS_SAVE_INCOMPLETE_TITLE, message, uiIDA,3,XUSER_INDEX_ANY,Callback_SaveGameIncompleteMessageBoxReturned,this, app.GetStringTable()) == C4JStorage::EMessage_Busy) { // If this failed to display, continue as if we cancelled. This isn't ideal, but the user should already have had some system notification of being out of memory, // and if we instantly retry then they may not be able to navigate whatever other error is blocking this from appearing Callback_SaveGameIncompleteMessageBoxReturned(this, 0, C4JStorage::EMessage_Cancelled); } } } } void CConsoleMinecraftApp::Callback_SaveGameIncomplete(void *pParam, C4JStorage::ESaveIncompleteType saveIncompleteType, int blocksRequired) { CConsoleMinecraftApp* pClass = (CConsoleMinecraftApp*)pParam; SceSaveDataDialogParam param; SceSaveDataDialogSystemMessageParam sysParam; SceSaveDataDialogItems items; SceSaveDataDirName dirName; sceSaveDataDialogParamInitialize(¶m); param.mode = SCE_SAVE_DATA_DIALOG_MODE_SYSTEM_MSG; param.dispType = SCE_SAVE_DATA_DIALOG_TYPE_SAVE; memset(&sysParam,0,sizeof(sysParam)); param.sysMsgParam = &sysParam; param.sysMsgParam->sysMsgType = SCE_SAVE_DATA_DIALOG_SYSMSG_TYPE_NOSPACE_CONTINUABLE; param.sysMsgParam->value = blocksRequired; memset(&items, 0, sizeof(items)); param.items = &items; SceUserServiceUserId userId; int ret = sceUserServiceGetInitialUser(&userId); param.items->userId = userId; ret = sceSaveDataDialogInitialize(); ret = sceSaveDataDialogOpen(¶m); pClass->m_bSaveDataDialogRunning = true; pClass->m_eSaveIncompleteType = saveIncompleteType; StorageManager.SetSaveDisabled(true); pClass->EnterSaveNotificationSection(); } int CConsoleMinecraftApp::Callback_SaveGameIncompleteMessageBoxReturned(void *pParam,int iPad,C4JStorage::EMessageResult result) { CConsoleMinecraftApp* pClass = (CConsoleMinecraftApp*)pParam; switch(result) { case C4JStorage::EMessage_ResultAccept: pClass->LeaveSaveNotificationSection(); StorageManager.SetSaveDisabled(false); StorageManager.ContinueIncompleteOperation(); break; case C4JStorage::EMessage_ResultDecline: case C4JStorage::EMessage_Cancelled: pClass->LeaveSaveNotificationSection(); // Set the global flag, so that we don't disable saving again once the message box is complete app.SetGameHostOption(eGameHostOption_DisableSaving, 1); StorageManager.CancelIncompleteOperation(); break; case C4JStorage::EMessage_ResultThirdOption: ui.NavigateToScene(iPad, eUIScene_InGameSaveManagementMenu, NULL, eUILayer_Error, eUIGroup_Fullscreen); break; } return 0; } bool CConsoleMinecraftApp::CheckForEmptyStore(int iPad) { SonyCommerce::CategoryInfo *pCategories=app.GetCategoryInfo(); bool bEmptyStore=true; if(pCategories!=NULL) { if(pCategories->countOfProducts>0) { bEmptyStore=false; } else { for(int i=0;icountOfSubCategories;i++) { std::vector*pvProductInfo=app.GetProductList(i); if(pvProductInfo->size()>0) { bEmptyStore=false; break; } } } } if(bEmptyStore) { ProfileManager.DisplaySystemMessage( SCE_MSG_DIALOG_SYSMSG_TYPE_TRC_EMPTY_STORE, iPad ); } return bEmptyStore; } void CConsoleMinecraftApp::ShowPatchAvailableError() { int32_t ret=sceErrorDialogInitialize(); if ( ret==SCE_OK ) { m_bPatchAvailableDialogRunning = true; SceErrorDialogParam param; sceErrorDialogParamInitialize( ¶m ); // 4J-PB - We want to display the option to get the patch now param.errorCode = SCE_NP_ERROR_LATEST_PATCH_PKG_DOWNLOADED; ret = sceUserServiceGetInitialUser( ¶m.userId ); if ( ret == SCE_OK ) { ret=sceErrorDialogOpen( ¶m ); } } } void CConsoleMinecraftApp::PatchAvailableDialogTick() { if(m_bPatchAvailableDialogRunning) { SceErrorDialogStatus stat = sceErrorDialogUpdateStatus(); if( stat == SCE_ERROR_DIALOG_STATUS_FINISHED ) { sceErrorDialogTerminate(); UINT uiIDA[1]; uiIDA[0]=IDS_PRO_NOTONLINE_DECLINE; ui.RequestMessageBox(IDS_ONLINE_SERVICE_TITLE, IDS_CONTENT_RESTRICTION_PATCH_AVAILABLE, uiIDA, 1, ProfileManager.GetPrimaryPad(), NULL, NULL, app.GetStringTable()); m_bPatchAvailableDialogRunning=false; } } }