mirror of
				https://github.com/maxswa/osrs-json-hiscores.git
				synced 2025-10-15 10:19:04 +00:00 
			
		
		
		
	Compare commits
	
		
			30 Commits
		
	
	
		
			update-rea
			...
			v2.21.1
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 79c067152c | ||
|   | e51e7bc32e | ||
|   | 7d7c7f9b08 | ||
|   | fd24890f67 | ||
|   | 3ba434978a | ||
|   | 44ecdf5434 | ||
|   | 99fc97f05e | ||
|   | b3fc5846f3 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1deed9f450 | ||
|   | 0be3f0b636 | ||
|   | ec1ed53669 | ||
|   | d0f5285470 | ||
|   | 9c56e44344 | ||
|   | e5b3075ebd | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 8bb50b73b2 | ||
|   | cb482ad720 | ||
|   | 0fbd85aa07 | ||
|   | e634b107b1 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 29db21493c | ||
|   | b117cfcf41 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d895326d9f | ||
|   | 1f7a25d421 | ||
|   | 057812681b | ||
|   | ee510ec69a | ||
|   | 6adcb02545 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | dacbd90189 | ||
|   | 3b502cb7cf | ||
|   | b3f81e66eb | ||
|   | 01150b6234 | ||
|   | 92452e240c | 
							
								
								
									
										13
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								README.md
									
									
									
									
									
								
							| @@ -93,7 +93,7 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | ||||
