Skip to content
Snippets Groups Projects
settings.py 4.46 KiB
Newer Older
Anton Gusev's avatar
Anton Gusev committed
# -*- coding: utf-8 -*-
import logging
Anton Gusev's avatar
Anton Gusev committed
from dotenv import load_dotenv
import os
true_list = ['True', 'true', 'TRUE', 1, '1']
Anton Gusev's avatar
Anton Gusev committed
load_dotenv()
Anton Gusev's avatar
Anton Gusev committed

# Scrapy settings for tutorial project
#
# For simplicity, this file contains only settings considered important or
# commonly used. You can find more settings consulting the documentation:
#
#     https://doc.scrapy.org/en/latest/topics/settings.html
#     https://doc.scrapy.org/en/latest/topics/downloader-middleware.html
#     https://doc.scrapy.org/en/latest/topics/spider-middleware.html

BOT_NAME = 'tutorial'

Anton Gusev's avatar
Anton Gusev committed
SPIDER_MODULES = ['spiders']
NEWSPIDER_MODULE = 'spiders'
Anton Gusev's avatar
Anton Gusev committed

# Crawl responsibly by identifying yourself (and your website) on the user-agent
Anton Gusev's avatar
Anton Gusev committed
# USER_AGENT = 'tutorial (+http://www.yourdomain.com)'
Anton Gusev's avatar
Anton Gusev committed

# Obey robots.txt rules
ROBOTSTXT_OBEY = True

# Configure maximum concurrent requests performed by Scrapy (default: 16)
Anton Gusev's avatar
Anton Gusev committed
# CONCURRENT_REQUESTS = 32
Anton Gusev's avatar
Anton Gusev committed

# Configure a delay for requests for the same website (default: 0)
# See https://doc.scrapy.org/en/latest/topics/settings.html#download-delay
# See also autothrottle settings and docs
Anton Gusev's avatar
Anton Gusev committed
# DOWNLOAD_DELAY = 3
Anton Gusev's avatar
Anton Gusev committed
# The download delay setting will honor only one of:
Anton Gusev's avatar
Anton Gusev committed
# CONCURRENT_REQUESTS_PER_DOMAIN = 16
# CONCURRENT_REQUESTS_PER_IP = 16
Anton Gusev's avatar
Anton Gusev committed

# Disable cookies (enabled by default)
Anton Gusev's avatar
Anton Gusev committed
# COOKIES_ENABLED = False
Anton Gusev's avatar
Anton Gusev committed

# Disable Telnet Console (enabled by default)
Anton Gusev's avatar
Anton Gusev committed
# TELNETCONSOLE_ENABLED = False
Anton Gusev's avatar
Anton Gusev committed

# Override the default request headers:
Anton Gusev's avatar
Anton Gusev committed
# DEFAULT_REQUEST_HEADERS = {
Anton Gusev's avatar
Anton Gusev committed
#   'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',
#   'Accept-Language': 'en',
Anton Gusev's avatar
Anton Gusev committed
# }
Anton Gusev's avatar
Anton Gusev committed

# Enable or disable spider middlewares
# See https://doc.scrapy.org/en/latest/topics/spider-middleware.html
Anton Gusev's avatar
Anton Gusev committed
# SPIDER_MIDDLEWARES = {
Anton Gusev's avatar
Anton Gusev committed
#    'tutorial.middlewares.TutorialSpiderMiddleware': 543,
Anton Gusev's avatar
Anton Gusev committed
# }
Anton Gusev's avatar
Anton Gusev committed

# Enable or disable downloader middlewares
# See https://doc.scrapy.org/en/latest/topics/downloader-middleware.html
Anton Gusev's avatar
Anton Gusev committed
# DOWNLOADER_MIDDLEWARES = {
Anton Gusev's avatar
Anton Gusev committed
#    'tutorial.middlewares.TutorialDownloaderMiddleware': 543,
Anton Gusev's avatar
Anton Gusev committed
# }
Anton Gusev's avatar
Anton Gusev committed

# Enable or disable extensions
# See https://doc.scrapy.org/en/latest/topics/extensions.html
Anton Gusev's avatar
Anton Gusev committed
# EXTENSIONS = {
Anton Gusev's avatar
Anton Gusev committed
#    'scrapy.extensions.telnet.TelnetConsole': None,
Anton Gusev's avatar
Anton Gusev committed
# }
Anton Gusev's avatar
Anton Gusev committed

