mirror of
				https://github.com/maxswa/osrs-json-hiscores.git
				synced 2025-10-15 10:19:04 +00:00 
			
		
		
		
	Compare commits
	
		
			23 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 5d9f6a6bac | ||
|   | 8737b50a82 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1255e7e3d2 | ||
|   | f4135d0b0f | ||
|   | 6135ff459c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 9fb7e4cebc | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 11350b2444 | ||
|   | e0d6c5b20f | ||
|   | c8a4440ac3 | ||
|   | f3781cf142 | ||
|   | 5fbc04217b | ||
|   | eb5d0ba49f | ||
|   | c68e3bebea | ||
|   | aa6fd6f39a | ||
|   | cc9aae8ced | ||
|   | 12882b4e34 | ||
|   | b17a8b9299 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 50f2c19257 | ||
|   | d892f8e67b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | af5664ae6e | ||
|   | 20c5c2f730 | ||
|   | 04e59cff04 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ad2249ba76 | 
| @@ -148,7 +148,9 @@ Activities consist of all levels of clue scrolls as well as minigames and bosses | |||||||
| | Kreearra                          |           `kreeArra`           | | | Kreearra                          |           `kreeArra`           | | ||||||
| | K'ril Tsutsaroth                  |        `krilTsutsaroth`        | | | K'ril Tsutsaroth                  |        `krilTsutsaroth`        | | ||||||
| | Mimic                             |            `mimic`             | | | Mimic                             |            `mimic`             | | ||||||
|  | | Nex                               |             `nex`              | | ||||||
| | The Nightmare of Ashihama         |          `nightmare`           | | | The Nightmare of Ashihama         |          `nightmare`           | | ||||||
|  | | Phosani's Nightmare               |      `phosanisNightmare`       | | ||||||
| | Obor                              |             `obor`             | | | Obor                              |             `obor`             | | ||||||
| | Sarachnis                         |          `sarachnis`           | | | Sarachnis                         |          `sarachnis`           | | ||||||
| | Scorpia                           |           `scorpia`            | | | Scorpia                           |           `scorpia`            | | ||||||
|   | |||||||
| @@ -1,82 +0,0 @@ | |||||||
| 1,2277,4600000000 |  | ||||||
| 15,99,200000000 |  | ||||||
| 28,99,200000000 |  | ||||||
| 18,99,200000000 |  | ||||||
| 7,99,200000000 |  | ||||||
| 8,99,200000000 |  | ||||||
| 11,99,200000000 |  | ||||||
| 32,99,200000000 |  | ||||||
| 159,99,200000000 |  | ||||||
| 15,99,200000000 |  | ||||||
| 12,99,200000000 |  | ||||||
| 9,99,200000000 |  | ||||||
| 48,99,200000000 |  | ||||||
| 4,99,200000000 |  | ||||||
| 3,99,200000000 |  | ||||||
| 25,99,200000000 |  | ||||||
| 5,99,200000000 |  | ||||||
| 23,99,200000000 |  | ||||||
| 12,99,200000000 |  | ||||||
| 2,99,200000000 |  | ||||||
| 19,99,200000000 |  | ||||||
| 7,99,200000000 |  | ||||||
| 4,99,200000000 |  | ||||||
| 4,99,200000000 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| 347584,22 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -1,-1 |  | ||||||
| -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. | 
| @@ -11,8 +11,7 @@ import { | |||||||
|   getPlayerTableURL, |   getPlayerTableURL, | ||||||
|   getSkillPageURL, |   getSkillPageURL, | ||||||
|   getStatsURL, |   getStatsURL, | ||||||
|   BOSSES, |   BOSSES | ||||||
|   Boss |  | ||||||
| } from '../src/index'; | } from '../src/index'; | ||||||
|  |  | ||||||
| const B0ATY_NAME = 'B0ATY'; | const B0ATY_NAME = 'B0ATY'; | ||||||
| @@ -21,7 +20,6 @@ const LYNX_TITAN_SPACE_NAME = 'lYnX tiTaN'; | |||||||
| const LYNX_TITAN_UNDERSCORE_NAME = 'lYnX_tiTaN'; | const LYNX_TITAN_UNDERSCORE_NAME = 'lYnX_tiTaN'; | ||||||
| const LYNX_TITAN_HYPHEN_NAME = 'lYnX-tiTaN'; | const LYNX_TITAN_HYPHEN_NAME = 'lYnX-tiTaN'; | ||||||
| const LYNX_TITAN_FORMATTED_NAME = 'Lynx Titan'; | const LYNX_TITAN_FORMATTED_NAME = 'Lynx Titan'; | ||||||
| const FYSAD_FORMATTED_NAME = 'Fysad'; |  | ||||||
|  |  | ||||||
| const attackTopPage = readFileSync(`${__dirname}/attackTopPage.html`, 'utf8'); | const attackTopPage = readFileSync(`${__dirname}/attackTopPage.html`, 'utf8'); | ||||||
| const b0atyNamePage = readFileSync(`${__dirname}/b0atyNamePage.html`, 'utf8'); | const b0atyNamePage = readFileSync(`${__dirname}/b0atyNamePage.html`, 'utf8'); | ||||||
| @@ -30,7 +28,6 @@ const lynxTitanNamePage = readFileSync( | |||||||
|   `${__dirname}/lynxTitanNamePage.html`, |   `${__dirname}/lynxTitanNamePage.html`, | ||||||
|   'utf8' |   'utf8' | ||||||
| ); | ); | ||||||
| const fysadStatsSeasonal = readFileSync(`${__dirname}/fysadStatsSeasonal.csv`, 'utf8'); |  | ||||||
|  |  | ||||||
| jest.spyOn(axios, 'get').mockImplementation((url) => { | jest.spyOn(axios, 'get').mockImplementation((url) => { | ||||||
|   const lynxUrls = [ |   const lynxUrls = [ | ||||||
| @@ -50,9 +47,6 @@ jest.spyOn(axios, 'get').mockImplementation((url) => { | |||||||
|   if (getStatsURL('main', LYNX_TITAN_FORMATTED_NAME) === url) { |   if (getStatsURL('main', LYNX_TITAN_FORMATTED_NAME) === url) { | ||||||
|     return Promise.resolve({ status: 200, data: lynxTitanStats }); |     return Promise.resolve({ status: 200, data: lynxTitanStats }); | ||||||
|   } |   } | ||||||
|   if (getStatsURL('seasonal', FYSAD_FORMATTED_NAME) === url) { |  | ||||||
|     return Promise.resolve({ status: 200, data: fysadStatsSeasonal }); |  | ||||||
|   } |  | ||||||
|   throw new Error(`No mock response for URL: ${url}`); |   throw new Error(`No mock response for URL: ${url}`); | ||||||
| }); | }); | ||||||
|  |  | ||||||
| @@ -120,7 +114,9 @@ test('Parse CSV to json', () => { | |||||||
|   625,2391 |   625,2391 | ||||||
|   120,2981 |   120,2981 | ||||||
|   1,109 |   1,109 | ||||||
|  |   99,39002 | ||||||
|   3,22666 |   3,22666 | ||||||
|  |   2,84 | ||||||
|   26,323 |   26,323 | ||||||
|   201,1101 |   201,1101 | ||||||
|   82,3404 |   82,3404 | ||||||
| @@ -211,7 +207,9 @@ test('Parse CSV to json', () => { | |||||||
|       kreeArra: { rank: 625, score: 2391 }, |       kreeArra: { rank: 625, score: 2391 }, | ||||||
|       krilTsutsaroth: { rank: 120, score: 2981 }, |       krilTsutsaroth: { rank: 120, score: 2981 }, | ||||||
|       mimic: { rank: 1, score: 109 }, |       mimic: { rank: 1, score: 109 }, | ||||||
|  |       nex: { rank: 99, score: 39002 }, | ||||||
|       nightmare: { rank: 3, score: 22666 }, |       nightmare: { rank: 3, score: 22666 }, | ||||||
|  |       phosanisNightmare: { rank: 2, score: 84 }, | ||||||
|       obor: { rank: 26, score: 323 }, |       obor: { rank: 26, score: 323 }, | ||||||
|       sarachnis: { rank: 201, score: 1101 }, |       sarachnis: { rank: 201, score: 1101 }, | ||||||
|       scorpia: { rank: 82, score: 3404 }, |       scorpia: { rank: 82, score: 3404 }, | ||||||
| @@ -448,8 +446,10 @@ test('Get non-existent player', async () => { | |||||||
| }); | }); | ||||||
|  |  | ||||||
| test('Get stats by gamemode', async () => { | test('Get stats by gamemode', async () => { | ||||||
|   const { skills, bosses } = await getStatsByGamemode(LYNX_TITAN_FORMATTED_NAME); |   const { skills, bosses } = await getStatsByGamemode( | ||||||
|    |     LYNX_TITAN_FORMATTED_NAME | ||||||
|  |   ); | ||||||
|  |  | ||||||
|   expect(skills).toMatchObject({ |   expect(skills).toMatchObject({ | ||||||
|     overall: { rank: expect.any(Number), level: 2277, xp: 4600000000 }, |     overall: { rank: expect.any(Number), level: 2277, xp: 4600000000 }, | ||||||
|     attack: { rank: expect.any(Number), level: 99, xp: 200000000 }, |     attack: { rank: expect.any(Number), level: 99, xp: 200000000 }, | ||||||
| @@ -482,15 +482,3 @@ test('Get stats by gamemode', async () => { | |||||||
|  |  | ||||||
|   expect.assertions(2); |   expect.assertions(2); | ||||||
| }); | }); | ||||||
|  |  | ||||||
| test('Get stats by game mode seasonal (omit TOB: Hard Mode from bosses)', async () => { |  | ||||||
|   const {bosses} = await getStatsByGamemode(FYSAD_FORMATTED_NAME, 'seasonal'); |  | ||||||
|   const bossKeys = Object.keys(bosses); |  | ||||||
|  |  | ||||||
|   const filteredBosses = BOSSES.filter(boss => boss !== 'theatreOfBloodHardMode'); |  | ||||||
|  |  | ||||||
|   expect(bossKeys).toStrictEqual(filteredBosses); |  | ||||||
|   expect(bossKeys).not.toContain<Boss>('theatreOfBloodHardMode'); |  | ||||||
|  |  | ||||||
|   expect.assertions(2); |  | ||||||
| }); |  | ||||||
|   | |||||||
| @@ -79,4 +79,5 @@ | |||||||
| -1,-1 | -1,-1 | ||||||
| -1,-1 | -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", |   "name": "osrs-json-hiscores", | ||||||
|   "version": "2.5.1", |   "version": "2.6.0", | ||||||
|   "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", | ||||||
|   | |||||||
| @@ -68,7 +68,7 @@ export async function getRSNFormat(rsn: string): Promise<string> { | |||||||
|  * @param csv Raw CSV from the official OSRS API. |  * @param csv Raw CSV from the official OSRS API. | ||||||
|  * @returns Parsed stats object. |  * @returns Parsed stats object. | ||||||
|  */ |  */ | ||||||
| export function parseStats(csv: string, mode: Gamemode = 'main'): Stats { | export function parseStats(csv: string): Stats { | ||||||
|   const splitCSV = csv |   const splitCSV = csv | ||||||
|     .split('\n') |     .split('\n') | ||||||
|     .filter((entry) => !!entry) |     .filter((entry) => !!entry) | ||||||
| @@ -97,17 +97,11 @@ export function parseStats(csv: string, mode: Gamemode = 'main'): Stats { | |||||||
|       return activity; |       return activity; | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|   /** `seasonal` API results don't currently include TOB: Hard Mode, so it needs to be filtered out in that case. */ |  | ||||||
|   const filteredBosses = |  | ||||||
|     mode === 'seasonal' |  | ||||||
|       ? BOSSES.filter((boss) => boss !== 'theatreOfBloodHardMode') |  | ||||||
|       : BOSSES; |  | ||||||
|  |  | ||||||
|   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, soulWarsZeal] = activityObjects.splice(0, 2); |   const [lastManStanding, soulWarsZeal] = activityObjects.splice(0, 2); | ||||||
|   const bossObjects = activityObjects.splice(0, filteredBosses.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) => { | ||||||
|     const newSkills = { ...prev }; |     const newSkills = { ...prev }; | ||||||
| @@ -129,7 +123,7 @@ export function parseStats(csv: string, mode: Gamemode = 'main'): Stats { | |||||||
|  |  | ||||||
|   const bosses: Bosses = bossObjects.reduce<Bosses>((prev, curr, index) => { |   const bosses: Bosses = bossObjects.reduce<Bosses>((prev, curr, index) => { | ||||||
|     const newBosses = { ...prev }; |     const newBosses = { ...prev }; | ||||||
|     newBosses[filteredBosses[index]] = curr; |     newBosses[BOSSES[index]] = curr; | ||||||
|     return newBosses; |     return newBosses; | ||||||
|   }, {} as Bosses); |   }, {} as Bosses); | ||||||
|  |  | ||||||
| @@ -256,7 +250,7 @@ export async function getStatsByGamemode( | |||||||
|   if (response.status !== 200) { |   if (response.status !== 200) { | ||||||
|     throw Error('Player not found'); |     throw Error('Player not found'); | ||||||
|   } |   } | ||||||
|   const stats = parseStats(response.data, mode); |   const stats = parseStats(response.data); | ||||||
|  |  | ||||||
|   return stats; |   return stats; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -89,7 +89,9 @@ export type Boss = | |||||||
|   | 'kreeArra' |   | 'kreeArra' | ||||||
|   | 'krilTsutsaroth' |   | 'krilTsutsaroth' | ||||||
|   | 'mimic' |   | 'mimic' | ||||||
|  |   | 'nex' | ||||||
|   | 'nightmare' |   | 'nightmare' | ||||||
|  |   | 'phosanisNightmare' | ||||||
|   | 'obor' |   | 'obor' | ||||||
|   | 'sarachnis' |   | 'sarachnis' | ||||||
|   | 'scorpia' |   | 'scorpia' | ||||||
|   | |||||||
| @@ -97,7 +97,9 @@ export const BOSSES: Boss[] = [ | |||||||
|   'kreeArra', |   'kreeArra', | ||||||
|   'krilTsutsaroth', |   'krilTsutsaroth', | ||||||
|   'mimic', |   'mimic', | ||||||
|  |   'nex', | ||||||
|   'nightmare', |   'nightmare', | ||||||
|  |   'phosanisNightmare', | ||||||
|   'obor', |   'obor', | ||||||
|   'sarachnis', |   'sarachnis', | ||||||
|   'scorpia', |   'scorpia', | ||||||
| @@ -165,7 +167,9 @@ export const FORMATTED_BOSS_NAMES: FormattedBossNames = { | |||||||
|   kreeArra: "Kree'Arra", |   kreeArra: "Kree'Arra", | ||||||
|   krilTsutsaroth: "K'ril Tsutsaroth", |   krilTsutsaroth: "K'ril Tsutsaroth", | ||||||
|   mimic: 'Mimic', |   mimic: 'Mimic', | ||||||
|  |   nex: 'Nex', | ||||||
|   nightmare: 'The Nightmare of Ashihama', |   nightmare: 'The Nightmare of Ashihama', | ||||||
|  |   phosanisNightmare: "Phosani's Nightmare", | ||||||
|   obor: 'Obor', |   obor: 'Obor', | ||||||
|   sarachnis: 'Sarachnis', |   sarachnis: 'Sarachnis', | ||||||
|   scorpia: 'Scorpia', |   scorpia: 'Scorpia', | ||||||
|   | |||||||
							
								
								
									
										46
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										46
									
								
								yarn.lock
									
									
									
									
									
								
							| @@ -1108,11 +1108,11 @@ axe-core@^4.0.2: | |||||||
|   integrity sha512-vwPpH4Aj4122EW38mxO/fxhGKtwWTMLDIJfZ1He0Edbtjcfna/R3YB67yVhezUMzqc3Jr3+Ii50KRntlENL4xQ== |   integrity sha512-vwPpH4Aj4122EW38mxO/fxhGKtwWTMLDIJfZ1He0Edbtjcfna/R3YB67yVhezUMzqc3Jr3+Ii50KRntlENL4xQ== | ||||||
|  |  | ||||||
| axios@^0.21.1: | axios@^0.21.1: | ||||||
|   version "0.21.1" |   version "0.21.2" | ||||||
|   resolved "https://registry.yarnpkg.com/axios/-/axios-0.21.1.tgz#22563481962f4d6bde9a76d516ef0e5d3c09b2b8" |   resolved "https://registry.yarnpkg.com/axios/-/axios-0.21.2.tgz#21297d5084b2aeeb422f5d38e7be4fbb82239017" | ||||||
|   integrity sha512-dKQiRHxGD9PPRIUNIWvZhPTPpl1rf/OxTYKsqKUDjBwYylTvV7SjSHJb9ratfyzM6wCdLCOYLzs73qpg5c4iGA== |   integrity sha512-87otirqUw3e8CzHTMO+/9kh/FSgXt/eVDvipijwDtEuwbkySWZ9SBm6VEubmJ/kLKEoLQV/POhxXFb66bfekfg== | ||||||
|   dependencies: |   dependencies: | ||||||
|     follow-redirects "^1.10.0" |     follow-redirects "^1.14.0" | ||||||
|  |  | ||||||
| axobject-query@^2.2.0: | axobject-query@^2.2.0: | ||||||
|   version "2.2.0" |   version "2.2.0" | ||||||
| @@ -2459,10 +2459,10 @@ flatted@^3.1.0: | |||||||
|   resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.1.1.tgz#c4b489e80096d9df1dfc97c79871aea7c617c469" |   resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.1.1.tgz#c4b489e80096d9df1dfc97c79871aea7c617c469" | ||||||
|   integrity sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA== |   integrity sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA== | ||||||
|  |  | ||||||
| follow-redirects@^1.10.0: | follow-redirects@^1.14.0: | ||||||
|   version "1.13.1" |   version "1.14.4" | ||||||
|   resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.13.1.tgz#5f69b813376cee4fd0474a3aba835df04ab763b7" |   resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.14.4.tgz#838fdf48a8bbdd79e52ee51fb1c94e3ed98b9379" | ||||||
|   integrity sha512-SSG5xmZh1mkPGyKzjZP8zLjltIfpW32Y5QpdNJyjcfGxK3qo3NDDkZOZSFiGn1A6SclQxY9GzEwAHQ3dmYRWpg== |   integrity sha512-zwGkiSXC1MUJG/qmeIFH2HBJx9u0V46QGUe3YR1fXG8bXQxq7fLj0RjLZQ5nubr9qNJUZrH+xUcwXEoXNpfS+g== | ||||||
|  |  | ||||||
| for-in@^1.0.2: | for-in@^1.0.2: | ||||||
|   version "1.0.2" |   version "1.0.2" | ||||||
| @@ -2775,9 +2775,9 @@ has@^1.0.3: | |||||||
|     function-bind "^1.1.1" |     function-bind "^1.1.1" | ||||||
|  |  | ||||||
| hosted-git-info@^2.1.4: | hosted-git-info@^2.1.4: | ||||||
|   version "2.8.8" |   version "2.8.9" | ||||||
|   resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.8.tgz#7539bd4bc1e0e0a895815a2e0262420b12858488" |   resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.9.tgz#dffc0bf9a21c02209090f2aa69429e1414daf3f9" | ||||||
|   integrity sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg== |   integrity sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw== | ||||||
|  |  | ||||||
| hosted-git-info@^3.0.0: | hosted-git-info@^3.0.0: | ||||||
|   version "3.0.8" |   version "3.0.8" | ||||||
| @@ -4411,9 +4411,9 @@ normalize-path@^3.0.0: | |||||||
|   integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== |   integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== | ||||||
|  |  | ||||||
| normalize-url@^4.1.0: | normalize-url@^4.1.0: | ||||||
|   version "4.5.0" |   version "4.5.1" | ||||||
|   resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-4.5.0.tgz#453354087e6ca96957bd8f5baf753f5982142129" |   resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-4.5.1.tgz#0dd90cf1288ee1d1313b87081c9a5932ee48518a" | ||||||
|   integrity sha512-2s47yzUxdexf1OhyRi4Em83iQk0aPvwTddtFz4hnSSw9dCEsLEGf6SwIO8ss/19S9iBb5sJaOuTvTGDeZI00BQ== |   integrity sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA== | ||||||
|  |  | ||||||
| normalize-version@^1.0.5: | normalize-version@^1.0.5: | ||||||
|   version "1.0.5" |   version "1.0.5" | ||||||
| @@ -4837,9 +4837,9 @@ path-key@^3.0.0, path-key@^3.1.0: | |||||||
|   integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== |   integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== | ||||||
|  |  | ||||||
| path-parse@^1.0.6: | path-parse@^1.0.6: | ||||||
|   version "1.0.6" |   version "1.0.7" | ||||||
|   resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.6.tgz#d62dbb5679405d72c4737ec58600e9ddcf06d24c" |   resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" | ||||||
|   integrity sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw== |   integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== | ||||||
|  |  | ||||||
| path-type@^2.0.0: | path-type@^2.0.0: | ||||||
|   version "2.0.0" |   version "2.0.0" | ||||||
| @@ -5892,9 +5892,9 @@ tmp@^0.0.33: | |||||||
|     os-tmpdir "~1.0.2" |     os-tmpdir "~1.0.2" | ||||||
|  |  | ||||||
| tmpl@1.0.x: | tmpl@1.0.x: | ||||||
|   version "1.0.4" |   version "1.0.5" | ||||||
|   resolved "https://registry.yarnpkg.com/tmpl/-/tmpl-1.0.4.tgz#23640dd7b42d00433911140820e5cf440e521dd1" |   resolved "https://registry.yarnpkg.com/tmpl/-/tmpl-1.0.5.tgz#8683e0b902bb9c20c4f726e3c0b69f36518c07cc" | ||||||
|   integrity sha1-I2QN17QtAEM5ERQIIOXPRA5SHdE= |   integrity sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw== | ||||||
|  |  | ||||||
| to-fast-properties@^2.0.0: | to-fast-properties@^2.0.0: | ||||||
|   version "2.0.0" |   version "2.0.0" | ||||||
| @@ -5968,9 +5968,9 @@ tr46@^2.0.2: | |||||||
|     punycode "^2.1.1" |     punycode "^2.1.1" | ||||||
|  |  | ||||||
| trim-newlines@^3.0.0: | trim-newlines@^3.0.0: | ||||||
|   version "3.0.0" |   version "3.0.1" | ||||||
|   resolved "https://registry.yarnpkg.com/trim-newlines/-/trim-newlines-3.0.0.tgz#79726304a6a898aa8373427298d54c2ee8b1cb30" |   resolved "https://registry.yarnpkg.com/trim-newlines/-/trim-newlines-3.0.1.tgz#260a5d962d8b752425b32f3a7db0dcacd176c144" | ||||||
|   integrity sha512-C4+gOpvmxaSMKuEf9Qc134F1ZuOHVXKRbtEflf4NTtuuJDEIJ9p5PXsalL8SkeRw+qit1Mo+yuvMPAKwWg/1hA== |   integrity sha512-c1PTsA3tYrIsLGkJkzHF+w9F2EyxfXGo4UyJc4pFL++FMjnq0HJS69T3M7d//gKrFKwy429bouPescbjecU+Zw== | ||||||
|  |  | ||||||
| ts-jest@^26.5.4: | ts-jest@^26.5.4: | ||||||
|   version "26.5.4" |   version "26.5.4" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user