mirror of
				https://github.com/maxswa/osrs-json-hiscores.git
				synced 2025-10-15 10:19:04 +00:00 
			
		
		
		
	Compare commits
	
		
			22 Commits
		
	
	
		
			v2.9.0
			...
			account-bu
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | b2bdd3d2ce | ||
|   | efbcdfc709 | ||
|   | fe913aba1f | ||
|   | 1497653bab | ||
|   | f76de38eb1 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2f1d10b309 | ||
|   | f08424cb81 | ||
|   | 69088db3b6 | ||
|   | 9cc89735cd | ||
|   | a126ae4fc7 | ||
|   | 52f3df1838 | ||
|   | 2891bbddc4 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e2ea2fe33d | ||
|   | b7ae812f45 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 240628d9cc | ||
|   | b754663f6d | ||
|   | 0678f7c979 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2a60283a93 | ||
|   | b912731cf9 | ||
|   | cf44c57ec6 | ||
|   | 3f34c9ab61 | ||
|   | 1ef73b6b0c | 
| @@ -3,7 +3,7 @@ | ||||
| [](https://www.npmjs.com/package/osrs-json-hiscores) | ||||
| [](https://npm-stat.com/charts.html?package=osrs-json-hiscores) | ||||
| [](https://github.com/maxswa/osrs-json-hiscores/blob/master/src/types.ts) | ||||
| [](https://github.com/maxswa/osrs-json-hiscores/actions/workflows/main.yml?query=branch%3Amain) | ||||
| [](https://github.com/maxswa/osrs-json-hiscores/actions/workflows/main.yml?query=branch%3Amain) | ||||
|  | ||||
| **The Old School Runescape API wrapper that does more!** | ||||
|  | ||||
| @@ -154,6 +154,7 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | ||||
| | The Nightmare of Ashihama         |          `nightmare`           | | ||||
| | Phosani's Nightmare               |      `phosanisNightmare`       | | ||||
| | Obor                              |             `obor`             | | ||||
| | Phantom Muspah                    |        `phantomMuspah`         | | ||||
| | Sarachnis                         |          `sarachnis`           | | ||||
| | Scorpia                           |           `scorpia`            | | ||||
| | Skotizo                           |           `skotizo`            | | ||||
| @@ -163,6 +164,8 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | ||||
| | Theatre Of Blood                  |        `theatreOfBlood`        | | ||||
| | Theatre Of Blood: Hard Mode       |    `theatreOfBloodHardMode`    | | ||||
| | Thermonuclear Smoke Devil         |   `thermonuclearSmokeDevil`    | | ||||
| | Tombs of Amascut                  |        `tombsOfAmascut`        | | ||||
| | Tombs of Amascut: Expert Mode     |   `tombsOfAmascutExpertMode`   | | ||||
| | TzKal-Zuk                         |           `tzKalZuk`           | | ||||
| | TzTok-Jad                         |           `tzTokJad`           | | ||||
| | Venenatis                         |          `venenatis`           | | ||||
|   | ||||
							
								
								
									
										1336
									
								
								__tests__/attackTopPage.html
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1336
									
								
								__tests__/attackTopPage.html
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1400
									
								
								__tests__/b0atyNamePage.html
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1400
									
								
								__tests__/b0atyNamePage.html
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -121,6 +121,7 @@ test('Parse CSV to json', () => { | ||||
|   3,22666 | ||||
|   2,84 | ||||
|   26,323 | ||||
|   44,6233 | ||||
|   201,1101 | ||||
|   82,3404 | ||||
|   5085,61 | ||||
| @@ -130,6 +131,8 @@ test('Parse CSV to json', () => { | ||||
|   6984,138 | ||||
|   23,923141 | ||||
|   4043,2000 | ||||
|   4073,1020 | ||||
|   289,13070 | ||||
|   489,8 | ||||
|   967,47 | ||||
|   11155,223 | ||||
| @@ -216,6 +219,7 @@ test('Parse CSV to json', () => { | ||||
|       nightmare: { rank: 3, score: 22666 }, | ||||
|       phosanisNightmare: { rank: 2, score: 84 }, | ||||
|       obor: { rank: 26, score: 323 }, | ||||
|       phantomMuspah: { rank: 44, score: 6233 }, | ||||
|       sarachnis: { rank: 201, score: 1101 }, | ||||
|       scorpia: { rank: 82, score: 3404 }, | ||||
|       skotizo: { rank: 5085, score: 61 }, | ||||
| @@ -225,6 +229,8 @@ test('Parse CSV to json', () => { | ||||
|       theatreOfBlood: { rank: 6984, score: 138 }, | ||||
|       theatreOfBloodHardMode: { rank: 23, score: 923141 }, | ||||
|       thermonuclearSmokeDevil: { rank: 4043, score: 2000 }, | ||||
|       tombsOfAmascut: { rank: 4073, score: 1020 }, | ||||
|       tombsOfAmascutExpertMode: { rank: 289, score: 13070 }, | ||||
|       tzKalZuk: { rank: 489, score: 8 }, | ||||
|       tzTokJad: { rank: 967, score: 47 }, | ||||
|       venenatis: { rank: 11155, score: 223 }, | ||||
| @@ -240,9 +246,11 @@ test('Parse CSV to json', () => { | ||||
| }); | ||||
|  | ||||
| test('Parse CSV with unknown activity', () => { | ||||
|   const statsWithUnknownActivity = lynxTitanStats + ` | ||||
|   const statsWithUnknownActivity = `${lynxTitanStats} | ||||
|     -1,-1`; | ||||
|   expect(() => parseStats(statsWithUnknownActivity)).toThrow(INVALID_FORMAT_ERROR); | ||||
|   expect(() => parseStats(statsWithUnknownActivity)).toThrow( | ||||
|     INVALID_FORMAT_ERROR | ||||
|   ); | ||||
| }); | ||||
|  | ||||
| test('Parse invalid CSV', () => { | ||||
|   | ||||
							
								
								
									
										1337
									
								
								__tests__/lynxTitanNamePage.html
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1337
									
								
								__tests__/lynxTitanNamePage.html
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -84,3 +84,6 @@ | ||||
| -1,-1 | ||||
| -1,-1 | ||||
| -1,-1 | ||||
| -1,-1 | ||||
| -1,-1 | ||||
| -1,-1 | ||||
| Can't render this file because it has a wrong number of fields in line 25. | 
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "osrs-json-hiscores", | ||||
|   "version": "2.9.0", | ||||
|   "version": "2.11.0", | ||||
|   "description": "The Old School Runescape API wrapper that does more!", | ||||
|   "main": "lib/index.js", | ||||
|   "types": "lib/index.d.ts", | ||||
|   | ||||
| @@ -50,12 +50,11 @@ export async function getRSNFormat(rsn: string): Promise<string> { | ||||
|   try { | ||||
|     const response = await httpGet(url); | ||||
|     const dom = new JSDOM(response.data); | ||||
|     const spans = dom.window.document.querySelectorAll( | ||||
|       'span[style="color:#AA0022;"]' | ||||
|     const anchor = dom.window.document.querySelector( | ||||
|       '.personal-hiscores__row.personal-hiscores__row--type-highlight a' | ||||
|     ); | ||||
|     if (spans.length >= 2) { | ||||
|       const nameSpan = spans[1]; | ||||
|       return rsnFromElement(nameSpan); | ||||
|     if (anchor) { | ||||
|       return rsnFromElement(anchor); | ||||
|     } | ||||
|     throw Error('Player not found'); | ||||
|   } catch { | ||||
| @@ -75,7 +74,10 @@ export function parseStats(csv: string): Stats { | ||||
|     .filter((entry) => !!entry) | ||||
|     .map((stat) => stat.split(',')); | ||||
|  | ||||
|   if (splitCSV.length !== SKILLS.length + BH_MODES.length + CLUES.length + BOSSES.length + 5) { | ||||
|   if ( | ||||
|     splitCSV.length !== | ||||
|     SKILLS.length + BH_MODES.length + CLUES.length + BOSSES.length + 5 | ||||
|   ) { | ||||
|     throw Error(INVALID_FORMAT_ERROR); | ||||
|   } | ||||
|  | ||||
| @@ -105,7 +107,12 @@ export function parseStats(csv: string): Stats { | ||||
|   const [leaguePoints] = activityObjects.splice(0, 1); | ||||
|   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 | ||||
|   ] = activityObjects.splice(0, 4); | ||||
|   const bossObjects = activityObjects.splice(0, BOSSES.length); | ||||
|  | ||||
|   const skills: Skills = skillObjects.reduce<Skills>((prev, curr, index) => { | ||||
| @@ -159,7 +166,7 @@ export function parseStats(csv: string): Stats { | ||||
| export async function getStats(rsn: string): Promise<Player> { | ||||
|   if (typeof rsn !== 'string') { | ||||
|     throw Error('RSN must be a string'); | ||||
|   } else if (!/^[a-zA-Z0-9 _]+$/.test(rsn)) { | ||||
|   } else if (!/^[a-zA-Z0-9 _-]+$/.test(rsn)) { | ||||
|     throw Error('RSN contains invalid character'); | ||||
|   } else if (rsn.length > 12 || rsn.length < 1) { | ||||
|     throw Error('RSN must be between 1 and 12 characters'); | ||||
| @@ -246,7 +253,7 @@ export async function getStatsByGamemode( | ||||
| ): Promise<Stats> { | ||||
|   if (typeof rsn !== 'string') { | ||||
|     throw Error('RSN must be a string'); | ||||
|   } else if (!/^[a-zA-Z0-9 _]+$/.test(rsn)) { | ||||
|   } else if (!/^[a-zA-Z0-9 _-]+$/.test(rsn)) { | ||||
|     throw Error('RSN contains invalid character'); | ||||
|   } else if (rsn.length > 12 || rsn.length < 1) { | ||||
|     throw Error('RSN must be between 1 and 12 characters'); | ||||
|   | ||||
| @@ -5,7 +5,10 @@ export type Gamemode = | ||||
|   | 'hardcore' | ||||
|   | 'deadman' | ||||
|   | 'seasonal' | ||||
|   | 'tournament'; | ||||
|   | 'tournament' | ||||
|   | 'skiller' | ||||
|   | 'oneDefence' | ||||
|   | 'freshStart'; | ||||
|  | ||||
| export interface Skill { | ||||
|   rank: number; | ||||
| @@ -93,6 +96,7 @@ export type Boss = | ||||
|   | 'nightmare' | ||||
|   | 'phosanisNightmare' | ||||
|   | 'obor' | ||||
|   | 'phantomMuspah' | ||||
|   | 'sarachnis' | ||||
|   | 'scorpia' | ||||
|   | 'skotizo' | ||||
| @@ -102,6 +106,8 @@ export type Boss = | ||||
|   | 'theatreOfBlood' | ||||
|   | 'theatreOfBloodHardMode' | ||||
|   | 'thermonuclearSmokeDevil' | ||||
|   | 'tombsOfAmascut' | ||||
|   | 'tombsOfAmascutExpertMode' | ||||
|   | 'tzKalZuk' | ||||
|   | 'tzTokJad' | ||||
|   | 'venenatis' | ||||
|   | ||||
| @@ -22,7 +22,10 @@ export const GAMEMODE_URL: GamemodeUrl = { | ||||
|   ultimate: `${BASE_URL}_ultimate/`, | ||||
|   deadman: `${BASE_URL}_deadman/`, | ||||
|   seasonal: `${BASE_URL}_seasonal/`, | ||||
|   tournament: `${BASE_URL}_tournament/` | ||||
|   tournament: `${BASE_URL}_tournament/`, | ||||
|   skiller: `${BASE_URL}_skiller/`, | ||||
|   oneDefence: `${BASE_URL}_skiller_defence/`, | ||||
|   freshStart: `${BASE_URL}_fresh_start/` | ||||
| }; | ||||
| export const SKILLS: SkillName[] = [ | ||||
|   'overall', | ||||
| @@ -101,6 +104,7 @@ export const BOSSES: Boss[] = [ | ||||
|   'nightmare', | ||||
|   'phosanisNightmare', | ||||
|   'obor', | ||||
|   'phantomMuspah', | ||||
|   'sarachnis', | ||||
|   'scorpia', | ||||
|   'skotizo', | ||||
| @@ -110,6 +114,8 @@ export const BOSSES: Boss[] = [ | ||||
|   'theatreOfBlood', | ||||
|   'theatreOfBloodHardMode', | ||||
|   'thermonuclearSmokeDevil', | ||||
|   'tombsOfAmascut', | ||||
|   'tombsOfAmascutExpertMode', | ||||
|   'tzKalZuk', | ||||
|   'tzTokJad', | ||||
|   'venenatis', | ||||
| @@ -173,6 +179,7 @@ export const FORMATTED_BOSS_NAMES: FormattedBossNames = { | ||||
|   nightmare: 'The Nightmare of Ashihama', | ||||
|   phosanisNightmare: "Phosani's Nightmare", | ||||
|   obor: 'Obor', | ||||
|   phantomMuspah: 'Phantom Muspah', | ||||
|   sarachnis: 'Sarachnis', | ||||
|   scorpia: 'Scorpia', | ||||
|   skotizo: 'Skotizo', | ||||
| @@ -182,6 +189,8 @@ export const FORMATTED_BOSS_NAMES: FormattedBossNames = { | ||||
|   theatreOfBlood: 'Theatre of Blood', | ||||
|   theatreOfBloodHardMode: 'Theatre of Blood: Hard Mode', | ||||
|   thermonuclearSmokeDevil: 'Thermonuclear Smoke Devil', | ||||
|   tombsOfAmascut: 'Tombs of Amascut', | ||||
|   tombsOfAmascutExpertMode: 'Tombs of Amascut: Expert Mode', | ||||
|   tzKalZuk: 'TzKal-Zuk', | ||||
|   tzTokJad: 'TzTok-Jad', | ||||
|   venenatis: 'Venenatis', | ||||
|   | ||||
							
								
								
									
										38
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								yarn.lock
									
									
									
									
									
								
							| @@ -1186,9 +1186,9 @@ babel-preset-jest@^26.6.2: | ||||
|     babel-preset-current-node-syntax "^1.0.0" | ||||
|  | ||||
| balanced-match@^1.0.0: | ||||
|   version "1.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767" | ||||
|   integrity sha1-ibTRmasr7kneFk6gK4nORi1xt2c= | ||||
|   version "1.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" | ||||
|   integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== | ||||
|  | ||||
| base@^0.11.1: | ||||
|   version "0.11.2" | ||||
| @@ -1576,7 +1576,7 @@ component-emitter@^1.2.1: | ||||
| concat-map@0.0.1: | ||||
|   version "0.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" | ||||
|   integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s= | ||||
|   integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== | ||||
|  | ||||
| configstore@^5.0.1: | ||||
|   version "5.0.1" | ||||
| @@ -1745,9 +1745,9 @@ decimal.js@^10.2.1: | ||||
|   integrity sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ== | ||||
|  | ||||
| decode-uri-component@^0.2.0: | ||||
|   version "0.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545" | ||||
|   integrity sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU= | ||||
|   version "0.2.2" | ||||
|   resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.2.tgz#e69dbe25d37941171dd540e024c444cd5188e1e9" | ||||
|   integrity sha512-FqUYQ+8o158GyGTrMFJms9qh3CqTKvAqgqsTnkLI8sKu0028orqBhxNMFkFen0zGyg6epACD32pjVk58ngIErQ== | ||||
|  | ||||
| decompress-response@^3.3.0: | ||||
|   version "3.3.0" | ||||
| @@ -3823,9 +3823,9 @@ json5@2.x, json5@^2.1.2: | ||||
|     minimist "^1.2.5" | ||||
|  | ||||
| json5@^1.0.1: | ||||
|   version "1.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.1.tgz#779fb0018604fa854eacbf6252180d83543e3dbe" | ||||
|   integrity sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow== | ||||
|   version "1.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.2.tgz#63d98d60f21b313b77c4d6da18bfa69d80e1d593" | ||||
|   integrity sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA== | ||||
|   dependencies: | ||||
|     minimist "^1.2.0" | ||||
|  | ||||
| @@ -4279,9 +4279,9 @@ min-indent@^1.0.0: | ||||
|   integrity sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg== | ||||
|  | ||||
| minimatch@^3.0.4: | ||||
|   version "3.0.4" | ||||
|   resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" | ||||
|   integrity sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA== | ||||
|   version "3.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" | ||||
|   integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== | ||||
|   dependencies: | ||||
|     brace-expansion "^1.1.7" | ||||
|  | ||||
| @@ -4295,9 +4295,9 @@ minimist-options@^4.0.2: | ||||
|     kind-of "^6.0.3" | ||||
|  | ||||
| minimist@^1.1.1, minimist@^1.2.0, minimist@^1.2.5: | ||||
|   version "1.2.6" | ||||
|   resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.6.tgz#8637a5b759ea0d6e98702cfb3a9283323c93af44" | ||||
|   integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== | ||||
|   version "1.2.7" | ||||
|   resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.7.tgz#daa1c4d91f507390437c6a8bc01078e7000c4d18" | ||||
|   integrity sha512-bzfL1YUZsP41gmu/qjrEk0Q6i2ix/cVeAhbCbqH9u3zYutS1cLg00qhrD0M2MVdCcx4Sc0UpP2eBWo9rotpq6g== | ||||
|  | ||||
| mixin-deep@^1.2.0: | ||||
|   version "1.3.2" | ||||
| @@ -4996,9 +4996,9 @@ pupa@^2.0.1: | ||||
|     escape-goat "^2.0.0" | ||||
|  | ||||
| qs@~6.5.2: | ||||
|   version "6.5.2" | ||||
|   resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.2.tgz#cb3ae806e8740444584ef154ce8ee98d403f3e36" | ||||
|   integrity sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA== | ||||
|   version "6.5.3" | ||||
|   resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.3.tgz#3aeeffc91967ef6e35c0e488ef46fb296ab76aad" | ||||
|   integrity sha512-qxXIEh4pCGfHICj1mAJQ2/2XVZkjCDTcEgfoSQxc/fYivUZxTkk7L3bDBJSoNrEzXI17oUO5Dp07ktqE5KzczA== | ||||
|  | ||||
| queue-microtask@^1.2.2: | ||||
|   version "1.2.3" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user