| ### Minigames | ||||
|  | ||||
| | Minigame                        |        Param        | | ||||
| | ------------------------------- | :---------------: | | ||||
| | ------------------------------- | :-----------------: | | ||||
| | Bounty Hunter (Legacy - Rogue)  |      `rogueBH`      | | ||||
| | Bounty Hunter (Legacy - Hunter) |     `hunterBH`      | | ||||
| | Bounty Hunter (Rogue)           |     `rogueBHV2`     | | ||||
| @@ -102,6 +102,8 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | ||||
| | PvP Arena - Rank                |     `pvpArena`      | | ||||
| | Soul Wars Zeal                  |   `soulWarsZeal`    | | ||||
| | Rifts closed                    |    `riftsClosed`    | | ||||
| | Colosseum Glory                 |  `colosseumGlory`   | | ||||
| | Collections Logged              | `collectionsLogged` | | ||||
|  | ||||
| ### Points | ||||
|  | ||||
| @@ -116,6 +118,8 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | ||||
| | --------------------------------- | :----------------------------: | | ||||
| | Abyssal Sire                      |         `abyssalSire`          | | ||||
| | Alchemical Hydra                  |       `alchemicalHydra`        | | ||||
| | Amoxliatl                         |          `amoxliatl`           | | ||||
| | Araxxor                           |           `araxxor`            | | ||||
| | Artio                             |            `artio`             | | ||||
| | Barrows Chests                    |           `barrows`            | | ||||
| | Bryophyta                         |          `bryophyta`           | | ||||
| @@ -143,6 +147,7 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | ||||
| | Kraken                            |            `kraken`            | | ||||
| | Kreearra                          |           `kreeArra`           | | ||||
| | K'ril Tsutsaroth                  |        `krilTsutsaroth`        | | ||||
| | Lunar Chests                      |         `lunarChests`          | | ||||
| | Mimic                             |            `mimic`             | | ||||
| | Nex                               |             `nex`              | | ||||
| | Nightmare                         |          `nightmare`           | | ||||
| @@ -151,12 +156,16 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | ||||
| | Phantom Muspah                    |        `phantomMuspah`         | | ||||
| | Sarachnis                         |          `sarachnis`           | | ||||
| | Scorpia                           |           `scorpia`            | | ||||
| | Scurrius                          |           `scurrius`           | | ||||
| | Skotizo                           |           `skotizo`            | | ||||
| | Sol Heredit                       |          `solHeredit`          | | ||||
| | Spindel                           |           `spindel`            | | ||||
| | Tempoross                         |          `tempoross`           | | ||||
| | The Gauntlet                      |           `gauntlet`           | | ||||
| | The Corrupted Gauntlet            |      `corruptedGauntlet`       | | ||||
| | The Hueycoatl                     |          `hueycoatl`           | | ||||
| | The Leviathan                     |          `leviathan`           | | ||||
| | The Royal Titans                  |         `royalTitans`          | | ||||
| | The Whisperer                     |          `whisperer`           | | ||||
| | Theatre Of Blood                  |        `theatreOfBlood`        | | ||||
| | Theatre Of Blood: Hard Mode       |    `theatreOfBloodHardMode`    | | ||||
| @@ -198,6 +207,8 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | ||||
|     pvpArena: {}, | ||||
|     soulWarsZeal: {}, | ||||
|     riftsClosed: {}, | ||||
|     colosseumGlory: {}, | ||||
|     collectionsLogged: {}, | ||||
|     bosses: {} | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -1,99 +1,108 @@ | ||||
| 3745,2277,840426611 | ||||
| 24080,99,30276246 | ||||
| 9559,99,31228199 | ||||
| 2212,99,143599407 | ||||
| 3550,99,123248914 | ||||
| 6564,99,109953707 | ||||
| 4244,99,15144846 | ||||
| 4107,99,57072224 | ||||
| 135556,99,13353511 | ||||
| 25855,99,16903268 | ||||
| 53472,99,13456850 | ||||
| 22453,99,16654917 | ||||
| 17690,99,19118307 | ||||
| 45816,99,14059776 | ||||
| 10409,99,16530015 | ||||
| 27702,99,14765145 | ||||
| 39430,99,13235063 | ||||
| 6722,99,15754877 | ||||
| 51813,99,14023027 | ||||
| 5324,99,33835543 | ||||
| 3154,99,69527777 | ||||
| 4719,99,22733384 | ||||
| 15135,99,17952893 | ||||
| 1089,99,17998715 | ||||
| 2210,2277,1150073045 | ||||
| 23988,99,33320012 | ||||
| 3114,99,51215128 | ||||
| 1203,99,200000000 | ||||
| 1372,99,196290925 | ||||
| 3458,99,159426771 | ||||
| 2746,99,17744970 | ||||
| 2031,99,91566360 | ||||
| 161852,99,13386665 | ||||
| 25801,99,19461878 | ||||
| 64826,99,13473417 | ||||
| 26528,99,16672481 | ||||
| 20829,99,19483653 | ||||
| 58378,99,14103220 | ||||
| 13188,99,16573909 | ||||
| 36283,99,15061037 | ||||
| 17137,99,14670565 | ||||
| 8751,99,16169665 | ||||
| 60803,99,14390315 | ||||
| 1718,99,57850681 | ||||
| 2117,99,110369178 | ||||
| 5540,99,22739567 | ||||
| 22326,99,18052465 | ||||
| 1467,99,18050183 | ||||
| -1,-1 | ||||
| -1,-1 | ||||
| 26164,10 | ||||
| 12886,3 | ||||
| 148658,8 | ||||
| 103161,7 | ||||
| 377,9556 | ||||
| 862,825 | ||||
| 148,6000 | ||||
| 2153,1606 | ||||
| 42107,298 | ||||
| 504,459 | ||||
| 1816,368 | ||||
| 14701,2521 | ||||
| 38135,10 | ||||
| 19368,3 | ||||
| 146220,8 | ||||
| 100923,7 | ||||
| 433,9802 | ||||
| 1542,825 | ||||
| 158,6000 | ||||
| 2572,1606 | ||||
| 47979,311 | ||||
| 1081,460 | ||||
| 880,600 | ||||
| 4258,6785 | ||||
| -1,-1 | ||||
| 6776,14780 | ||||
| 4773,1060 | ||||
| 2741,2192 | ||||
| 90203,594 | ||||
| 29573,143 | ||||
| 3668,1830 | ||||
| 206778,5 | ||||
| 32897,293 | ||||
| 64112,58 | ||||
| 18492,1905 | ||||
| 178941,34 | ||||
| 2379,501 | ||||
| 82902,50 | ||||
| 147358,26 | ||||
| 51973,287 | ||||
| 2377,2000 | ||||
| 147406,41 | ||||
| 32225,707 | ||||
| 42229,698 | ||||
| 32212,714 | ||||
| 79605,25 | ||||
| 9517,688 | ||||
| 19125,1228 | ||||
| 65849,474 | ||||
| 2080,2140 | ||||
| 16433,182 | ||||
| 2006,2046 | ||||
| 48575,580 | ||||
| 115056,1908 | ||||
| 10406,920 | ||||
| 2196,1444 | ||||
| 1005,33 | ||||
| 28413,620 | ||||
| 4157,744 | ||||
| 4261,500 | ||||
| 993,217 | ||||
| 21848,251 | ||||
| 66260,119 | ||||
| 108898,26 | ||||
| 373975,9 | ||||
| 2005,1569 | ||||
| 40001,273 | ||||
| 192608,7 | ||||
| 78367,201 | ||||
| 5679,583 | ||||
| 478,1760 | ||||
| 22932,250 | ||||
| 15059,7 | ||||
| 7161,3066 | ||||
| 101555,35 | ||||
| 610,933 | ||||
| 15733,2 | ||||
| -1,-1 | ||||
| 2051,2078 | ||||
| 194,7096 | ||||
| 69260,51 | ||||
| 14039,2780 | ||||
| 876367,62 | ||||
| 165341,25 | ||||
| 226318,275 | ||||
| 7596,14780 | ||||
| 8124,1060 | ||||
| 10438,43487 | ||||
| 1114,1155 | ||||
| 3497,2192 | ||||
| 3204,4796 | ||||
| 1087,984 | ||||
| 2230,2328 | ||||
| 51533,143 | ||||
| 4243,1830 | ||||
| 256985,5 | ||||
| 54424,293 | ||||
| 114691,58 | ||||
| 11700,2657 | ||||
| 211708,34 | ||||
| 1779,736 | ||||
| 24958,215 | ||||
| 46504,116 | ||||
| 66096,287 | ||||
| 3133,2000 | ||||
| 26682,198 | ||||
| 19337,1078 | ||||
| 25021,1062 | ||||
| 19290,1088 | ||||
| 89474,25 | ||||
| 7535,1320 | ||||
| 23251,1228 | ||||
| 82016,477 | ||||
| 876,3642 | ||||
| 7073,310 | ||||
| 2476,2046 | ||||
| 55411,580 | ||||
| 68801,2899 | ||||
| 4608,1740 | ||||
| 3079,1444 | ||||
| 8344,324 | ||||
| 540,53 | ||||
| 38395,626 | ||||
| 4176,749 | ||||
| 5519,500 | ||||
| 1394,217 | ||||
| 26127,379 | ||||
| 49730,249 | ||||
| 57206,91 | ||||
| 6106,1245 | ||||
| 185920,29 | ||||
| 3232,49 | ||||
| 4276,1569 | ||||
| 57314,273 | ||||
| 256794,7 | ||||
| 113862,201 | ||||
| 1969,538 | ||||
| 12346,671 | ||||
| 5606,149 | ||||
| 550,2450 | ||||
| 25557,310 | ||||
| 1391,538 | ||||
| 9325,3066 | ||||
| 131996,37 | ||||
| 214,1720 | ||||
| 8902,7 | ||||
| 148385,8 | ||||
| 6120,2113 | ||||
| 287,7096 | ||||
| 97368,51 | ||||
| 15591,2780 | ||||
| 1000405,67 | ||||
| 213696,25 | ||||
| 240082,340 | ||||
| Can't render this file because it has a wrong number of fields in line 25. | 
| @@ -3,199 +3,676 @@ | ||||
|     { | ||||
|       "id": 0, | ||||
|       "name": "Overall", | ||||
|       "rank": 3745, | ||||
|       "rank": 2210, | ||||
|       "level": 2277, | ||||
|       "xp": 840426611 | ||||
|       "xp": 1150073045 | ||||
|     }, | ||||
|     { | ||||
|       "id": 1, | ||||
|       "name": "Attack", | ||||
|       "rank": 23988, | ||||
|       "level": 99, | ||||
|       "xp": 33320012 | ||||
|     }, | ||||
|     { | ||||
|       "id": 2, | ||||
|       "name": "Defence", | ||||
|       "rank": 3114, | ||||
|       "level": 99, | ||||
|       "xp": 51215128 | ||||
|     }, | ||||
|     { | ||||
|       "id": 3, | ||||
|       "name": "Strength", | ||||
|       "rank": 1203, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { "id": 1, "name": "Attack", "rank": 24080, "level": 99, "xp": 30276246 }, | ||||
|     { "id": 2, "name": "Defence", "rank": 9559, "level": 99, "xp": 31228199 }, | ||||
|     { "id": 3, "name": "Strength", "rank": 2212, "level": 99, "xp": 143599407 }, | ||||
|     { | ||||
|       "id": 4, | ||||
|       "name": "Hitpoints", | ||||
|       "rank": 3550, | ||||
|       "rank": 1372, | ||||
|       "level": 99, | ||||
|       "xp": 123248914 | ||||
|       "xp": 196290925 | ||||
|     }, | ||||
|     { | ||||
|       "id": 5, | ||||
|       "name": "Ranged", | ||||
|       "rank": 3458, | ||||
|       "level": 99, | ||||
|       "xp": 159426771 | ||||
|     }, | ||||
|     { | ||||
|       "id": 6, | ||||
|       "name": "Prayer", | ||||
|       "rank": 2746, | ||||
|       "level": 99, | ||||
|       "xp": 17744970 | ||||
|     }, | ||||
|     { | ||||
|       "id": 7, | ||||
|       "name": "Magic", | ||||
|       "rank": 2031, | ||||
|       "level": 99, | ||||
|       "xp": 91566360 | ||||
|     }, | ||||
|     { | ||||
|       "id": 8, | ||||
|       "name": "Cooking", | ||||
|       "rank": 161852, | ||||
|       "level": 99, | ||||
|       "xp": 13386665 | ||||
|     }, | ||||
|     { "id": 5, "name": "Ranged", "rank": 6564, "level": 99, "xp": 109953707 }, | ||||
|     { "id": 6, "name": "Prayer", "rank": 4244, "level": 99, "xp": 15144846 }, | ||||
|     { "id": 7, "name": "Magic", "rank": 4107, "level": 99, "xp": 57072224 }, | ||||
|     { "id": 8, "name": "Cooking", "rank": 135556, "level": 99, "xp": 13353511 }, | ||||
|     { | ||||
|       "id": 9, | ||||
|       "name": "Woodcutting", | ||||
|       "rank": 25855, | ||||
|       "rank": 25801, | ||||
|       "level": 99, | ||||
|       "xp": 16903268 | ||||
|       "xp": 19461878 | ||||
|     }, | ||||
|     { | ||||
|       "id": 10, | ||||
|       "name": "Fletching", | ||||
|       "rank": 53472, | ||||
|       "rank": 64826, | ||||
|       "level": 99, | ||||
|       "xp": 13456850 | ||||
|       "xp": 13473417 | ||||
|     }, | ||||
|     { | ||||
|       "id": 11, | ||||
|       "name": "Fishing", | ||||
|       "rank": 26528, | ||||
|       "level": 99, | ||||
|       "xp": 16672481 | ||||
|     }, | ||||
|     { "id": 11, "name": "Fishing", "rank": 22453, "level": 99, "xp": 16654917 }, | ||||
|     { | ||||
|       "id": 12, | ||||
|       "name": "Firemaking", | ||||
|       "rank": 17690, | ||||
|       "rank": 20829, | ||||
|       "level": 99, | ||||
|       "xp": 19118307 | ||||
|       "xp": 19483653 | ||||
|     }, | ||||
|     { | ||||
|       "id": 13, | ||||
|       "name": "Crafting", | ||||
|       "rank": 45816, | ||||
|       "rank": 58378, | ||||
|       "level": 99, | ||||
|       "xp": 14059776 | ||||
|       "xp": 14103220 | ||||
|     }, | ||||
|     { | ||||
|       "id": 14, | ||||
|       "name": "Smithing", | ||||
|       "rank": 10409, | ||||
|       "rank": 13188, | ||||
|       "level": 99, | ||||
|       "xp": 16530015 | ||||
|       "xp": 16573909 | ||||
|     }, | ||||
|     { | ||||
|       "id": 15, | ||||
|       "name": "Mining", | ||||
|       "rank": 36283, | ||||
|       "level": 99, | ||||
|       "xp": 15061037 | ||||
|     }, | ||||
|     { "id": 15, "name": "Mining", "rank": 27702, "level": 99, "xp": 14765145 }, | ||||
|     { | ||||
|       "id": 16, | ||||
|       "name": "Herblore", | ||||
|       "rank": 39430, | ||||
|       "rank": 17137, | ||||
|       "level": 99, | ||||
|       "xp": 13235063 | ||||
|       "xp": 14670565 | ||||
|     }, | ||||
|     { | ||||
|       "id": 17, | ||||
|       "name": "Agility", | ||||
|       "rank": 8751, | ||||
|       "level": 99, | ||||
|       "xp": 16169665 | ||||
|     }, | ||||
|     { "id": 17, "name": "Agility", "rank": 6722, "level": 99, "xp": 15754877 }, | ||||
|     { | ||||
|       "id": 18, | ||||
|       "name": "Thieving", | ||||
|       "rank": 51813, | ||||
|       "rank": 60803, | ||||
|       "level": 99, | ||||
|       "xp": 14023027 | ||||
|       "xp": 14390315 | ||||
|     }, | ||||
|     { | ||||
|       "id": 19, | ||||
|       "name": "Slayer", | ||||
|       "rank": 1718, | ||||
|       "level": 99, | ||||
|       "xp": 57850681 | ||||
|     }, | ||||
|     { | ||||
|       "id": 20, | ||||
|       "name": "Farming", | ||||
|       "rank": 2117, | ||||
|       "level": 99, | ||||
|       "xp": 110369178 | ||||
|     }, | ||||
|     { "id": 19, "name": "Slayer", "rank": 5324, "level": 99, "xp": 33835543 }, | ||||
|     { "id": 20, "name": "Farming", "rank": 3154, "level": 99, "xp": 69527777 }, | ||||
|     { | ||||
|       "id": 21, | ||||
|       "name": "Runecraft", | ||||
|       "rank": 4719, | ||||
|       "rank": 5540, | ||||
|       "level": 99, | ||||
|       "xp": 22733384 | ||||
|       "xp": 22739567 | ||||
|     }, | ||||
|     { | ||||
|       "id": 22, | ||||
|       "name": "Hunter", | ||||
|       "rank": 22326, | ||||
|       "level": 99, | ||||
|       "xp": 18052465 | ||||
|     }, | ||||
|     { "id": 22, "name": "Hunter", "rank": 15135, "level": 99, "xp": 17952893 }, | ||||
|     { | ||||
|       "id": 23, | ||||
|       "name": "Construction", | ||||
|       "rank": 1089, | ||||
|       "rank": 1467, | ||||
|       "level": 99, | ||||
|       "xp": 17998715 | ||||
|       "xp": 18050183 | ||||
|     } | ||||
|   ], | ||||
|   "activities": [ | ||||
|     { "id": 0, "name": "League Points", "rank": -1, "score": -1 }, | ||||
|     { "id": 1, "name": "Deadman Points", "rank": -1, "score": -1 }, | ||||
|     { "id": 2, "name": "Bounty Hunter - Hunter", "rank": 26164, "score": 10 }, | ||||
|     { "id": 3, "name": "Bounty Hunter - Rogue", "rank": 12886, "score": 3 }, | ||||
|     { | ||||
|       "id": 0, | ||||
|       "name": "League Points", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 1, | ||||
|       "name": "Deadman Points", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 2, | ||||
|       "name": "Bounty Hunter - Hunter", | ||||
|       "rank": 38135, | ||||
|       "score": 10 | ||||
|     }, | ||||
|     { | ||||
|       "id": 3, | ||||
|       "name": "Bounty Hunter - Rogue", | ||||
|       "rank": 19368, | ||||
|       "score": 3 | ||||
|     }, | ||||
|     { | ||||
|       "id": 4, | ||||
|       "name": "Bounty Hunter (Legacy) - Hunter", | ||||
|       "rank": 148658, | ||||
|       "rank": 146220, | ||||
|       "score": 8 | ||||
|     }, | ||||
|     { | ||||
|       "id": 5, | ||||
|       "name": "Bounty Hunter (Legacy) - Rogue", | ||||
|       "rank": 103161, | ||||
|       "rank": 100923, | ||||
|       "score": 7 | ||||
|     }, | ||||
|     { "id": 6, "name": "Clue Scrolls (all)", "rank": 377, "score": 9556 }, | ||||
|     { "id": 7, "name": "Clue Scrolls (beginner)", "rank": 862, "score": 825 }, | ||||
|     { "id": 8, "name": "Clue Scrolls (easy)", "rank": 148, "score": 6000 }, | ||||
|     { "id": 9, "name": "Clue Scrolls (medium)", "rank": 2153, "score": 1606 }, | ||||
|     { "id": 10, "name": "Clue Scrolls (hard)", "rank": 42107, "score": 298 }, | ||||
|     { "id": 11, "name": "Clue Scrolls (elite)", "rank": 504, "score": 459 }, | ||||
|     { "id": 12, "name": "Clue Scrolls (master)", "rank": 1816, "score": 368 }, | ||||
|     { "id": 13, "name": "LMS - Rank", "rank": 14701, "score": 2521 }, | ||||
|     { "id": 14, "name": "PvP Arena - Rank", "rank": -1, "score": -1 }, | ||||
|     { "id": 15, "name": "Soul Wars Zeal", "rank": 6776, "score": 14780 }, | ||||
|     { "id": 16, "name": "Rifts closed", "rank": 4773, "score": 1060 }, | ||||
|     { "id": 17, "name": "Abyssal Sire", "rank": 2741, "score": 2192 }, | ||||
|     { "id": 18, "name": "Alchemical Hydra", "rank": 90203, "score": 594 }, | ||||
|     { "id": 19, "name": "Artio", "rank": 29573, "score": 143 }, | ||||
|     { "id": 20, "name": "Barrows Chests", "rank": 3668, "score": 1830 }, | ||||
|     { "id": 21, "name": "Bryophyta", "rank": 206778, "score": 5 }, | ||||
|     { "id": 22, "name": "Callisto", "rank": 32897, "score": 293 }, | ||||
|     { "id": 23, "name": "Calvar'ion", "rank": 64112, "score": 58 }, | ||||
|     { "id": 24, "name": "Cerberus", "rank": 18492, "score": 1905 }, | ||||
|     { "id": 25, "name": "Chambers of Xeric", "rank": 178941, "score": 34 }, | ||||
|     { | ||||
|       "id": 6, | ||||
|       "name": "Clue Scrolls (all)", | ||||
|       "rank": 433, | ||||
|       "score": 9802 | ||||
|     }, | ||||
|     { | ||||
|       "id": 7, | ||||
|       "name": "Clue Scrolls (beginner)", | ||||
|       "rank": 1542, | ||||
|       "score": 825 | ||||
|     }, | ||||
|     { | ||||
|       "id": 8, | ||||
|       "name": "Clue Scrolls (easy)", | ||||
|       "rank": 158, | ||||
|       "score": 6000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 9, | ||||
|       "name": "Clue Scrolls (medium)", | ||||
|       "rank": 2572, | ||||
|       "score": 1606 | ||||
|     }, | ||||
|     { | ||||
|       "id": 10, | ||||
|       "name": "Clue Scrolls (hard)", | ||||
|       "rank": 47979, | ||||
|       "score": 311 | ||||
|     }, | ||||
|     { | ||||
|       "id": 11, | ||||
|       "name": "Clue Scrolls (elite)", | ||||
|       "rank": 1081, | ||||
|       "score": 460 | ||||
|     }, | ||||
|     { | ||||
|       "id": 12, | ||||
|       "name": "Clue Scrolls (master)", | ||||
|       "rank": 880, | ||||
|       "score": 600 | ||||
|     }, | ||||
|     { | ||||
|       "id": 13, | ||||
|       "name": "LMS - Rank", | ||||
|       "rank": 4258, | ||||
|       "score": 6785 | ||||
|     }, | ||||
|     { | ||||
|       "id": 14, | ||||
|       "name": "PvP Arena - Rank", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 15, | ||||
|       "name": "Soul Wars Zeal", | ||||
|       "rank": 7596, | ||||
|       "score": 14780 | ||||
|     }, | ||||
|     { | ||||
|       "id": 16, | ||||
|       "name": "Rifts closed", | ||||
|       "rank": 8124, | ||||
|       "score": 1060 | ||||
|     }, | ||||
|     { | ||||
|       "id": 17, | ||||
|       "name": "Colosseum Glory", | ||||
|       "rank": 10438, | ||||
|       "score": 43487 | ||||
|     }, | ||||
|     { | ||||
|       "id": 18, | ||||
|       "name": "Collections Logged", | ||||
|       "rank": 1114, | ||||
|       "score": 1155 | ||||
|     }, | ||||
|     { | ||||
|       "id": 19, | ||||
|       "name": "Abyssal Sire", | ||||
|       "rank": 3497, | ||||
|       "score": 2192 | ||||
|     }, | ||||
|     { | ||||
|       "id": 20, | ||||
|       "name": "Alchemical Hydra", | ||||
|       "rank": 3204, | ||||
|       "score": 4796 | ||||
|     }, | ||||
|     { | ||||
|       "id": 21, | ||||
|       "name": "Amoxliatl", | ||||
|       "rank": 1087, | ||||
|       "score": 984 | ||||
|     }, | ||||
|     { | ||||
|       "id": 22, | ||||
|       "name": "Araxxor", | ||||
|       "rank": 2230, | ||||
|       "score": 2328 | ||||
|     }, | ||||
|     { | ||||
|       "id": 23, | ||||
|       "name": "Artio", | ||||
|       "rank": 51533, | ||||
|       "score": 143 | ||||
|     }, | ||||
|     { | ||||
|       "id": 24, | ||||
|       "name": "Barrows Chests", | ||||
|       "rank": 4243, | ||||
|       "score": 1830 | ||||
|     }, | ||||
|     { | ||||
|       "id": 25, | ||||
|       "name": "Bryophyta", | ||||
|       "rank": 256985, | ||||
|       "score": 5 | ||||
|     }, | ||||
|     { | ||||
|       "id": 26, | ||||
|       "name": "Chambers of Xeric: Challenge Mode", | ||||
|       "rank": 2379, | ||||
|       "score": 501 | ||||
|       "name": "Callisto", | ||||
|       "rank": 54424, | ||||
|       "score": 293 | ||||
|     }, | ||||
|     { | ||||
|       "id": 27, | ||||
|       "name": "Calvar'ion", | ||||
|       "rank": 114691, | ||||
|       "score": 58 | ||||
|     }, | ||||
|     { | ||||
|       "id": 28, | ||||
|       "name": "Cerberus", | ||||
|       "rank": 11700, | ||||
|       "score": 2657 | ||||
|     }, | ||||
|     { | ||||
|       "id": 29, | ||||
|       "name": "Chambers of Xeric", | ||||
|       "rank": 211708, | ||||
|       "score": 34 | ||||
|     }, | ||||
|     { | ||||
|       "id": 30, | ||||
|       "name": "Chambers of Xeric: Challenge Mode", | ||||
|       "rank": 1779, | ||||
|       "score": 736 | ||||
|     }, | ||||
|     { | ||||
|       "id": 31, | ||||
|       "name": "Chaos Elemental", | ||||
|       "rank": 24958, | ||||
|       "score": 215 | ||||
|     }, | ||||
|     { | ||||
|       "id": 32, | ||||
|       "name": "Chaos Fanatic", | ||||
|       "rank": 46504, | ||||
|       "score": 116 | ||||
|     }, | ||||
|     { | ||||
|       "id": 33, | ||||
|       "name": "Commander Zilyana", | ||||
|       "rank": 66096, | ||||
|       "score": 287 | ||||
|     }, | ||||
|     { | ||||
|       "id": 34, | ||||
|       "name": "Corporeal Beast", | ||||
|       "rank": 3133, | ||||
|       "score": 2000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 35, | ||||
|       "name": "Crazy Archaeologist", | ||||
|       "rank": 26682, | ||||
|       "score": 198 | ||||
|     }, | ||||
|     { | ||||
|       "id": 36, | ||||
|       "name": "Dagannoth Prime", | ||||
|       "rank": 19337, | ||||
|       "score": 1078 | ||||
|     }, | ||||
|     { | ||||
|       "id": 37, | ||||
|       "name": "Dagannoth Rex", | ||||
|       "rank": 25021, | ||||
|       "score": 1062 | ||||
|     }, | ||||
|     { | ||||
|       "id": 38, | ||||
|       "name": "Dagannoth Supreme", | ||||
|       "rank": 19290, | ||||
|       "score": 1088 | ||||
|     }, | ||||
|     { | ||||
|       "id": 39, | ||||
|       "name": "Deranged Archaeologist", | ||||
|       "rank": 89474, | ||||
|       "score": 25 | ||||
|     }, | ||||
|     { | ||||
|       "id": 40, | ||||
|       "name": "Duke Sucellus", | ||||
|       "rank": 7535, | ||||
|       "score": 1320 | ||||
|     }, | ||||
|     { | ||||
|       "id": 41, | ||||
|       "name": "General Graardor", | ||||
|       "rank": 23251, | ||||
|       "score": 1228 | ||||
|     }, | ||||
|     { | ||||
|       "id": 42, | ||||
|       "name": "Giant Mole", | ||||
|       "rank": 82016, | ||||
|       "score": 477 | ||||
|     }, | ||||
|     { | ||||
|       "id": 43, | ||||
|       "name": "Grotesque Guardians", | ||||
|       "rank": 876, | ||||
|       "score": 3642 | ||||
|     }, | ||||
|     { | ||||
|       "id": 44, | ||||
|       "name": "Hespori", | ||||
|       "rank": 7073, | ||||
|       "score": 310 | ||||
|     }, | ||||
|     { | ||||
|       "id": 45, | ||||
|       "name": "Kalphite Queen", | ||||
|       "rank": 2476, | ||||
|       "score": 2046 | ||||
|     }, | ||||
|     { | ||||
|       "id": 46, | ||||
|       "name": "King Black Dragon", | ||||
|       "rank": 55411, | ||||
|       "score": 580 | ||||
|     }, | ||||
|     { | ||||
|       "id": 47, | ||||
|       "name": "Kraken", | ||||
|       "rank": 68801, | ||||
|       "score": 2899 | ||||
|     }, | ||||
|     { | ||||
|       "id": 48, | ||||
|       "name": "Kree'Arra", | ||||
|       "rank": 4608, | ||||
|       "score": 1740 | ||||
|     }, | ||||
|     { | ||||
|       "id": 49, | ||||
|       "name": "K'ril Tsutsaroth", | ||||
|       "rank": 3079, | ||||
|       "score": 1444 | ||||
|     }, | ||||
|     { | ||||
|       "id": 50, | ||||
|       "name": "Lunar Chests", | ||||
|       "rank": 8344, | ||||
|       "score": 324 | ||||
|     }, | ||||
|     { | ||||
|       "id": 51, | ||||
|       "name": "Mimic", | ||||
|       "rank": 540, | ||||
|       "score": 53 | ||||
|     }, | ||||
|     { | ||||
|       "id": 52, | ||||
|       "name": "Nex", | ||||
|       "rank": 38395, | ||||
|       "score": 626 | ||||
|     }, | ||||
|     { | ||||
|       "id": 53, | ||||
|       "name": "Nightmare", | ||||
|       "rank": 4176, | ||||
|       "score": 749 | ||||
|     }, | ||||
|     { | ||||
|       "id": 54, | ||||
|       "name": "Phosani's Nightmare", | ||||
|       "rank": 5519, | ||||
|       "score": 500 | ||||
|     }, | ||||
|     { | ||||
|       "id": 55, | ||||
|       "name": "Obor", | ||||
|       "rank": 1394, | ||||
|       "score": 217 | ||||
|     }, | ||||
|     { | ||||
|       "id": 56, | ||||
|       "name": "Phantom Muspah", | ||||
|       "rank": 26127, | ||||
|       "score": 379 | ||||
|     }, | ||||
|     { | ||||
|       "id": 57, | ||||
|       "name": "Sarachnis", | ||||
|       "rank": 49730, | ||||
|       "score": 249 | ||||
|     }, | ||||
|     { | ||||
|       "id": 58, | ||||
|       "name": "Scorpia", | ||||
|       "rank": 57206, | ||||
|       "score": 91 | ||||
|     }, | ||||
|     { | ||||
|       "id": 59, | ||||
|       "name": "Scurrius", | ||||
|       "rank": 6106, | ||||
|       "score": 1245 | ||||
|     }, | ||||
|     { | ||||
|       "id": 60, | ||||
|       "name": "Skotizo", | ||||
|       "rank": 185920, | ||||
|       "score": 29 | ||||
|     }, | ||||
|     { | ||||
|       "id": 61, | ||||
|       "name": "Sol Heredit", | ||||
|       "rank": 3232, | ||||
|       "score": 49 | ||||
|     }, | ||||
|     { "id": 27, "name": "Chaos Elemental", "rank": 82902, "score": 50 }, | ||||
|     { "id": 28, "name": "Chaos Fanatic", "rank": 147358, "score": 26 }, | ||||
|     { "id": 29, "name": "Commander Zilyana", "rank": 51973, "score": 287 }, | ||||
|     { "id": 30, "name": "Corporeal Beast", "rank": 2377, "score": 2000 }, | ||||
|     { "id": 31, "name": "Crazy Archaeologist", "rank": 147406, "score": 41 }, | ||||
|     { "id": 32, "name": "Dagannoth Prime", "rank": 32225, "score": 707 }, | ||||
|     { "id": 33, "name": "Dagannoth Rex", "rank": 42229, "score": 698 }, | ||||
|     { "id": 34, "name": "Dagannoth Supreme", "rank": 32212, "score": 714 }, | ||||
|     { "id": 35, "name": "Deranged Archaeologist", "rank": 79605, "score": 25 }, | ||||
|     { "id": 36, "name": "Duke Sucellus", "rank": 9517, "score": 688 }, | ||||
|     { "id": 37, "name": "General Graardor", "rank": 19125, "score": 1228 }, | ||||
|     { "id": 38, "name": "Giant Mole", "rank": 65849, "score": 474 }, | ||||
|     { "id": 39, "name": "Grotesque Guardians", "rank": 2080, "score": 2140 }, | ||||
|     { "id": 40, "name": "Hespori", "rank": 16433, "score": 182 }, | ||||
|     { "id": 41, "name": "Kalphite Queen", "rank": 2006, "score": 2046 }, | ||||
|     { "id": 42, "name": "King Black Dragon", "rank": 48575, "score": 580 }, | ||||
|     { "id": 43, "name": "Kraken", "rank": 115056, "score": 1908 }, | ||||
|     { "id": 44, "name": "Kree'Arra", "rank": 10406, "score": 920 }, | ||||
|     { "id": 45, "name": "K'ril Tsutsaroth", "rank": 2196, "score": 1444 }, | ||||
|     { "id": 46, "name": "Mimic", "rank": 1005, "score": 33 }, | ||||
|     { "id": 47, "name": "Nex", "rank": 28413, "score": 620 }, | ||||
|     { "id": 48, "name": "Nightmare", "rank": 4157, "score": 744 }, | ||||
|     { "id": 49, "name": "Phosani's Nightmare", "rank": 4261, "score": 500 }, | ||||
|     { "id": 50, "name": "Obor", "rank": 993, "score": 217 }, | ||||
|     { "id": 51, "name": "Phantom Muspah", "rank": 21848, "score": 251 }, | ||||
|     { "id": 52, "name": "Sarachnis", "rank": 66260, "score": 119 }, | ||||
|     { "id": 53, "name": "Scorpia", "rank": 108898, "score": 26 }, | ||||
|     { "id": 54, "name": "Skotizo", "rank": 373975, "score": 9 }, | ||||
|     { "id": 55, "name": "Spindel", "rank": 2005, "score": 1569 }, | ||||
|     { "id": 56, "name": "Tempoross", "rank": 40001, "score": 273 }, | ||||
|     { "id": 57, "name": "The Gauntlet", "rank": 192608, "score": 7 }, | ||||
|     { "id": 58, "name": "The Corrupted Gauntlet", "rank": 78367, "score": 201 }, | ||||
|     { "id": 59, "name": "The Leviathan", "rank": 5679, "score": 583 }, | ||||
|     { "id": 60, "name": "The Whisperer", "rank": 478, "score": 1760 }, | ||||
|     { "id": 61, "name": "Theatre of Blood", "rank": 22932, "score": 250 }, | ||||
|     { | ||||
|       "id": 62, | ||||
|       "name": "Theatre of Blood: Hard Mode", | ||||
|       "rank": 15059, | ||||
|       "score": 7 | ||||
|       "name": "Spindel", | ||||
|       "rank": 4276, | ||||
|       "score": 1569 | ||||
|     }, | ||||
|     { | ||||
|       "id": 63, | ||||
|       "name": "Thermonuclear Smoke Devil", | ||||
|       "rank": 7161, | ||||
|       "score": 3066 | ||||
|       "name": "Tempoross", | ||||
|       "rank": 57314, | ||||
|       "score": 273 | ||||
|     }, | ||||
|     { | ||||
|       "id": 64, | ||||
|       "name": "The Gauntlet", | ||||
|       "rank": 256794, | ||||
|       "score": 7 | ||||
|     }, | ||||
|     { "id": 64, "name": "Tombs of Amascut", "rank": 101555, "score": 35 }, | ||||
|     { | ||||
|       "id": 65, | ||||
|       "name": "Tombs of Amascut: Expert Mode", | ||||
|       "rank": 610, | ||||
|       "score": 933 | ||||
|       "name": "The Corrupted Gauntlet", | ||||
|       "rank": 113862, | ||||
|       "score": 201 | ||||
|     }, | ||||
|     { "id": 66, "name": "TzKal-Zuk", "rank": 15733, "score": 2 }, | ||||
|     { "id": 67, "name": "TzTok-Jad", "rank": -1, "score": -1 }, | ||||
|     { "id": 68, "name": "Vardorvis", "rank": 2051, "score": 2078 }, | ||||
|     { "id": 69, "name": "Venenatis", "rank": 194, "score": 7096 }, | ||||
|     { "id": 70, "name": "Vet'ion", "rank": 69260, "score": 51 }, | ||||
|     { "id": 71, "name": "Vorkath", "rank": 14039, "score": 2780 }, | ||||
|     { "id": 72, "name": "Wintertodt", "rank": 876367, "score": 62 }, | ||||
|     { "id": 73, "name": "Zalcano", "rank": 165341, "score": 25 }, | ||||
|     { "id": 74, "name": "Zulrah", "rank": 226318, "score": 275 } | ||||
|     { | ||||
|       "id": 66, | ||||
|       "name": "The Hueycoatl", | ||||
|       "rank": 1969, | ||||
|       "score": 538 | ||||
|     }, | ||||
|     { | ||||
|       "id": 67, | ||||
|       "name": "The Leviathan", | ||||
|       "rank": 12346, | ||||
|       "score": 671 | ||||
|     }, | ||||
|     { | ||||
|       "id": 68, | ||||
|       "name": "The Royal Titans", | ||||
|       "rank": 5606, | ||||
|       "score": 149 | ||||
|     }, | ||||
|     { | ||||
|       "id": 69, | ||||
|       "name": "The Whisperer", | ||||
|       "rank": 550, | ||||
|       "score": 2450 | ||||
|     }, | ||||
|     { | ||||
|       "id": 70, | ||||
|       "name": "Theatre of Blood", | ||||
|       "rank": 25557, | ||||
|       "score": 310 | ||||
|     }, | ||||
|     { | ||||
|       "id": 71, | ||||
|       "name": "Theatre of Blood: Hard Mode", | ||||
|       "rank": 1391, | ||||
|       "score": 538 | ||||
|     }, | ||||
|     { | ||||
|       "id": 72, | ||||
|       "name": "Thermonuclear Smoke Devil", | ||||
|       "rank": 9325, | ||||
|       "score": 3066 | ||||
|     }, | ||||
|     { | ||||
|       "id": 73, | ||||
|       "name": "Tombs of Amascut", | ||||
|       "rank": 131996, | ||||
|       "score": 37 | ||||
|     }, | ||||
|     { | ||||
|       "id": 74, | ||||
|       "name": "Tombs of Amascut: Expert Mode", | ||||
|       "rank": 214, | ||||
|       "score": 1720 | ||||
|     }, | ||||
|     { | ||||
|       "id": 75, | ||||
|       "name": "TzKal-Zuk", | ||||
|       "rank": 8902, | ||||
|       "score": 7 | ||||
|     }, | ||||
|     { | ||||
|       "id": 76, | ||||
|       "name": "TzTok-Jad", | ||||
|       "rank": 148385, | ||||
|       "score": 8 | ||||
|     }, | ||||
|     { | ||||
|       "id": 77, | ||||
|       "name": "Vardorvis", | ||||
|       "rank": 6120, | ||||
|       "score": 2113 | ||||
|     }, | ||||
|     { | ||||
|       "id": 78, | ||||
|       "name": "Venenatis", | ||||
|       "rank": 287, | ||||
|       "score": 7096 | ||||
|     }, | ||||
|     { | ||||
|       "id": 79, | ||||
|       "name": "Vet'ion", | ||||
|       "rank": 97368, | ||||
|       "score": 51 | ||||
|     }, | ||||
|     { | ||||
|       "id": 80, | ||||
|       "name": "Vorkath", | ||||
|       "rank": 15591, | ||||
|       "score": 2780 | ||||
|     }, | ||||
|     { | ||||
|       "id": 81, | ||||
|       "name": "Wintertodt", | ||||
|       "rank": 1000405, | ||||
|       "score": 67 | ||||
|     }, | ||||
|     { | ||||
|       "id": 82, | ||||
|       "name": "Zalcano", | ||||
|       "rank": 213696, | ||||
|       "score": 25 | ||||
|     }, | ||||
|     { | ||||
|       "id": 83, | ||||
|       "name": "Zulrah", | ||||
|       "rank": 240082, | ||||
|       "score": 340 | ||||
|     } | ||||
|   ] | ||||
| } | ||||
| @@ -15,7 +15,10 @@ import { | ||||
|   InvalidFormatError, | ||||
|   BH_MODES, | ||||
|   parseJsonStats, | ||||
|   HiscoresResponse | ||||
|   HiscoresResponse, | ||||
|   InvalidRSNError, | ||||
|   PlayerNotFoundError, | ||||
|   HiScoresError | ||||
| } from '../src/index'; | ||||
|  | ||||
| const B0ATY_NAME = 'B0ATY'; | ||||
| @@ -24,6 +27,8 @@ const LYNX_TITAN_SPACE_NAME = 'lYnX tiTaN'; | ||||
| const LYNX_TITAN_UNDERSCORE_NAME = 'lYnX_tiTaN'; | ||||
| const LYNX_TITAN_HYPHEN_NAME = 'lYnX-tiTaN'; | ||||
| const LYNX_TITAN_FORMATTED_NAME = 'Lynx Titan'; | ||||
| const NON_EXISTENT_NAME = 'nonExistent'; | ||||
| const ERROR_NAME = 'errorName'; | ||||
|  | ||||
| const attackTopPage = readFileSync(`${__dirname}/attackTopPage.html`, 'utf8'); | ||||
| const b0atyNamePage = readFileSync(`${__dirname}/b0atyNamePage.html`, 'utf8'); | ||||
| @@ -57,6 +62,12 @@ jest.spyOn(axios, 'get').mockImplementation((url) => { | ||||
|   if (getStatsURL('main', LYNX_TITAN_FORMATTED_NAME, true) === url) { | ||||
|     return Promise.resolve({ status: 200, data: lynxTitanStats }); | ||||
|   } | ||||
|   if (getPlayerTableURL('main', NON_EXISTENT_NAME) === url) { | ||||
|     return Promise.resolve({ data: '<html></html>' }); | ||||
|   } | ||||
|   if (getPlayerTableURL('main', ERROR_NAME)) { | ||||
|     return Promise.reject(); | ||||
|   } | ||||
|   throw new Error(`No mock response for URL: ${url}`); | ||||
| }); | ||||
|  | ||||
| @@ -102,8 +113,12 @@ test('Parse CSV to json', () => { | ||||
|   13,4057 | ||||
|   37,225 | ||||
|   25,1110 | ||||
|   7827,43249 | ||||
|   1114,1155 | ||||
|   382,2780 | ||||
|   944,3000 | ||||
|   561,398429 | ||||
|   37,111 | ||||
|   704,892 | ||||
|   1981,1452 | ||||
|   4981,23 | ||||
| @@ -131,6 +146,7 @@ test('Parse CSV to json', () => { | ||||
|   41643,1477 | ||||
|   625,2391 | ||||
|   120,2981 | ||||
|   54,2958 | ||||
|   1,109 | ||||
|   99,39002 | ||||
|   3,22666 | ||||
| @@ -139,12 +155,16 @@ test('Parse CSV to json', () => { | ||||
|   44,6233 | ||||
|   201,1101 | ||||
|   82,3404 | ||||
|   555,7079 | ||||
|   5085,61 | ||||
|   8731,1423 | ||||
|   678,903 | ||||
|   18823,23 | ||||
|   63,375 | ||||
|   2870,6 | ||||
|   891,9102 | ||||
|   2871,7 | ||||
|   5606,149 | ||||
|   2872,8 | ||||
|   6984,138 | ||||
|   23,923141 | ||||
| @@ -200,6 +220,8 @@ test('Parse CSV to json', () => { | ||||
|     pvpArena: { rank: 13, score: 4057 }, | ||||
|     soulWarsZeal: { rank: 37, score: 225 }, | ||||
|     riftsClosed: { rank: 25, score: 1110 }, | ||||
|     colosseumGlory: { rank: 7827, score: 43249 }, | ||||
|     collectionsLogged: { rank: 1114, score: 1155 }, | ||||
|     clues: { | ||||
|       all: { rank: 32, score: 12148 }, | ||||
|       beginner: { rank: 3105, score: 76 }, | ||||
| @@ -212,6 +234,8 @@ test('Parse CSV to json', () => { | ||||
|     bosses: { | ||||
|       abyssalSire: { rank: 382, score: 2780 }, | ||||
|       alchemicalHydra: { rank: 944, score: 3000 }, | ||||
|       amoxliatl: { rank: 561, score: 398429 }, | ||||
|       araxxor: { rank: 37, score: 111 }, | ||||
|       artio: { rank: 704, score: 892 }, | ||||
|       barrows: { rank: 1981, score: 1452 }, | ||||
|       bryophyta: { rank: 4981, score: 23 }, | ||||
| @@ -239,6 +263,7 @@ test('Parse CSV to json', () => { | ||||
|       kraken: { rank: 41643, score: 1477 }, | ||||
|       kreeArra: { rank: 625, score: 2391 }, | ||||
|       krilTsutsaroth: { rank: 120, score: 2981 }, | ||||
|       lunarChests: { rank: 54, score: 2958 }, | ||||
|       mimic: { rank: 1, score: 109 }, | ||||
|       nex: { rank: 99, score: 39002 }, | ||||
|       nightmare: { rank: 3, score: 22666 }, | ||||
| @@ -247,12 +272,16 @@ test('Parse CSV to json', () => { | ||||
|       phantomMuspah: { rank: 44, score: 6233 }, | ||||
|       sarachnis: { rank: 201, score: 1101 }, | ||||
|       scorpia: { rank: 82, score: 3404 }, | ||||
|       scurrius: { rank: 555, score: 7079 }, | ||||
|       skotizo: { rank: 5085, score: 61 }, | ||||
|       solHeredit: { rank: 8731, score: 1423 }, | ||||
|       spindel: { rank: 678, score: 903 }, | ||||
|       tempoross: { rank: 18823, score: 23 }, | ||||
|       gauntlet: { rank: 63, score: 375 }, | ||||
|       corruptedGauntlet: { rank: 2870, score: 6 }, | ||||
|       hueycoatl: { rank: 891, score: 9102 }, | ||||
|       leviathan: { rank: 2871, score: 7 }, | ||||
|       royalTitans: { rank: 5606, score: 149 }, | ||||
|       whisperer: { rank: 2872, score: 8 }, | ||||
|       theatreOfBlood: { rank: 6984, score: 138 }, | ||||
|       theatreOfBloodHardMode: { rank: 23, score: 923141 }, | ||||
| @@ -304,7 +333,15 @@ describe('Get name format', () => { | ||||
|     expect(data).toBe(B0ATY_FORMATTED_NAME); | ||||
|   }); | ||||
|   it('throws an error for a name with invalid characters', async () => { | ||||
|     await expect(getRSNFormat('b&aty')).rejects.toBeTruthy(); | ||||
|     await expect(getRSNFormat('b&aty')).rejects.toThrow(InvalidRSNError); | ||||
|   }); | ||||
|   it('throws an error for a non-existent player', async () => { | ||||
|     await expect(getRSNFormat(NON_EXISTENT_NAME)).rejects.toThrow( | ||||
|       PlayerNotFoundError | ||||
|     ); | ||||
|   }); | ||||
|   it('throws an error for a hiscores issue', async () => { | ||||
|     await expect(getRSNFormat(ERROR_NAME)).rejects.toThrow(HiScoresError); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
| @@ -491,7 +528,7 @@ test('Get attack top page', async () => { | ||||
|  | ||||
| test('Get non-existent player', async () => { | ||||
|   getStats('fishy').catch((err) => { | ||||
|     if (err.response) { | ||||
|     if (err?.response) { | ||||
|       expect(err.response.status).toBe(404); | ||||
|     } | ||||
|   }); | ||||
|   | ||||
| @@ -1,14 +1,68 @@ | ||||
| { | ||||
|   "skills": [ | ||||
|     { "id": 0, "name": "Overall", "rank": 1, "level": 2277, "xp": 4600000000 }, | ||||
|     { "id": 1, "name": "Attack", "rank": 15, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 2, "name": "Defence", "rank": 28, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 3, "name": "Strength", "rank": 18, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 4, "name": "Hitpoints", "rank": 7, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 5, "name": "Ranged", "rank": 8, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 6, "name": "Prayer", "rank": 11, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 7, "name": "Magic", "rank": 31, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 8, "name": "Cooking", "rank": 155, "level": 99, "xp": 200000000 }, | ||||
|     { | ||||
|       "id": 0, | ||||
|       "name": "Overall", | ||||
|       "rank": 1, | ||||
|       "level": 2277, | ||||
|       "xp": 4600000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 1, | ||||
|       "name": "Attack", | ||||
|       "rank": 15, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 2, | ||||
|       "name": "Defence", | ||||
|       "rank": 28, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 3, | ||||
|       "name": "Strength", | ||||
|       "rank": 18, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 4, | ||||
|       "name": "Hitpoints", | ||||
|       "rank": 7, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 5, | ||||
|       "name": "Ranged", | ||||
|       "rank": 8, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 6, | ||||
|       "name": "Prayer", | ||||
|       "rank": 11, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 7, | ||||
|       "name": "Magic", | ||||
|       "rank": 30, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 8, | ||||
|       "name": "Cooking", | ||||
|       "rank": 149, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 9, | ||||
|       "name": "Woodcutting", | ||||
| @@ -16,8 +70,20 @@ | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { "id": 10, "name": "Fletching", "rank": 12, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 11, "name": "Fishing", "rank": 9, "level": 99, "xp": 200000000 }, | ||||
|     { | ||||
|       "id": 10, | ||||
|       "name": "Fletching", | ||||
|       "rank": 12, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 11, | ||||
|       "name": "Fishing", | ||||
|       "rank": 9, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 12, | ||||
|       "name": "Firemaking", | ||||
| @@ -25,16 +91,76 @@ | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { "id": 13, "name": "Crafting", "rank": 4, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 14, "name": "Smithing", "rank": 3, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 15, "name": "Mining", "rank": 24, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 16, "name": "Herblore", "rank": 5, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 17, "name": "Agility", "rank": 24, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 18, "name": "Thieving", "rank": 12, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 19, "name": "Slayer", "rank": 2, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 20, "name": "Farming", "rank": 19, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 21, "name": "Runecraft", "rank": 6, "level": 99, "xp": 200000000 }, | ||||
|     { "id": 22, "name": "Hunter", "rank": 4, "level": 99, "xp": 200000000 }, | ||||
|     { | ||||
|       "id": 13, | ||||
|       "name": "Crafting", | ||||
|       "rank": 4, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 14, | ||||
|       "name": "Smithing", | ||||
|       "rank": 3, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 15, | ||||
|       "name": "Mining", | ||||
|       "rank": 23, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 16, | ||||
|       "name": "Herblore", | ||||
|       "rank": 5, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 17, | ||||
|       "name": "Agility", | ||||
|       "rank": 24, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 18, | ||||
|       "name": "Thieving", | ||||
|       "rank": 12, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 19, | ||||
|       "name": "Slayer", | ||||
|       "rank": 2, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 20, | ||||
|       "name": "Farming", | ||||
|       "rank": 19, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 21, | ||||
|       "name": "Runecraft", | ||||
|       "rank": 6, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 22, | ||||
|       "name": "Hunter", | ||||
|       "rank": 3, | ||||
|       "level": 99, | ||||
|       "xp": 200000000 | ||||
|     }, | ||||
|     { | ||||
|       "id": 23, | ||||
|       "name": "Construction", | ||||
| @@ -44,10 +170,30 @@ | ||||
|     } | ||||
|   ], | ||||
|   "activities": [ | ||||
|     { "id": 0, "name": "League Points", "rank": -1, "score": -1 }, | ||||
|     { "id": 1, "name": "Deadman Points", "rank": -1, "score": -1 }, | ||||
|     { "id": 2, "name": "Bounty Hunter - Hunter", "rank": -1, "score": -1 }, | ||||
|     { "id": 3, "name": "Bounty Hunter - Rogue", "rank": -1, "score": -1 }, | ||||
|     { | ||||
|       "id": 0, | ||||
|       "name": "League Points", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 1, | ||||
|       "name": "Deadman Points", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 2, | ||||
|       "name": "Bounty Hunter - Hunter", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 3, | ||||
|       "name": "Bounty Hunter - Rogue", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 4, | ||||
|       "name": "Bounty Hunter (Legacy) - Hunter", | ||||
| @@ -60,89 +206,473 @@ | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { "id": 6, "name": "Clue Scrolls (all)", "rank": 805212, "score": 22 }, | ||||
|     { "id": 7, "name": "Clue Scrolls (beginner)", "rank": -1, "score": -1 }, | ||||
|     { "id": 8, "name": "Clue Scrolls (easy)", "rank": -1, "score": -1 }, | ||||
|     { "id": 9, "name": "Clue Scrolls (medium)", "rank": -1, "score": -1 }, | ||||
|     { "id": 10, "name": "Clue Scrolls (hard)", "rank": 502504, "score": 22 }, | ||||
|     { "id": 11, "name": "Clue Scrolls (elite)", "rank": -1, "score": -1 }, | ||||
|     { "id": 12, "name": "Clue Scrolls (master)", "rank": -1, "score": -1 }, | ||||
|     { "id": 13, "name": "LMS - Rank", "rank": -1, "score": -1 }, | ||||
|     { "id": 14, "name": "PvP Arena - Rank", "rank": -1, "score": -1 }, | ||||
|     { "id": 15, "name": "Soul Wars Zeal", "rank": -1, "score": -1 }, | ||||
|     { "id": 16, "name": "Rifts closed", "rank": -1, "score": -1 }, | ||||
|     { "id": 17, "name": "Abyssal Sire", "rank": -1, "score": -1 }, | ||||
|     { "id": 18, "name": "Alchemical Hydra", "rank": -1, "score": -1 }, | ||||
|     { "id": 19, "name": "Artio", "rank": -1, "score": -1 }, | ||||
|     { "id": 20, "name": "Barrows Chests", "rank": -1, "score": -1 }, | ||||
|     { "id": 21, "name": "Bryophyta", "rank": -1, "score": -1 }, | ||||
|     { "id": 22, "name": "Callisto", "rank": -1, "score": -1 }, | ||||
|     { "id": 23, "name": "Calvar'ion", "rank": -1, "score": -1 }, | ||||
|     { "id": 24, "name": "Cerberus", "rank": -1, "score": -1 }, | ||||
|     { "id": 25, "name": "Chambers of Xeric", "rank": -1, "score": -1 }, | ||||
|     { | ||||
|       "id": 6, | ||||
|       "name": "Clue Scrolls (all)", | ||||
|       "rank": 937868, | ||||
|       "score": 22 | ||||
|     }, | ||||
|     { | ||||
|       "id": 7, | ||||
|       "name": "Clue Scrolls (beginner)", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 8, | ||||
|       "name": "Clue Scrolls (easy)", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 9, | ||||
|       "name": "Clue Scrolls (medium)", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 10, | ||||
|       "name": "Clue Scrolls (hard)", | ||||
|       "rank": 578038, | ||||
|       "score": 22 | ||||
|     }, | ||||
|     { | ||||
|       "id": 11, | ||||
|       "name": "Clue Scrolls (elite)", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 12, | ||||
|       "name": "Clue Scrolls (master)", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 13, | ||||
|       "name": "LMS - Rank", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 14, | ||||
|       "name": "PvP Arena - Rank", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 15, | ||||
|       "name": "Soul Wars Zeal", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 16, | ||||
|       "name": "Rifts closed", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 17, | ||||
|       "name": "Colosseum Glory", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 18, | ||||
|       "name": "Collections Logged", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 19, | ||||
|       "name": "Abyssal Sire", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 20, | ||||
|       "name": "Alchemical Hydra", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 21, | ||||
|       "name": "Amoxliatl", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 22, | ||||
|       "name": "Araxxor", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 23, | ||||
|       "name": "Artio", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 24, | ||||
|       "name": "Barrows Chests", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 25, | ||||
|       "name": "Bryophyta", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 26, | ||||
|       "name": "Callisto", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 27, | ||||
|       "name": "Calvar'ion", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 28, | ||||
|       "name": "Cerberus", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 29, | ||||
|       "name": "Chambers of Xeric", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 30, | ||||
|       "name": "Chambers of Xeric: Challenge Mode", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { "id": 27, "name": "Chaos Elemental", "rank": -1, "score": -1 }, | ||||
|     { "id": 28, "name": "Chaos Fanatic", "rank": -1, "score": -1 }, | ||||
|     { "id": 29, "name": "Commander Zilyana", "rank": -1, "score": -1 }, | ||||
|     { "id": 30, "name": "Corporeal Beast", "rank": -1, "score": -1 }, | ||||
|     { "id": 31, "name": "Crazy Archaeologist", "rank": -1, "score": -1 }, | ||||
|     { "id": 32, "name": "Dagannoth Prime", "rank": -1, "score": -1 }, | ||||
|     { "id": 33, "name": "Dagannoth Rex", "rank": -1, "score": -1 }, | ||||
|     { "id": 34, "name": "Dagannoth Supreme", "rank": -1, "score": -1 }, | ||||
|     { "id": 35, "name": "Deranged Archaeologist", "rank": -1, "score": -1 }, | ||||
|     { "id": 36, "name": "Duke Sucellus", "rank": -1, "score": -1 }, | ||||
|     { "id": 37, "name": "General Graardor", "rank": -1, "score": -1 }, | ||||
|     { "id": 38, "name": "Giant Mole", "rank": -1, "score": -1 }, | ||||
|     { "id": 39, "name": "Grotesque Guardians", "rank": -1, "score": -1 }, | ||||
|     { "id": 40, "name": "Hespori", "rank": -1, "score": -1 }, | ||||
|     { "id": 41, "name": "Kalphite Queen", "rank": -1, "score": -1 }, | ||||
|     { "id": 42, "name": "King Black Dragon", "rank": -1, "score": -1 }, | ||||
|     { "id": 43, "name": "Kraken", "rank": -1, "score": -1 }, | ||||
|     { "id": 44, "name": "Kree'Arra", "rank": -1, "score": -1 }, | ||||
|     { "id": 45, "name": "K'ril Tsutsaroth", "rank": -1, "score": -1 }, | ||||
|     { "id": 46, "name": "Mimic", "rank": -1, "score": -1 }, | ||||
|     { "id": 47, "name": "Nex", "rank": -1, "score": -1 }, | ||||
|     { "id": 48, "name": "Nightmare", "rank": -1, "score": -1 }, | ||||
|     { "id": 49, "name": "Phosani's Nightmare", "rank": -1, "score": -1 }, | ||||
|     { "id": 50, "name": "Obor", "rank": -1, "score": -1 }, | ||||
|     { "id": 51, "name": "Phantom Muspah", "rank": -1, "score": -1 }, | ||||
|     { "id": 52, "name": "Sarachnis", "rank": -1, "score": -1 }, | ||||
|     { "id": 53, "name": "Scorpia", "rank": -1, "score": -1 }, | ||||
|     { "id": 54, "name": "Skotizo", "rank": -1, "score": -1 }, | ||||
|     { "id": 55, "name": "Spindel", "rank": -1, "score": -1 }, | ||||
|     { "id": 56, "name": "Tempoross", "rank": -1, "score": -1 }, | ||||
|     { "id": 57, "name": "The Gauntlet", "rank": -1, "score": -1 }, | ||||
|     { "id": 58, "name": "The Corrupted Gauntlet", "rank": -1, "score": -1 }, | ||||
|     { "id": 59, "name": "The Leviathan", "rank": -1, "score": -1 }, | ||||
|     { "id": 60, "name": "The Whisperer", "rank": -1, "score": -1 }, | ||||
|     { "id": 61, "name": "Theatre of Blood", "rank": -1, "score": -1 }, | ||||
|     { | ||||
|       "id": 31, | ||||
|       "name": "Chaos Elemental", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 32, | ||||
|       "name": "Chaos Fanatic", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 33, | ||||
|       "name": "Commander Zilyana", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 34, | ||||
|       "name": "Corporeal Beast", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 35, | ||||
|       "name": "Crazy Archaeologist", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 36, | ||||
|       "name": "Dagannoth Prime", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 37, | ||||
|       "name": "Dagannoth Rex", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 38, | ||||
|       "name": "Dagannoth Supreme", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 39, | ||||
|       "name": "Deranged Archaeologist", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 40, | ||||
|       "name": "Duke Sucellus", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 41, | ||||
|       "name": "General Graardor", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 42, | ||||
|       "name": "Giant Mole", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 43, | ||||
|       "name": "Grotesque Guardians", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 44, | ||||
|       "name": "Hespori", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 45, | ||||
|       "name": "Kalphite Queen", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 46, | ||||
|       "name": "King Black Dragon", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 47, | ||||
|       "name": "Kraken", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 48, | ||||
|       "name": "Kree'Arra", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 49, | ||||
|       "name": "K'ril Tsutsaroth", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 50, | ||||
|       "name": "Lunar Chests", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 51, | ||||
|       "name": "Mimic", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 52, | ||||
|       "name": "Nex", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 53, | ||||
|       "name": "Nightmare", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 54, | ||||
|       "name": "Phosani's Nightmare", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 55, | ||||
|       "name": "Obor", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 56, | ||||
|       "name": "Phantom Muspah", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 57, | ||||
|       "name": "Sarachnis", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 58, | ||||
|       "name": "Scorpia", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 59, | ||||
|       "name": "Scurrius", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 60, | ||||
|       "name": "Skotizo", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 61, | ||||
|       "name": "Sol Heredit", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 62, | ||||
|       "name": "Spindel", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 63, | ||||
|       "name": "Tempoross", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 64, | ||||
|       "name": "The Gauntlet", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 65, | ||||
|       "name": "The Corrupted Gauntlet", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 66, | ||||
|       "name": "The Hueycoatl", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 67, | ||||
|       "name": "The Leviathan", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 68, | ||||
|       "name": "The Royal Titans", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 69, | ||||
|       "name": "The Whisperer", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 70, | ||||
|       "name": "Theatre of Blood", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 71, | ||||
|       "name": "Theatre of Blood: Hard Mode", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { "id": 63, "name": "Thermonuclear Smoke Devil", "rank": -1, "score": -1 }, | ||||
|     { "id": 64, "name": "Tombs of Amascut", "rank": -1, "score": -1 }, | ||||
|     { | ||||
|       "id": 65, | ||||
|       "id": 72, | ||||
|       "name": "Thermonuclear Smoke Devil", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 73, | ||||
|       "name": "Tombs of Amascut", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 74, | ||||
|       "name": "Tombs of Amascut: Expert Mode", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { "id": 66, "name": "TzKal-Zuk", "rank": -1, "score": -1 }, | ||||
|     { "id": 67, "name": "TzTok-Jad", "rank": 225, "score": 186 }, | ||||
|     { "id": 68, "name": "Vardorvis", "rank": -1, "score": -1 }, | ||||
|     { "id": 69, "name": "Venenatis", "rank": -1, "score": -1 }, | ||||
|     { "id": 70, "name": "Vet'ion", "rank": -1, "score": -1 }, | ||||
|     { "id": 71, "name": "Vorkath", "rank": -1, "score": -1 }, | ||||
|     { "id": 72, "name": "Wintertodt", "rank": -1, "score": -1 }, | ||||
|     { "id": 73, "name": "Zalcano", "rank": -1, "score": -1 }, | ||||
|     { "id": 74, "name": "Zulrah", "rank": -1, "score": -1 } | ||||
|     { | ||||
|       "id": 75, | ||||
|       "name": "TzKal-Zuk", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 76, | ||||
|       "name": "TzTok-Jad", | ||||
|       "rank": 317, | ||||
|       "score": 186 | ||||
|     }, | ||||
|     { | ||||
|       "id": 77, | ||||
|       "name": "Vardorvis", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 78, | ||||
|       "name": "Venenatis", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 79, | ||||
|       "name": "Vet'ion", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 80, | ||||
|       "name": "Vorkath", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 81, | ||||
|       "name": "Wintertodt", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 82, | ||||
|       "name": "Zalcano", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     }, | ||||
|     { | ||||
|       "id": 83, | ||||
|       "name": "Zulrah", | ||||
|       "rank": -1, | ||||
|       "score": -1 | ||||
|     } | ||||
|   ] | ||||
| } | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "osrs-json-hiscores", | ||||
|   "version": "2.16.3", | ||||
|   "version": "2.21.1", | ||||
|   "description": "The Old School Runescape API wrapper that does more!", | ||||
|   "main": "lib/index.js", | ||||
|   "types": "lib/index.d.ts", | ||||
|   | ||||
| @@ -44,7 +44,9 @@ import { | ||||
|   FORMATTED_PVP_ARENA, | ||||
|   FORMATTED_SOUL_WARS, | ||||
|   FORMATTED_RIFTS_CLOSED, | ||||
|   FORMATTED_DEADMAN_POINTS | ||||
|   FORMATTED_DEADMAN_POINTS, | ||||
|   FORMATTED_COLOSSEUM_GLORY, | ||||
|   FORMATTED_COLLECTIONS_LOGGED | ||||
| } from './utils'; | ||||
|  | ||||
| /** | ||||
| @@ -84,11 +86,12 @@ export async function getOfficialStats( | ||||
|  */ | ||||
| export async function getRSNFormat( | ||||
|   rsn: string, | ||||
|   config?: AxiosRequestConfig | ||||
|   config?: AxiosRequestConfig, | ||||
|   mode: Gamemode = 'main' | ||||
| ): Promise<string> { | ||||
|   validateRSN(rsn); | ||||
|  | ||||
|   const url = getPlayerTableURL('main', rsn); | ||||
|   const url = getPlayerTableURL(mode, rsn); | ||||
|   try { | ||||
|     const response = await httpGet<string | Buffer | BinaryData | undefined>( | ||||
|       url, | ||||
| @@ -101,10 +104,10 @@ export async function getRSNFormat( | ||||
|     if (anchor) { | ||||
|       return rsnFromElement(anchor); | ||||
|     } | ||||
|     throw new PlayerNotFoundError(); | ||||
|   } catch { | ||||
|     throw new HiScoresError(); | ||||
|   } | ||||
|   throw new PlayerNotFoundError(); | ||||
| } | ||||
|  | ||||
| /** | ||||
| @@ -162,6 +165,8 @@ export function parseJsonStats(json: HiscoresResponse): Stats { | ||||
|   const pvpArena = getActivity(FORMATTED_PVP_ARENA); | ||||
|   const soulWarsZeal = getActivity(FORMATTED_SOUL_WARS); | ||||
|   const riftsClosed = getActivity(FORMATTED_RIFTS_CLOSED); | ||||
|   const colosseumGlory = getActivity(FORMATTED_COLOSSEUM_GLORY); | ||||
|   const collectionsLogged = getActivity(FORMATTED_COLLECTIONS_LOGGED); | ||||
|  | ||||
|   const stats: Stats = { | ||||
|     skills, | ||||
| @@ -172,6 +177,8 @@ export function parseJsonStats(json: HiscoresResponse): Stats { | ||||
|     pvpArena, | ||||
|     soulWarsZeal, | ||||
|     riftsClosed, | ||||
|     colosseumGlory, | ||||
|     collectionsLogged, | ||||
|     clues, | ||||
|     bosses | ||||
|   }; | ||||
| @@ -221,8 +228,14 @@ export function parseStats(csv: string): Stats { | ||||
|   const [leaguePoints, deadmanPoints] = activityObjects.splice(0, 2); | ||||
|   const bhObjects = activityObjects.splice(0, BH_MODES.length); | ||||
|   const clueObjects = activityObjects.splice(0, CLUES.length); | ||||
|   const [lastManStanding, pvpArena, soulWarsZeal, riftsClosed] = | ||||
|     activityObjects.splice(0, 4); | ||||
|   const [ | ||||
|     lastManStanding, | ||||
|     pvpArena, | ||||
|     soulWarsZeal, | ||||
|     riftsClosed, | ||||
|     colosseumGlory, | ||||
|     collectionsLogged | ||||
|   ] = activityObjects.splice(0, 6); | ||||
|   const bossObjects = activityObjects.splice(0, BOSSES.length); | ||||
|  | ||||
|   const skills: Skills = skillObjects.reduce<Skills>((prev, curr, index) => { | ||||
| @@ -258,6 +271,8 @@ export function parseStats(csv: string): Stats { | ||||
|     pvpArena, | ||||
|     soulWarsZeal, | ||||
|     riftsClosed, | ||||
|     colosseumGlory, | ||||
|     collectionsLogged, | ||||
|     clues, | ||||
|     bosses | ||||
|   }; | ||||
|   | ||||
							
								
								
									
										11
									
								
								src/types.ts
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								src/types.ts
									
									
									
									
									
								
							| @@ -69,6 +69,8 @@ export type BH = { [Type in BHType]: Activity }; | ||||
| export type Boss = | ||||
|   | 'abyssalSire' | ||||
|   | 'alchemicalHydra' | ||||
|   | 'amoxliatl' | ||||
|   | 'araxxor' | ||||
|   | 'artio' | ||||
|   | 'barrows' | ||||
|   | 'bryophyta' | ||||
| @@ -96,6 +98,7 @@ export type Boss = | ||||
|   | 'kraken' | ||||
|   | 'kreeArra' | ||||
|   | 'krilTsutsaroth' | ||||
|   | 'lunarChests' | ||||
|   | 'mimic' | ||||
|   | 'nex' | ||||
|   | 'nightmare' | ||||
| @@ -104,12 +107,16 @@ export type Boss = | ||||
|   | 'phantomMuspah' | ||||
|   | 'sarachnis' | ||||
|   | 'scorpia' | ||||
|   | 'scurrius' | ||||
|   | 'skotizo' | ||||
|   | 'solHeredit' | ||||
|   | 'spindel' | ||||
|   | 'tempoross' | ||||
|   | 'gauntlet' | ||||
|   | 'corruptedGauntlet' | ||||
|   | 'hueycoatl' | ||||
|   | 'leviathan' | ||||
|   | 'royalTitans' | ||||
|   | 'whisperer' | ||||
|   | 'theatreOfBlood' | ||||
|   | 'theatreOfBloodHardMode' | ||||
| @@ -146,6 +153,8 @@ export type ActivityName = | ||||
|   | 'hardClues' | ||||
|   | 'eliteClues' | ||||
|   | 'masterClues' | ||||
|   | 'colosseumGlory' | ||||
|   | 'collectionsLogged' | ||||
|   | Boss; | ||||
|  | ||||
| export interface Stats { | ||||
| @@ -164,6 +173,8 @@ export interface Stats { | ||||
|   pvpArena: Activity; | ||||
|   soulWarsZeal: Activity; | ||||
|   riftsClosed: Activity; | ||||
|   colosseumGlory: Activity; | ||||
|   collectionsLogged: Activity; | ||||
|   bosses: Bosses; | ||||
| } | ||||
| export type Modes = { [M in Gamemode]?: Stats }; | ||||
|   | ||||
| @@ -76,6 +76,8 @@ export const GAMEMODES: Gamemode[] = [ | ||||
| export const BOSSES: Boss[] = [ | ||||
|   'abyssalSire', | ||||
|   'alchemicalHydra', | ||||
|   'amoxliatl', | ||||
|   'araxxor', | ||||
|   'artio', | ||||
|   'barrows', | ||||
|   'bryophyta', | ||||
| @@ -103,6 +105,7 @@ export const BOSSES: Boss[] = [ | ||||
|   'kraken', | ||||
|   'kreeArra', | ||||
|   'krilTsutsaroth', | ||||
|   'lunarChests', | ||||
|   'mimic', | ||||
|   'nex', | ||||
|   'nightmare', | ||||
| @@ -111,12 +114,16 @@ export const BOSSES: Boss[] = [ | ||||
|   'phantomMuspah', | ||||
|   'sarachnis', | ||||
|   'scorpia', | ||||
|   'scurrius', | ||||
|   'skotizo', | ||||
|   'solHeredit', | ||||
|   'spindel', | ||||
|   'tempoross', | ||||
|   'gauntlet', | ||||
|   'corruptedGauntlet', | ||||
|   'hueycoatl', | ||||
|   'leviathan', | ||||
|   'royalTitans', | ||||
|   'whisperer', | ||||
|   'theatreOfBlood', | ||||
|   'theatreOfBloodHardMode', | ||||
| @@ -151,6 +158,8 @@ export const ACTIVITIES: ActivityName[] = [ | ||||
|   'pvpArena', | ||||
|   'soulWarsZeal', | ||||
|   'riftsClosed', | ||||
|   'colosseumGlory', | ||||
|   'collectionsLogged', | ||||
|   ...BOSSES | ||||
| ]; | ||||
|  | ||||
| @@ -161,6 +170,8 @@ export type FormattedBossNames = { | ||||
| export const FORMATTED_BOSS_NAMES: FormattedBossNames = { | ||||
|   abyssalSire: 'Abyssal Sire', | ||||
|   alchemicalHydra: 'Alchemical Hydra', | ||||
|   amoxliatl: 'Amoxliatl', | ||||
|   araxxor: 'Araxxor', | ||||
|   artio: 'Artio', | ||||
|   barrows: 'Barrows Chests', | ||||
|   bryophyta: 'Bryophyta', | ||||
| @@ -188,6 +199,7 @@ export const FORMATTED_BOSS_NAMES: FormattedBossNames = { | ||||
|   kraken: 'Kraken', | ||||
|   kreeArra: "Kree'Arra", | ||||
|   krilTsutsaroth: "K'ril Tsutsaroth", | ||||
|   lunarChests: 'Lunar Chests', | ||||
|   mimic: 'Mimic', | ||||
|   nex: 'Nex', | ||||
|   nightmare: 'Nightmare', | ||||
| @@ -196,12 +208,16 @@ export const FORMATTED_BOSS_NAMES: FormattedBossNames = { | ||||
|   phantomMuspah: 'Phantom Muspah', | ||||
|   sarachnis: 'Sarachnis', | ||||
|   scorpia: 'Scorpia', | ||||
|   scurrius: 'Scurrius', | ||||
|   skotizo: 'Skotizo', | ||||
|   solHeredit: 'Sol Heredit', | ||||
|   spindel: 'Spindel', | ||||
|   tempoross: 'Tempoross', | ||||
|   gauntlet: 'The Gauntlet', | ||||
|   corruptedGauntlet: 'The Corrupted Gauntlet', | ||||
|   hueycoatl: 'The Hueycoatl', | ||||
|   leviathan: 'The Leviathan', | ||||
|   royalTitans: 'The Royal Titans', | ||||
|   whisperer: 'The Whisperer', | ||||
|   theatreOfBlood: 'Theatre of Blood', | ||||
|   theatreOfBloodHardMode: 'Theatre of Blood: Hard Mode', | ||||
| @@ -281,6 +297,8 @@ export const FORMATTED_SOUL_WARS = 'Soul Wars Zeal'; | ||||
| export const FORMATTED_LEAGUE_POINTS = 'League Points'; | ||||
| export const FORMATTED_DEADMAN_POINTS = 'Deadman Points'; | ||||
| export const FORMATTED_RIFTS_CLOSED = 'Rifts closed'; | ||||
| export const FORMATTED_COLOSSEUM_GLORY = 'Colosseum Glory'; | ||||
| export const FORMATTED_COLLECTIONS_LOGGED = 'Collections Logged'; | ||||
|  | ||||
| export const INVALID_FORMAT_ERROR = 'Invalid hiscores format'; | ||||
| export const PLAYER_NOT_FOUND_ERROR = 'Player not found'; | ||||
|   | ||||
| @@ -6,10 +6,7 @@ | ||||
|     "outDir": "./lib", | ||||
|     "strict": true, | ||||
|     "lib": ["ES2015", "DOM", "DOM.Iterable"], | ||||
|     "typeRoots": [ | ||||
|       "./node_modules/@types", | ||||
|       "./src/@types" | ||||
|     ] | ||||
|     "typeRoots": ["./node_modules/@types", "./src/@types"] | ||||
|   }, | ||||
|   "include": ["src"], | ||||
|   "exclude": ["node_modules", "**/__tests__/*"] | ||||
|   | ||||
							
								
								
									
										66
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										66
									
								
								yarn.lock
									
									
									
									
									
								
							| @@ -1288,11 +1288,11 @@ available-typed-arrays@^1.0.5: | ||||
|   integrity sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw== | ||||
|  | ||||
| axios@^1.6.2: | ||||
|   version "1.6.2" | ||||
|   resolved "https://registry.yarnpkg.com/axios/-/axios-1.6.2.tgz#de67d42c755b571d3e698df1b6504cde9b0ee9f2" | ||||
|   integrity sha512-7i24Ri4pmDRfJTR7LDBhsOTtcm+9kjX5WiY1X3wIisx6G9So3pfMkEiU7emUBe46oceVImccTEM3k6C5dbVW8A== | ||||
|   version "1.7.4" | ||||
|   resolved "https://registry.yarnpkg.com/axios/-/axios-1.7.4.tgz#4c8ded1b43683c8dd362973c393f3ede24052aa2" | ||||
|   integrity sha512-DukmaFRnY6AzAALSH4J2M3k6PkaC+MfaAGdEERRWcC9q3/TWQwLpHR8ZRLKTdQ3aBDL64EdluRDjJqKw+BPZEw== | ||||
|   dependencies: | ||||
|     follow-redirects "^1.15.0" | ||||
|     follow-redirects "^1.15.6" | ||||
|     form-data "^4.0.0" | ||||
|     proxy-from-env "^1.1.0" | ||||
|  | ||||
| @@ -1383,12 +1383,12 @@ brace-expansion@^1.1.7: | ||||
|     balanced-match "^1.0.0" | ||||
|     concat-map "0.0.1" | ||||
|  | ||||
| braces@^3.0.1, braces@^3.0.2: | ||||
|   version "3.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" | ||||
|   integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== | ||||
| braces@^3.0.3: | ||||
|   version "3.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.3.tgz#490332f40919452272d55a8480adc0c441358789" | ||||
|   integrity sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA== | ||||
|   dependencies: | ||||
|     fill-range "^7.0.1" | ||||
|     fill-range "^7.1.1" | ||||
|  | ||||
| browserslist@^4.21.9: | ||||
|   version "4.21.9" | ||||
| @@ -1729,9 +1729,9 @@ cosmiconfig@^7.0.0: | ||||
|     yaml "^1.10.0" | ||||
|  | ||||
| cross-spawn@^7.0.2, cross-spawn@^7.0.3: | ||||
|   version "7.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" | ||||
|   integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== | ||||
|   version "7.0.6" | ||||
|   resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.6.tgz#8a58fe78f00dcd70c370451759dfbfaf03e8ee9f" | ||||
|   integrity sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA== | ||||
|   dependencies: | ||||
|     path-key "^3.1.0" | ||||
|     shebang-command "^2.0.0" | ||||
| @@ -2392,10 +2392,10 @@ file-entry-cache@^6.0.1: | ||||
|   dependencies: | ||||
|     flat-cache "^3.0.4" | ||||
|  | ||||
| fill-range@^7.0.1: | ||||
|   version "7.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" | ||||
|   integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== | ||||
| fill-range@^7.1.1: | ||||
|   version "7.1.1" | ||||
|   resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.1.1.tgz#44265d3cac07e3ea7dc247516380643754a05292" | ||||
|   integrity sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg== | ||||
|   dependencies: | ||||
|     to-regex-range "^5.0.1" | ||||
|  | ||||
| @@ -2428,10 +2428,10 @@ flatted@^3.1.0: | ||||
|   resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.1.1.tgz#c4b489e80096d9df1dfc97c79871aea7c617c469" | ||||
|   integrity sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA== | ||||
|  | ||||
| follow-redirects@^1.15.0: | ||||
|   version "1.15.4" | ||||
|   resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.4.tgz#cdc7d308bf6493126b17ea2191ea0ccf3e535adf" | ||||
|   integrity sha512-Cr4D/5wlrb0z9dgERpUL3LrmPKVDsETIJhaCMeDfuFYcqa5bldGV6wBsAN6X/vxlXQtFBMrXdXxdL8CbDTGniw== | ||||
| follow-redirects@^1.15.6: | ||||
|   version "1.15.6" | ||||
|   resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.6.tgz#7f815c0cda4249c74ff09e95ef97c23b5fd0399b" | ||||
|   integrity sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA== | ||||
|  | ||||
| for-each@^0.3.3: | ||||
|   version "0.3.3" | ||||
| @@ -4092,20 +4092,12 @@ merge2@^1.3.0, merge2@^1.4.1: | ||||
|   resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" | ||||
|   integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== | ||||
|  | ||||
| micromatch@^4.0.2: | ||||
|   version "4.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.2.tgz#4fcb0999bf9fbc2fcbdd212f6d629b9a56c39259" | ||||
|   integrity sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q== | ||||
| micromatch@^4.0.2, micromatch@^4.0.4, micromatch@^4.0.5: | ||||
|   version "4.0.8" | ||||
|   resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.8.tgz#d66fa18f3a47076789320b9b1af32bd86d9fa202" | ||||
|   integrity sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA== | ||||
|   dependencies: | ||||
|     braces "^3.0.1" | ||||
|     picomatch "^2.0.5" | ||||
|  | ||||
| micromatch@^4.0.4, micromatch@^4.0.5: | ||||
|   version "4.0.5" | ||||
|   resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" | ||||
|   integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== | ||||
|   dependencies: | ||||
|     braces "^3.0.2" | ||||
|     braces "^3.0.3" | ||||
|     picomatch "^2.3.1" | ||||
|  | ||||
| mime-db@1.45.0: | ||||
| @@ -4667,7 +4659,7 @@ picocolors@^1.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" | ||||
|   integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== | ||||
|  | ||||
| picomatch@^2.0.4, picomatch@^2.0.5, picomatch@^2.2.1: | ||||
| picomatch@^2.0.4, picomatch@^2.2.1: | ||||
|   version "2.2.2" | ||||
|   resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.2.2.tgz#21f333e9b6b8eaff02468f5146ea406d345f4dad" | ||||
|   integrity sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg== | ||||
| @@ -5847,9 +5839,9 @@ write-file-atomic@^4.0.2: | ||||
|     signal-exit "^3.0.7" | ||||
|  | ||||
| ws@^8.13.0: | ||||
|   version "8.13.0" | ||||
|   resolved "https://registry.yarnpkg.com/ws/-/ws-8.13.0.tgz#9a9fb92f93cf41512a0735c8f4dd09b8a1211cd0" | ||||
|   integrity sha512-x9vcZYTrFPC7aSIbj7sRCYo7L/Xb8Iy+pW0ng0wt2vCJv7M9HOMy0UoN3rr+IFC7hb7vXoqS+P9ktyLLLhO+LA== | ||||
|   version "8.17.1" | ||||
|   resolved "https://registry.yarnpkg.com/ws/-/ws-8.17.1.tgz#9293da530bb548febc95371d90f9c878727d919b" | ||||
|   integrity sha512-6XQFvXTkbfUOZOKKILFG1PDK2NDQs4azKQl26T0YS5CxqWLgXajbPZ+h4gZekJyRqFU8pvnbAbbs/3TgRPy+GQ== | ||||
|  | ||||
| xdg-basedir@^4.0.0: | ||||
|   version "4.0.0" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user