Instagram IDs to username avatar
Instagram IDs to username
Deprecated

Pricing

Pay per usage

Go to Store
Instagram IDs to username

Instagram IDs to username

Deprecated
pocesar/instagram-ids-to-usernames

Developed by

Paulo Cesar

Maintained by Community

Convert Instagram ID numbers back to usernames

0.0 (0)

Pricing

Pay per usage

1

Monthly users

1

Runs succeeded

>99%

Last modified

2 years ago

.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}

Pricing

Pricing model

Pay per usage

This Actor is paid per platform usage. The Actor is free to use, and you only pay for the Apify platform usage.