mirror of
				https://github.com/maxswa/osrs-json-hiscores.git
				synced 2025-10-15 10:19:04 +00:00 
			
		
		
		
	Compare commits
	
		
			8 Commits
		
	
	
		
			toa
			...
			get-rsn-fo
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 2891bbddc4 | ||
|   | b7ae812f45 | ||
|   | b754663f6d | ||
|   | 0678f7c979 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2a60283a93 | ||
|   | b912731cf9 | ||
|   | cf44c57ec6 | ||
|   | 3f34c9ab61 | 
							
								
								
									
										1836
									
								
								__tests__/attackTopPage.html
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1836
									
								
								__tests__/attackTopPage.html
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1880
									
								
								__tests__/b0atyNamePage.html
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1880
									
								
								__tests__/b0atyNamePage.html
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1829
									
								
								__tests__/lynxTitanNamePage.html
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1829
									
								
								__tests__/lynxTitanNamePage.html
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "osrs-json-hiscores", |   "name": "osrs-json-hiscores", | ||||||
|   "version": "2.9.0", |   "version": "2.10.1", | ||||||
|   "description": "The Old School Runescape API wrapper that does more!", |   "description": "The Old School Runescape API wrapper that does more!", | ||||||
|   "main": "lib/index.js", |   "main": "lib/index.js", | ||||||
|   "types": "lib/index.d.ts", |   "types": "lib/index.d.ts", | ||||||
|   | |||||||
| @@ -50,12 +50,11 @@ export async function getRSNFormat(rsn: string): Promise<string> { | |||||||
|   try { |   try { | ||||||
|     const response = await httpGet(url); |     const response = await httpGet(url); | ||||||
|     const dom = new JSDOM(response.data); |     const dom = new JSDOM(response.data); | ||||||
|     const spans = dom.window.document.querySelectorAll( |     const anchor = dom.window.document.querySelector( | ||||||
|       'span[style="color:#AA0022;"]' |       '.personal-hiscores__row.personal-hiscores__row--type-highlight a' | ||||||
|     ); |     ); | ||||||
|     if (spans.length >= 2) { |     if (anchor) { | ||||||
|       const nameSpan = spans[1]; |       return rsnFromElement(anchor); | ||||||
|       return rsnFromElement(nameSpan); |  | ||||||
|     } |     } | ||||||
|     throw Error('Player not found'); |     throw Error('Player not found'); | ||||||
|   } catch { |   } catch { | ||||||
| @@ -75,7 +74,10 @@ export function parseStats(csv: string): Stats { | |||||||
|     .filter((entry) => !!entry) |     .filter((entry) => !!entry) | ||||||
|     .map((stat) => stat.split(',')); |     .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); |     throw Error(INVALID_FORMAT_ERROR); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -105,7 +107,12 @@ export function parseStats(csv: string): Stats { | |||||||
|   const [leaguePoints] = activityObjects.splice(0, 1); |   const [leaguePoints] = activityObjects.splice(0, 1); | ||||||
|   const bhObjects = activityObjects.splice(0, BH_MODES.length); |   const bhObjects = activityObjects.splice(0, BH_MODES.length); | ||||||
|   const clueObjects = activityObjects.splice(0, CLUES.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 bossObjects = activityObjects.splice(0, BOSSES.length); | ||||||
|  |  | ||||||
|   const skills: Skills = skillObjects.reduce<Skills>((prev, curr, index) => { |   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> { | export async function getStats(rsn: string): Promise<Player> { | ||||||
|   if (typeof rsn !== 'string') { |   if (typeof rsn !== 'string') { | ||||||
|     throw Error('RSN must be a 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'); |     throw Error('RSN contains invalid character'); | ||||||
|   } else if (rsn.length > 12 || rsn.length < 1) { |   } else if (rsn.length > 12 || rsn.length < 1) { | ||||||
|     throw Error('RSN must be between 1 and 12 characters'); |     throw Error('RSN must be between 1 and 12 characters'); | ||||||
| @@ -246,7 +253,7 @@ export async function getStatsByGamemode( | |||||||
| ): Promise<Stats> { | ): Promise<Stats> { | ||||||
|   if (typeof rsn !== 'string') { |   if (typeof rsn !== 'string') { | ||||||
|     throw Error('RSN must be a 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'); |     throw Error('RSN contains invalid character'); | ||||||
|   } else if (rsn.length > 12 || rsn.length < 1) { |   } else if (rsn.length > 12 || rsn.length < 1) { | ||||||
|     throw Error('RSN must be between 1 and 12 characters'); |     throw Error('RSN must be between 1 and 12 characters'); | ||||||
|   | |||||||
| @@ -1745,9 +1745,9 @@ decimal.js@^10.2.1: | |||||||
|   integrity sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ== |   integrity sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ== | ||||||
|  |  | ||||||
| decode-uri-component@^0.2.0: | decode-uri-component@^0.2.0: | ||||||
|   version "0.2.0" |   version "0.2.2" | ||||||
|   resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545" |   resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.2.tgz#e69dbe25d37941171dd540e024c444cd5188e1e9" | ||||||
|   integrity sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU= |   integrity sha512-FqUYQ+8o158GyGTrMFJms9qh3CqTKvAqgqsTnkLI8sKu0028orqBhxNMFkFen0zGyg6epACD32pjVk58ngIErQ== | ||||||
|  |  | ||||||
| decompress-response@^3.3.0: | decompress-response@^3.3.0: | ||||||
|   version "3.3.0" |   version "3.3.0" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user