Instagram IDs to username
Go to Store
This Actor is unavailable because the developer has decided to deprecate it. Would you like to try a similar Actor instead?
See alternative ActorsInstagram IDs to username
pocesar/instagram-ids-to-usernames
Convert Instagram ID numbers back to usernames
.editorconfig
1root = true
2
3[*]
4indent_style = space
5indent_size = 4
6charset = utf-8
7trim_trailing_whitespace = true
8insert_final_newline = true
9end_of_line = lf
.eslintrc
1{
2 "extends": "@apify"
3}
.gitignore
1# This file tells Git which files shouldn't be added to source control
2
3.idea
4node_modules
Dockerfile
1# First, specify the base Docker image. You can read more about
2# the available images at https://sdk.apify.com/docs/guides/docker-images
3# You can also use any other image from Docker Hub.
4FROM apify/actor-node:16
5
6# Second, copy just package.json and package-lock.json since it should be
7# the only file that affects "npm install" in the next step, to speed up the build
8COPY package*.json ./
9
10# Install NPM packages, skip optional and development dependencies to
11# keep the image small. Avoid logging too much and print the dependency
12# tree for debugging
13RUN npm --quiet set progress=false \
14 && npm install --only=prod --no-optional \
15 && echo "Installed NPM packages:" \
16 && (npm list --only=prod --no-optional --all || true) \
17 && echo "Node.js version:" \
18 && node --version \
19 && echo "NPM version:" \
20 && npm --version
21
22# Next, copy the remaining files and directories with the source code.
23# Since we do this after NPM install, quick build will be really fast
24# for most source file changes.
25COPY . ./
26
27# Optionally, specify how to launch the source code of your actor.
28# By default, Apify's base Docker images define the CMD instruction
29# that runs the Node.js source code using the command specified
30# in the "scripts.start" section of the package.json file.
31# In short, the instruction looks something like this:
32#
33# CMD npm start
INPUT_SCHEMA.json
1{
2 "title": "Input schema for the apify_project actor.",
3 "type": "object",
4 "schemaVersion": 1,
5 "properties": {
6 "ids": {
7 "title": "Instagram Ids",
8 "type": "array",
9 "default": [],
10 "prefill": ["297604134"],
11 "description": "Get the usernames of given Instagram Ids",
12 "editor": "stringList"
13 }
14 },
15 "required": []
16}
apify.json
1{
2 "env": { "npm_config_loglevel": "silent" }
3}
main.js
1// This is the main Node.js source code file of your actor.
2
3// Import Apify SDK. For more information, see https://sdk.apify.com/
4const Apify = require('apify');
5
6const { log } = Apify.utils;
7
8const isNumber = (s) => +s == s;
9const addRequest = (id, userData) => ({ url: `https://i.instagram.com/api/v1/users/${id}/info/`, userData });
10
11Apify.main(async () => {
12 const { ids, resource } = await Apify.getInput();
13
14 const requestQueue = await Apify.openRequestQueue();
15 let count = 0;
16
17 if (resource?.defaultDatasetId) {
18 const dataset = await Apify.openDataset(resource.defaultDatasetId);
19
20 await dataset.forEach(async (item) => {
21 const id = [
22 item.ownerId,
23 item.owner,
24 ].filter(isNumber).map(String);
25
26 if (id[0]) {
27 await requestQueue.addRequest(addRequest(id[0], item));
28 count++;
29 }
30 });
31
32 if (resource?.defaultKeyValueStoreId) {
33 const kv = await Apify.openKeyValueStore(resource?.defaultKeyValueStoreId);
34 const { defaultDatasetId, actorRunId } = Apify.getEnv();
35
36 await Promise.all([
37 kv.setValue('DATASET_ID', defaultDatasetId),
38 kv.setValue('RUN_ID', actorRunId),
39 ]);
40 }
41 }
42
43 for (const id of (ids ?? [])) {
44 await requestQueue.addRequest(addRequest(id));
45 count++;
46 }
47
48 const proxyConfiguration = await Apify.createProxyConfiguration({
49 groups: ['RESIDENTIAL'],
50 });
51
52 const idCount = await requestQueue.getInfo().then(({ totalRequestCount }) => totalRequestCount || count);
53
54 log.info(`Going to fetch information for ${idCount} ids`);
55
56 const crawler = new Apify.CheerioCrawler({
57 requestQueue,
58 proxyConfiguration,
59 preNavigationHooks: [async (context, requestAsBrowserOptions) => {
60 requestAsBrowserOptions.headers = {
61 ...requestAsBrowserOptions.headers,
62 "Accept": "*/*",
63 "Alt-Used": "i.instagram.com",
64 "Accept-Language": "en-US,en",
65 "X-IG-App-ID": "936619743392459",
66 "X-ASBD-ID": "198387",
67 "X-IG-WWW-Claim": "0",
68 "Origin": "https://www.instagram.com",
69 "Referrer": "https://www.instagram.com/",
70 };
71 }],
72 handlePageFunction: async (context) => {
73 const { request, json } = context;
74
75 if (json?.status !== "ok") {
76 throw new Error(`Got wrong status "${json?.status ?? json?.message ?? '-'}"`);
77 }
78
79 if (!json?.user) {
80 throw new Error(`Missing user property from response`);
81 }
82
83 await Apify.pushData({
84 ...json.user,
85 url: `https://www.instagram.com/${json.user.username}`,
86 ...request.userData,
87 });
88 }
89 });
90
91 await crawler.run();
92});
package.json
1{
2 "name": "project-empty",
3 "version": "0.0.1",
4 "description": "This is a boilerplate of an Apify actor.",
5 "dependencies": {
6 "apify": "^2.3.2"
7 },
8 "scripts": {
9 "start": "node main.js",
10 "lint": "./node_modules/.bin/eslint ./src --ext .js,.jsx",
11 "lint:fix": "./node_modules/.bin/eslint ./src --ext .js,.jsx --fix",
12 "test": "echo \"Error: oops, the actor has no tests yet, sad!\" && exit 1"
13 },
14 "author": "It's not you it's me",
15 "license": "ISC"
16}
Developer
Maintained by Community
Categories