# Configure item pipelines
# See https://doc.scrapy.org/en/latest/topics/item-pipeline.html
IMAGES_STORE = './image'
Anton Gusev's avatar
Anton Gusev committed
ITEM_PIPELINES = {
Anton Gusev's avatar
Anton Gusev committed
    'pipelines.DatabaseWriter.DatabaseWriter': 101,
    'pipelines.StatsMailer.StatsMailer': 999,
    'pipelines.StatsWriter.StatsWriter': 1000,
Anton Gusev's avatar
Anton Gusev committed
    'scrapy.pipelines.images.ImagesPipeline': 1,
}
Anton Gusev's avatar
Anton Gusev committed

# Enable and configure the AutoThrottle extension (disabled by default)
# See https://doc.scrapy.org/en/latest/topics/autothrottle.html
Anton Gusev's avatar
Anton Gusev committed
# AUTOTHROTTLE_ENABLED = True
Anton Gusev's avatar
Anton Gusev committed
# The initial download delay
Anton Gusev's avatar
Anton Gusev committed
# AUTOTHROTTLE_START_DELAY = 5
Anton Gusev's avatar
Anton Gusev committed
# The maximum download delay to be set in case of high latencies
Anton Gusev's avatar
Anton Gusev committed
# AUTOTHROTTLE_MAX_DELAY = 60
Anton Gusev's avatar
Anton Gusev committed
# The average number of requests Scrapy should be sending in parallel to
# each remote server
Anton Gusev's avatar
Anton Gusev committed
# AUTOTHROTTLE_TARGET_CONCURRENCY = 1.0
Anton Gusev's avatar
Anton Gusev committed
# Enable showing throttling stats for every response received:
Anton Gusev's avatar
Anton Gusev committed
# AUTOTHROTTLE_DEBUG = False
Anton Gusev's avatar
Anton Gusev committed

# Enable and configure HTTP caching (disabled by default)
# See https://doc.scrapy.org/en/latest/topics/downloader-middleware.html#httpcache-middleware-settings
Anton Gusev's avatar
Anton Gusev committed
# HTTPCACHE_ENABLED = True
# HTTPCACHE_EXPIRATION_SECS = 0
# HTTPCACHE_DIR = 'httpcache'
# HTTPCACHE_IGNORE_HTTP_CODES = []
# HTTPCACHE_STORAGE = 'scrapy.extensions.httpcache.FilesystemCacheStorage'

DB_CONNECTION = os.getenv('DB_CONNECTION')
DB_USERNAME = os.getenv('DB_USERNAME')
DB_PASSWORD = os.getenv('DB_PASSWORD')
DB_HOST = os.getenv('DB_HOST')
DB_PORT = int(os.getenv('DB_PORT'))
DB_DATABASE = os.getenv('DB_DATABASE')
Anton Gusev's avatar
Anton Gusev committed
CONNECTION_STRING = "{drivername}://{user}:{passwd}@{host}:{port}/{db_name}?charset=utf8".format(
    drivername=DB_CONNECTION,
    user=DB_USERNAME,
    passwd=DB_PASSWORD,
    host=DB_HOST,
    port=str(DB_PORT),
    db_name=DB_DATABASE,

# Logger config
Anton Gusev's avatar
Anton Gusev committed
LOG_FILE = os.getenv('LOG_FILE', 'log.log')
LOG_ENABLED = os.getenv('LOG_ENABLED', 'True') in true_list
LOG_LEVEL = logging._nameToLevel.get(os.getenv('LOG_LEVEL', 'INFO'))
Anton Gusev's avatar
Anton Gusev committed
LOG_FORMAT = os.getenv('LOG_FORMAT', '%(asctime)s - %(levelname)s - %(name)s  : \n %(message)s')
LOG_STDOUT = os.getenv('LOG_STDOUT', 'False') in true_list
LOG_SHORT_NAMES = False
# LOG_DATEFORMAT
Anton Gusev's avatar
Anton Gusev committed

# Mail config
MAIL_FROM = os.getenv('MAIL_FROM', 'scrapy@localhost')
MAIL_HOST = os.getenv('MAIL_HOST')
MAIL_PORT = int(os.getenv('MAIL_PORT', 465))
Anton Gusev's avatar
Anton Gusev committed
MAIL_USER = os.getenv('MAIL_USER')
MAIL_PASS = os.getenv('MAIL_PASS')
MAIL_TLS = os.getenv('MAIL_TLS', 'False') in true_list
MAIL_SSL = os.getenv('MAIL_SSL', 'True') in true_list