test-issues-on-by-default avatar

test-issues-on-by-default

Try for free

No credit card required

Go to Store
test-issues-on-by-default

test-issues-on-by-default

mhamas/test-issues-on-by-default
Try for free

No credit card required

Dockerfile

1# This is a template for a Dockerfile used to run acts in Actor system.
2# The base image name below is set during the act build, based on user settings.
3# IMPORTANT: The base image must set a correct working directory, such as /usr/src/app or /home/user
4FROM apify/actor-node
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 --all || true) \
17 && echo "Node.js version:" \
18 && node --version \
19 && echo "NPM version:" \
20 && npm --version
21
22# Copy source code to container
23# Do this in the last step, to have fast build if only the source code changed
24COPY  . ./
25
26# NOTE: The CMD is already defined by the base image.
27# Uncomment this for local node inspector debugging:
28# CMD [ "node", "--inspect=0.0.0.0:9229", "main.js" ]

package.json

1{
2    "name": "apify-project",
3    "version": "0.0.1",
4    "description": "",
5    "author": "It's not you it's me",
6    "license": "ISC",
7    "dependencies": {
8        "apify": "latest",
9        "cheerio": "latest"
10    },
11    "scripts": {
12        "start": "node main.js"
13    }
14}

main.js

1// Import Apify SDK. For more information, see https://sdk.apify.com/
2const Apify = require('apify');
3const cheerio = require('cheerio');
4
5Apify.main(async () => {
6    // Get input of the actor.
7    // If you'd like to have your input checked and have Apify display
8    // a user interface for it, add INPUT_SCHEMA.json file to your actor.
9    // For more information, see https://apify.com/docs/actor/input-schema
10    const input = await Apify.getInput();
11    console.log('Actor input:');
12    console.dir(input);
13
14    // Fetch a HTML of a web page.
15    const url = input.url || 'http://www.example.com';
16    const { body } = await Apify.utils.requestAsBrowser({ url });
17
18    // Parse the HTML
19    const $ = cheerio.load(body);
20    const pageTitle = $('title').text();
21    const caption = $('h1').text();
22
23    // Save the actor output.
24    const output = {
25        pageTitle,
26        caption,
27        crawledAt: new Date(),
28        body,
29    };
30    console.log('Actor output:');
31    console.dir(output);
32    await Apify.setValue('OUTPUT', output);
33});
Developer
Maintained by Community

Actor Metrics

  • 1 monthly user

  • 1 star

  • >99% runs succeeded

  • Created in Oct 2021

  • Modified 3 years ago

Categories