Skip to content

Instantly share code, notes, and snippets.

@Peekab0
Last active October 11, 2024 21:32
Show Gist options
  • Save Peekab0/427234f5ed7a28c93467d403d31ab468 to your computer and use it in GitHub Desktop.
Save Peekab0/427234f5ed7a28c93467d403d31ab468 to your computer and use it in GitHub Desktop.
Fixed Quixel code
((async (startPage = 0, autoClearConsole = true) => {
const getCookie = (name) => {
const value = `; ${document.cookie}`;
const parts = value.split(`; ${name}=`);
if (parts.length === 2) return parts.pop().split(';').shift();
};
const callCacheApi = async (params = {}) => {
const defaultParams = {
page: 0,
maxValuesPerFacet: 1000,
hitsPerPage: 1000,
attributesToRetrieve: ["id", "name"].join(",")
};
const response = await fetch("https://proxy-algolia-prod.quixel.com/algolia/cache", {
"headers": {
"x-api-key": "2Zg8!d2WAHIUW?pCO28cVjfOt9seOWPx@2j"
},
"body": JSON.stringify({
url: "https://6UJ1I5A072-2.algolianet.com/1/indexes/assets/query?x-algolia-application-id=6UJ1I5A072&x-algolia-api-key=e93907f4f65fb1d9f813957bdc344892",
params: new URLSearchParams({ ...defaultParams, ...params }).toString()
}),
"method": "POST",
});
return await response.json();
};
const callAcl = async ({ id, name }) => {
const response = await fetch("https://quixel.com/v1/acl", {
"headers": {
"authorization": "Bearer " + authToken,
"content-type": "application/json;charset=UTF-8",
},
"body": JSON.stringify({ assetID: id }),
"method": "POST",
});
const json = await response.json();
if (json?.isError) {
console.error(` --> **UNABLE TO ADD ITEM** Item ${id} | ${name} (${json?.msg})`);
} else {
console.log(` --> ADDED ITEM Item ${id} | ${name}`);
}
};
const callAcquired = async () => {
const response = await fetch("https://quixel.com/v1/assets/acquired", {
"headers": {
"authorization": "Bearer " + authToken,
"content-type": "application/json;charset=UTF-8",
},
"method": "GET",
});
return await response.json();
};
// 1. Check token exist, quixel API needs it
console.log("-> Checking Auth API Token...");
let authToken = "";
try {
const authCookie = getCookie("auth") ?? "{}";
authToken = JSON.parse(decodeURIComponent(authCookie))?.token;
if (!authToken) {
return console.error("-> Error: cannot find authentication token. Please login again.");
}
} catch (_) {
return console.error("-> Error: cannot find authentication token. Please login again.");
}
// 2. Get all currently acquired items
console.log("-> Get Acquired Items...");
const acquiredItems = (await callAcquired()).map(a => a.assetID);
// 3. Get total count of items
console.log("-> Getting Total Number of Pages....");
const { nbPages: totalPages, hitsPerPage: itemsPerPage, nbHits: totalItems } = await callCacheApi();
console.log("-> ==============================================");
console.log(`-> Total # of items: ${totalItems}`);
console.log(`-> ${totalPages} total pages with ${itemsPerPage} per page`);
console.log(`-> Total Items to add: ${(totalItems - acquiredItems.length)}.`);
console.log("-> ==============================================");
if (!confirm(`Click OK to start adding ${(totalItems - acquiredItems.length)} items in your account.`)) return;
// Loop
let pageIdx = startPage || 0;
while (pageIdx < totalPages) {
console.log(`-> ======================= PAGE ${pageIdx + 1}/${totalPages} START =======================`);
console.log("-> Getting Items from page " + (pageIdx + 1) + " ...");
try {
const { hits: items } = await callCacheApi({ page: pageIdx });
console.log("-> Adding non-acquired items...");
// Filter out owned items
const unownedItems = items.filter(i => !acquiredItems.includes(i.id));
const aclPromises = unownedItems.map(callAcl);
await Promise.all(aclPromises);
console.log(`-> ======================= PAGE ${pageIdx + 1}/${totalPages} COMPLETED =======================`);
} catch (error) {
console.error(`Error processing page ${pageIdx + 1}: ${error.message}`);
}
if (autoClearConsole) console.clear(); // Fix the issue that too much log hangs the console. Set autoClearConsole = false to keep the logs
pageIdx++;
}
console.log("-> Getting new acquired info...");
// Get acquired items again
const newItemsAcquired = (await callAcquired()).length;
const newTotalCount = (await callCacheApi()).nbHits;
console.log(`-> Completed. Your account now has a total of ${newItemsAcquired} out of ${newTotalCount} items.`);
alert(`-> Your account now has a total of ${newItemsAcquired} out of ${newTotalCount} items.\n\nIf you find some items missing, try refreshing the page and run the script again.`);
})());
@sTiKyt
Copy link

sTiKyt commented Sep 23, 2024

Works nice, if you get hit with 403 errors, enable VPN, refresh the page, and run script again

@gnagga
Copy link

gnagga commented Oct 4, 2024

Sorry for the neebie question: how do i launch this once i downloaded the .txt?

@Peekab0
Copy link
Author

Peekab0 commented Oct 4, 2024

Sorry for the neebie question: how do i launch this once i downloaded the .txt?

Copy the script

Login into https://quixel.com/

Go to https://quixel.com/megascans/collections

Open devtools (F12) -> Go to "Console" tab

Paste in the script and press Enter.

A dialog should popup confirming the execution, 7. click "OK" Sit back and wait

@wxxstd
Copy link

wxxstd commented Oct 11, 2024

Looks like I got ip banned from the site midway. Turning on vpn solved this. Has anyone else had this issue?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment