mirror of
				https://git.sr.ht/~cadence/bibliogram
				synced 2025-10-26 00:55:37 +00:00 
			
		
		
		
	Handle user not found in assistant
This commit is contained in:
		
							parent
							
								
									b2b84c0663
								
							
						
					
					
						commit
						99213216f7
					
				| @ -76,6 +76,7 @@ async function fetchUser(username, isRSS) { | ||||
| function fetchUserFromHTML(username) { | ||||
| 	return userRequestCache.getOrFetch("user/"+username, false, true, () => { | ||||
| 		return switcher.request("user_html", `https://www.instagram.com/${username}/`, async res => { | ||||
| 			throw constants.symbols.INSTAGRAM_DEMANDS_LOGIN // TEST
 | ||||
| 			if (res.status === 301) throw constants.symbols.ENDPOINT_OVERRIDDEN | ||||
| 			if (res.status === 302) throw constants.symbols.INSTAGRAM_DEMANDS_LOGIN | ||||
| 			if (res.status === 429) throw constants.symbols.RATE_LIMITED | ||||
|  | ||||
| @ -26,9 +26,14 @@ class Assistant { | ||||
| 				if (root.status === "ok") { | ||||
| 					this.lastRequestStatus = constants.symbols.assistant_statuses.OK | ||||
| 					resolve(root.data.user) | ||||
| 				} else { | ||||
| 					this.lastRequestStatus = constants.symbols.assistant_statuses.BLOCKED | ||||
| 					reject(constants.symbols.assistant_statuses.BLOCKED) | ||||
| 				} else { // "fail"
 | ||||
| 					if (root.identifier === "NOT_FOUND") { | ||||
| 						this.lastRequestStatus = constants.symbols.assistant_statuses.OK | ||||
| 						reject(constants.symbols.NOT_FOUND) | ||||
| 					} else { // blocked
 | ||||
| 						this.lastRequestStatus = constants.symbols.assistant_statuses.BLOCKED | ||||
| 						reject(constants.symbols.assistant_statuses.BLOCKED) | ||||
| 					} | ||||
| 				} | ||||
| 			}).catch(error => { | ||||
| 				// console.error(error)
 | ||||
|  | ||||
| @ -25,6 +25,12 @@ class AssistantSwitcher { | ||||
| 					const user = await assistant.requestUser(username) | ||||
| 					return resolve(user) | ||||
| 				} catch (e) { | ||||
| 					if (e === constants.symbols.NOT_FOUND) { | ||||
| 						const rejection = Promise.reject(e) | ||||
| 						rejection.catch(() => {}) // otherwise we get a warning that the rejection was handled asynchronously
 | ||||
| 						collectors.userRequestCache.set(`user/${username}`, false, rejection) | ||||
| 						return reject(e) | ||||
| 					} | ||||
| 					// that assistant broke. try the next one.
 | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| @ -65,6 +65,14 @@ module.exports = [ | ||||
| 							message: "Rate limited by Instagram.", | ||||
| 							identifier: "RATE_LIMITED" | ||||
| 						}) | ||||
| 					} else if (error === constants.symbols.NOT_FOUND || error === constants.symbols.ENDPOINT_OVERRIDDEN) { | ||||
| 						return reply(404, { | ||||
| 							status: "fail", | ||||
| 							version: "1.0", | ||||
| 							generatedAt: Date.now(), | ||||
| 							message: "User not found.", | ||||
| 							identifier: "NOT_FOUND" | ||||
| 						}) | ||||
| 					} else { | ||||
| 						throw error | ||||
| 					} | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user