diff --git a/.circleci/config.yml b/.circleci/config.yml
new file mode 100644
index 00000000..1ab1287e
--- /dev/null
+++ b/.circleci/config.yml
@@ -0,0 +1,40 @@
+version: 2.1
+
+orbs:
+ python: circleci/python@1.3.2
+ docker: circleci/docker@1.5.0
+
+jobs:
+ build-and-test:
+ executor: python/default
+ environment:
+ TEST: True
+ steps:
+ - checkout
+ - setup_remote_docker
+ - docker/install-docker-compose
+ - run:
+ command: |
+ python -m pip install --upgrade pip
+ pip install pylint
+ pip install -r requirements.txt
+ pip install scrapy-autounit
+ name: Install dependencies
+ - run:
+ command: |
+ scrapy crawl espn-live
+ scrapy crawl espn-players
+ python3 -m unittest discover autounit/tests/
+ name: Crawler Test with autounit
+ - run:
+ command: |
+ pylint app -E
+ pylint app --exit-zero
+ name: Lint with pylint
+ - run:
+ name: Test with pytest
+ command: sudo docker-compose -f docker/docker-compose-test.yaml up --build --exit-code-from test
+workflows:
+ main:
+ jobs:
+ - build-and-test
diff --git a/.github/workflows/python-app.yml b/.github/workflows/python-app.yml
deleted file mode 100644
index dc6b1694..00000000
--- a/.github/workflows/python-app.yml
+++ /dev/null
@@ -1,38 +0,0 @@
-# This workflow will install Python dependencies, run tests and lint with a single version of Python
-# For more information see: https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions
-
-name: Python application
-
-on:
- push:
- branches: [ master , 'feature-*']
- pull_request:
- branches: [ master , 'feature-*']
-
-jobs:
- build:
- strategy:
- matrix:
- platform: [ubuntu-latest, windows-latest, macos-latest]
- runs-on: ${{ matrix.platform }}
-
- steps:
- - uses: actions/checkout@v2
- - name: Set up Python 3.8
- uses: actions/setup-python@v2
- with:
- python-version: 3.8
- - name: Install dependencies
- run: |
- python -m pip install --upgrade pip
- pip install pylint pytest
- pip install -r requirements.txt
- - name: Lint with pylint
- run: |
- # stop the build if there are Python syntax errors or undefined names
- pylint app -E
- # exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide
- pylint app --exit-zero
- - name: Test with pytest
- run: |
- pytest
diff --git a/.gitignore b/.gitignore
index 1b77d315..0d9261e0 100644
--- a/.gitignore
+++ b/.gitignore
@@ -67,6 +67,7 @@ instance/
# Scrapy stuff:
.scrapy
+autounit
# Sphinx documentation
docs/_build/
diff --git a/Dockerfile.development b/Dockerfile.development
deleted file mode 100644
index 3396e521..00000000
--- a/Dockerfile.development
+++ /dev/null
@@ -1,16 +0,0 @@
-
-FROM python:3.8-slim as build
-
-WORKDIR /
-
-COPY ./requirements.txt ./requirements.txt
-RUN apt-get update && \
- apt-get -y install gcc mono-mcs && \
- rm -rf /var/lib/apt/lists/*
-RUN pip install -r requirements.txt
-
-COPY ./app /app
-COPY ./crawler /crawler
-COPY ./scrapy.cfg /scrapy.cfg
-
-ENTRYPOINT ["uvicorn", "app.main:app"]
\ No newline at end of file
diff --git a/README.md b/README.md
old mode 100644
new mode 100755
index 1c750ad8..d15428e2
--- a/README.md
+++ b/README.md
@@ -8,7 +8,7 @@ In the past year or so fantasy cricket has been getting a lot of traction and wi
1. [FastAPI](https://fastapi.tiangolo.com/)
2. [sklearn](https://scikit-learn.org/stable/)
-3. [pycricbuzz](https://github.com/codophobia/pycricbuzz)
+3. [scrapyrt](https://scrapyrt.readthedocs.io/en/stable/)
4. [scrapy](https://docs.scrapy.org/en/latest/)
Install using
@@ -16,7 +16,7 @@ Install using
pip3 install -r requirements.txt
```
-## I want to run your project
+## Local Development
To run our project follow these steps
@@ -27,24 +27,57 @@ To run our project follow these steps
cd Best11-Fantasycricket
```
-3. Run the model :
+3.
+ **Linux and MACOS**
+
+ 1. Type `nano /etc/hosts` on your terminal or open `/etc/hosts` on your prefered editor
+
+ **Windows**
+ 1. Open `C:\windows\system32\drivers\etc\hosts` in your prefered editor
+
+
+ 2. And add the below line to the the file and save
+
+ `127.0.0.1 espncricinfo`
+
+ **OR**
+
+ 1. Open `app/fantasy_cricket/scrapyrt_client.py` in your prefered editor
+
+ 2. Change line `16` to
+
+ ```python
+ self.url = "http://localhost:9080/crawl.json"
+ ```
+
+4. Open a tab on your terminal and run
`uvicorn app.main:app`
-5. `Open http://localhost:8000/` and voila!!
+5. Open another tab on your terminal and run
+
+`scrapyrt`
+
+
+6. Open `http://localhost:8000/` and voila!!
+
+**Note:**
+Visit `http://localhost:9080/crawl.json` with the correct queries to see the crawler api
### Docker
1. Follow the steps:
- ```bash
- docker build -t best11fantasycricket:latest "."
- ```
```bash
- docker-compose up
+ docker build -t espncricinfo:latest "." -f docker/espncricinfo/Dockerfile
+ docker build -t best11:latest "." -f docker/11tastic/Dockerfile
+ docker-compose -f docker/docker-compose.yaml up
```
-2. Visit `http://localhost:8080/`
+2. Visit `http://localhost:8080/` to see the website in action
+
+**Note**
+ Visit `http://localhost:9080/crawl.json` with the correct queries to see the crawler api
## How do I contribute to this project????
@@ -69,9 +102,9 @@ If you have any questions regarding our project , you can contact any of the mai
### Acknowledgements
-1. Special thanks to [scientes](https://github.com/scientes) for setting up the basic webcrawler
+1. Special thanks to [scientes](https://github.com/scientes) for allowing us to use the server to host the website
-2. We would like to thank [Howstat](http://www.howstat.com/cricket/home.asp) for their amazing website with daily updates and availabilty to scrape
+2. We would like to thank [espncricinfo](https://www.espncricinfo.com/) for their amazing website with daily updates and availabilty to scrape
If you liked our project we would really appreciate you starring this repo.
diff --git a/app/__init__.py b/app/__init__.py
old mode 100644
new mode 100755
diff --git a/app/fantasy_cricket/__init__.py b/app/fantasy_cricket/__init__.py
old mode 100644
new mode 100755
diff --git a/app/fantasy_cricket/data/flags.json b/app/fantasy_cricket/data/flags.json
deleted file mode 100644
index 91df0982..00000000
--- a/app/fantasy_cricket/data/flags.json
+++ /dev/null
@@ -1,37 +0,0 @@
-{
- "countries": {
- "India": {
- "flag": ""
- },
- "England": {
- "flag": ""
- },
- "Australia": {
- "flag": ""
- },
- "Bangladesh": {
- "flag": ""
- },
- "New Zealand": {
- "flag": ""
- },
- "South Africa": {
- "flag": ""
- },
- "West Indies": {
- "flag": ""
- },
- "Pakistan": {
- "flag": ""
- },
- "Ireland": {
- "flag": ""
- },
- "Afghanistan": {
- "flag": ""
- },
- "Sri Lanka": {
- "flag": ""
- }
- }
-}
\ No newline at end of file
diff --git a/app/fantasy_cricket/fantasy_leagues.py b/app/fantasy_cricket/fantasy_leagues.py
new file mode 100644
index 00000000..7409a656
--- /dev/null
+++ b/app/fantasy_cricket/fantasy_leagues.py
@@ -0,0 +1,37 @@
+"""This module defines all supported fantasy_leagues and their functionality.
+All browsers must inherit from app.fantasy_cricket.Team`.
+"""
+from app.fantasy_cricket.team import Team
+
+
+class Dream11(Team):
+ """Dream11 League
+
+ Supported formats:
+ * ODI
+ * T20
+ * TEST
+ """
+
+ name = "Dream11"
+
+ batting_dict = {
+ "runs": [1, 1, 1],
+ "boundaries": [1, 1, 1],
+ "sixes": [2, 2, 2],
+ "50": [4, 4, 8],
+ "100": [8, 8, 16],
+ "duck": [-4, -3, -2],
+ }
+
+ bowling_dict = {
+ "wicket": [16, 25, 25],
+ "4-wicket-haul": [4, 4, 8],
+ "5-wicket-haul": [8, 8, 16],
+ "Maiden": [0, 8, 4],
+ }
+
+ wk_dict = {
+ "Catch": [8, 8, 8],
+ "Stump": [12, 12, 12],
+ }
diff --git a/app/fantasy_cricket/matches.py b/app/fantasy_cricket/matches.py
new file mode 100755
index 00000000..f2383287
--- /dev/null
+++ b/app/fantasy_cricket/matches.py
@@ -0,0 +1,56 @@
+"""
+The module is defined to get upcoming match data of the next 2 days
+"""
+
+from typing import List
+from app.fantasy_cricket.scrapyrt_client import EspnClient
+
+
+class Matches:
+ """
+ A class to get upcoming live match data of the next 2 days
+
+ """
+
+ def __init__(self) -> None:
+
+ self.espn = EspnClient()
+
+ def get_upcoming_match(self):
+ """
+ Gets current matches dict
+ """
+ matches = []
+ for match in self.espn.get_upcoming_dets():
+ if match["team1_squad"] != [] and match["team2_squad"] != []:
+ matches.append(
+ {
+ "team1": match["team1"],
+ "team2": match["team2"],
+ "flag_team1": "https://a.espncdn.com/i/teamlogos/cricket/500/"
+ + match["team1_id"]
+ + ".png",
+ "flag_team2": "https://a.espncdn.com/i/teamlogos/cricket/500/"
+ + match["team2_id"]
+ + ".png",
+ }
+ )
+
+ return matches
+
+ def get_squad_match_type(self, teams: List[str]):
+ """
+ Gets squad and match_class based on teams
+ """
+
+ for match in self.espn.get_upcoming_dets():
+
+ if match["team1"] == teams[0] and match["team2"] == teams[1]:
+ match_det = {
+ "team1_squad": match["team1_squad"],
+ "team2_squad": match["team2_squad"],
+ "match_type": match["match_id"],
+ }
+ break
+
+ return match_det
diff --git a/app/fantasy_cricket/scrapyrt_client.py b/app/fantasy_cricket/scrapyrt_client.py
new file mode 100755
index 00000000..4091466c
--- /dev/null
+++ b/app/fantasy_cricket/scrapyrt_client.py
@@ -0,0 +1,112 @@
+"""
+This module is built as an api wrapper around the scrapyrt process
+"""
+
+from typing import List
+import requests
+
+
+class EspnClient:
+ """
+ A simple wrapper built on the scrapyrt api process
+ """
+
+ def __init__(self) -> None:
+
+ self.url = "http://espncricinfo:9080/crawl.json"
+
+ def get_upcoming_dets(self):
+ """
+ Gets the upcoming matches from the scrapyrt api
+ """
+ matches = requests.get(
+ self.url, params={"spider_name": "espn-live", "start_requests": "true"}
+ )
+
+ return matches.json()["items"]
+
+ def get_player_dets(self, players: List[str], team: str):
+ """
+ Gets and parses player info from the scrapyrt api
+ """
+ player_data = []
+ for player in players:
+ player_data.append(
+ (
+ requests.get(
+ self.url,
+ params={
+ "spider_name": "espn-players",
+ "url": "https://www.espncricinfo.com/ci/content/player/"
+ + str(player)
+ + ".html",
+ },
+ ).json()["items"][0],
+ player,
+ )
+ )
+ for player, player_id in player_data:
+ if not player["role"]:
+ continue
+ if "wicketkeeper" in player["role"].lower():
+ player["role"] = "wicket-keeper"
+ elif "allrounder" in player["role"].lower():
+ player["role"] = "all-rounder"
+ elif "bowler" in player["role"].lower():
+ player["role"] = "bowler"
+ else:
+ player["role"] = "batsman"
+ player["team"] = team
+ player["player_id"] = player_id
+
+ player_data = [player for player, _ in player_data if player["role"]]
+ return player_data
+
+ def get_match_det(self, player_id: str, role: str, match_type: str):
+ """
+ Gets and parses match details got fr0om the scrapyrt api
+ """
+ role_filter_dict = {
+ "batsman": ["Catch", "Stump", "wicket", "Maiden"],
+ "bowler": ["Catch", "Stump", "runs", "boundaries", "sixes"],
+ "all-rounder": ["Catch", "Stump"],
+ "wicket-keeper": ["wicket", "Maiden"],
+ }
+ match_det = requests.get(
+ self.url,
+ params={
+ "spider_name": "espn-matches",
+ "url": "https://stats.espncricinfo.com/ci/engine/player/"
+ + player_id
+ + ".html?class="
+ + match_type
+ + ";orderby=start;orderbyad=reverse;template=results;type=allround;view=match",
+ },
+ ).json()["items"]
+ for i, _ in enumerate(match_det):
+ match_det[i] = {
+ key: val
+ for key, val in match_det[i].items()
+ if key not in role_filter_dict[role]
+ }
+ if role in ["batsman", "all-rounder", "wicket-keeper"]:
+ match_det[i]["100"] = match_det[i]["50"] = match_det[i]["duck"] = 0
+ if not match_det[i]["runs"]:
+ match_det[i]["runs"] = match_det[i]["boundaries"] = match_det[i][
+ "sixes"
+ ] = 0
+ elif match_det[i]["runs"] >= 100:
+ match_det[i]["100"] = 1
+ elif match_det[i]["runs"] >= 50:
+ match_det[i]["50"] = 1
+ elif match_det[i]["runs"] == 0:
+ match_det[i]["duck"] = 1
+ if role in ["bowler", "all-rounder"]:
+ match_det[i]["4-wicket-haul"] = match_det[i]["5-wicket-haul"] = 0
+ if not match_det[i]["wicket"]:
+ match_det[i]["wicket"] = match_det[i]["Maiden"] = 0
+ elif match_det[i]["wicket"] >= 5:
+ match_det[i]["5-wicket-haul"] = 1
+ elif match_det[i]["wicket"] >= 4:
+ match_det[i]["4-wicket-haul"] = 1
+ return match_det
diff --git a/app/fantasy_cricket/static/bat.png b/app/fantasy_cricket/static/bat.png
deleted file mode 100644
index 4a495fb6..00000000
Binary files a/app/fantasy_cricket/static/bat.png and /dev/null differ
diff --git a/app/fantasy_cricket/static/fonts/hackerspace.ttf b/app/fantasy_cricket/static/fonts/hackerspace.ttf
old mode 100644
new mode 100755
diff --git a/app/fantasy_cricket/static/icon.png b/app/fantasy_cricket/static/icon.png
deleted file mode 100644
index a81e1258..00000000
Binary files a/app/fantasy_cricket/static/icon.png and /dev/null differ
diff --git a/app/fantasy_cricket/static/loading.gif b/app/fantasy_cricket/static/loading.gif
deleted file mode 100644
index 05e1f570..00000000
Binary files a/app/fantasy_cricket/static/loading.gif and /dev/null differ
diff --git a/app/fantasy_cricket/static/result1.jpg b/app/fantasy_cricket/static/result1.jpg
deleted file mode 100644
index 98f91ca3..00000000
Binary files a/app/fantasy_cricket/static/result1.jpg and /dev/null differ
diff --git a/app/fantasy_cricket/static/styles/style.css b/app/fantasy_cricket/static/styles/style.css
deleted file mode 100644
index fb294015..00000000
--- a/app/fantasy_cricket/static/styles/style.css
+++ /dev/null
@@ -1,73 +0,0 @@
-/* This following style sheet is not being used */
-body {
- background-image: url("../images/background1.jpg");
-}
-
-h1 {
- text-align: center;
- color: white;
- font-size: 3em;
- margin-top: 2.5em;
-}
-
-h2 {
- text-align: center;
- color: white;
- font-size: 2em;
- margin-top: 3em;
-}
-
-form {
- margin-top: 1em;
- margin-left: 4.5em;
-}
-
-input {
- position: absolute;
- left: 44%;
- border-radius: 5px;
- border: 1px solid;
- padding: 8px 6px;
- line-height: 120%;
-}
-
-.container {
- display: grid;
- grid-template-columns: auto auto auto auto;
- grid-gap: 10px;
- grid-row-gap: 40px;
- padding: 10px;
-}
-
-input:hover[type="submit"] {
- color: white;
- box-shadow: 0 5px 15px rgba(145, 92, 182, .4);
-}
-
-.button {
- position: absolute;
- top: 450px;
- left: 710px;
-}
-
-p {
- text-align: center;
-}
-
-.custom-select {
- width:200px;
- position: absolute;
- left: 43.5%;
- text-align: center;
- margin-top: 1.5em;
-}
-
-select {
- height:30px;
- text-align: center;
- border-radius: 3px;
- font-family: Arial;
- line-height:30px;
- font-size: 1em;
-}
-
diff --git a/app/fantasy_cricket/static/styles/style1.css b/app/fantasy_cricket/static/styles/style1.css
old mode 100644
new mode 100755
index c714e50c..9e6516ba
--- a/app/fantasy_cricket/static/styles/style1.css
+++ b/app/fantasy_cricket/static/styles/style1.css
@@ -1,5 +1,5 @@
.bgImage {
- background-image: url("../result1.jpg") ;
+ background-image: url("https://user-images.githubusercontent.com/54945757/106836486-448fe600-66bf-11eb-9878-bb8e2237dd91.jpg") ;
background-size:cover;
position: fixed;
left: 0;
diff --git a/app/fantasy_cricket/static/styles/style2.css b/app/fantasy_cricket/static/styles/style2.css
old mode 100644
new mode 100755
diff --git a/app/fantasy_cricket/team.py b/app/fantasy_cricket/team.py
old mode 100644
new mode 100755
index 7587ebea..2135f474
--- a/app/fantasy_cricket/team.py
+++ b/app/fantasy_cricket/team.py
@@ -1,218 +1,124 @@
"""
-This module defines the teams class which outputs the team for the match
-and the Predict class which predicts the score based on the role
-Copyright (C) 2020 Royston E Tauro & Sammith S Bharadwaj & Shreyas Raviprasad
- This program is free software: you can redistribute it and/or modify
- it under the terms of the GNU Affero General Public License as published
- by the Free Software Foundation, either version 3 of the License, or
- (at your option) any later version.
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU Affero General Public License for more details.
- You should have received a copy of the GNU Affero General Public License
- along with this program. If not, see