Skip to content

Commit

Permalink
Merge pull request #9 from PokemonGoF/dev
Browse files Browse the repository at this point in the history
Merge from main repo
  • Loading branch information
MerlionRock authored Jul 24, 2017
2 parents a7e85d1 + 767ccf2 commit 2d55b31
Show file tree
Hide file tree
Showing 9 changed files with 191 additions and 234 deletions.
8 changes: 7 additions & 1 deletion configs/config.json.example
Original file line number Diff line number Diff line change
Expand Up @@ -471,7 +471,13 @@
"order_by": "cp",
"min_interval":360,
"min_recheck":30,
"max_recheck":120
"max_recheck":120,
"chain_fill_gyms": true,
"ignore_max_cp_pokemon": ["Blissey"],
"never_place": ["Machamp"],
"leave_at_least_spots": 1,
"take_at_most": 10,
"pick_random_pokemon": true
}
},
{
Expand Down
44 changes: 44 additions & 0 deletions docs/configuration_files.md
Original file line number Diff line number Diff line change
Expand Up @@ -1516,3 +1516,47 @@ If you have any Pokemon that are dead or need healing, this task will try to do
}
```

## GymPokemon
[[back to top](#table-of-contents)]

### Description
[[back to top](#table-of-contents)]

Drop a Pokemon in a Gym when there is room for. No fighting will be done! Never!

### Options
[[back to top](#table-of-contents)]

* `enabled`: `Default: False`. Enable or distable this task
* `order_by`: `Default: "cp"`. Based on what atrribute should be sorted (decending)
* `min_interval`: `Default: 360`. Time in seconds between printing the Pokemon we have in gyms
* `min_recheck`: `Default: 30`. Minimal time in seconds to check for new gyms in range
* `max_recheck`: `Default: 120`. Maxium time in seconds to check for new gyms in range
* `chain_fill_gyms`: `Default: True`. When we drop a Pokemon in a gym, should we imediatly move to the next gym if a open spot is found?
* `ignore_max_cp_pokemon`: `Default: ["Blissey"]`. A list of Pokemon who can be placed in gyms even if above 3000cp
* `never_place`: `Default: []`. A list of Pokemon that should never be placed in a gym
* `leave_at_least_spots`: `Default: 0`. How many open spots should we leave for normal players? (Max 4!!)
* `take_at_most`: `Default: 20`. How many gym should we be in at the same time? Max 20!!
* `pick_random_pokemon`: `Default: True`. Pick a random Pokemon from the top 20 sorted by "order_by", or the top 1 availible?


### Sample configuration
[[back to top](#table-of-contents)]
```json
{
"type": "GymPokemon",
"config": {
"enabled": false,
"order_by": "cp",
"min_interval":360,
"min_recheck":30,
"max_recheck":120,
"chain_fill_gyms": true,
"ignore_max_cp_pokemon": ["Blissey"],
"never_place": ["Machamp"],
"leave_at_least_spots": 1,
"take_at_most": 10,
"pick_random_pokemon": true
}
}
```
65 changes: 34 additions & 31 deletions docs/installation.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
- [pip](https://pip.pypa.io/en/stable/installing/)
- [git](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git)
- [virtualenv](https://virtualenv.pypa.io/en/stable/installation/) (Recommended)
- [hashing key](http://hashing.pogodev.org) - if you want use latest API, not the old, 0.45
- [hashing key](http://hashing.pogodev.org) - Hashing key now required for bot operation

### Easy installation
1. Clone the git: `git clone https://github.com/PokemonGoF/PokemonGo-Bot`
Expand All @@ -27,13 +27,13 @@
This will reset and makes sure you have no changes made to any code since it will overide it
3. Rerun the bot `./run.sh`

for manual installation please refer to [here](https://github.com/PokemonGoF/PokemonGo-Bot/blob/dev/docs/manual_installation.md)
For manual installation please refer to [here](https://github.com/PokemonGoF/PokemonGo-Bot/blob/dev/docs/manual_installation.md)

# Windows
We do recommend Windows users to use [Docker](#docker) this will work much easier and smoother (also safer)

## Requirements
- [hashing key](http://hashing.pogodev.org) - if you want use latest API, not the old, 0.45
- [hashing key](http://hashing.pogodev.org) - Hashing key now required for bot operation

### Easy Installation
1. Download [PokemonGo-Bot-Install.bat](https://github.com/PokemonGoF/PokemonGo-Bot/blob/master/windows_bat/PokemonGo-Bot-Install.bat)
Expand All @@ -51,70 +51,73 @@ This will check for an update and will start the bot afterwards.

### Easy installation
Start by downloading for your platform:

- [Mac](https://www.docker.com/products/docker#/mac)
- [Windows](https://www.docker.com/products/docker#/windows)
- [Linux](https://www.docker.com/products/docker#/linux)

Once you have Docker installed, simply create the various config files for your different accounts (e.g. `configs/config.json`, `configs/userdata.js`) and then create a Docker image for PokemonGo-Bot using the Dockerfile in this repo.

- Once you have Docker installed, simply create the various config files for your different accounts (e.g. `configs/config.json`, `configs/userdata.js`) and then create a Docker image for PokemonGo-Bot using the Dockerfile in this repo.

```
cd PokemonGo-Bot
docker build -t pokemongo-bot .
```

By default our Dockerfile ensures that the "master" branch will be used for building the docker container, if you want to use the "dev" branch then you should build the container with below build command:
- By default our Dockerfile ensures that the "master" branch will be used for building the docker container, if you want to use the "dev" branch then you should build the container with below build command:

```
docker build --build-arg BUILD_BRANCH=dev -t pokemongo-bot .
```



After build process you can verify that the image was created with:
- After build process you can verify that the image was created with:

```
docker images
```

To run the bot container with the PokemonGo-Bot Docker image you've created:
- To run the bot container with the PokemonGo-Bot Docker image you've created:

```
docker run --name=bot1-pokego --rm -it -v $(pwd)/configs/config.json:/usr/src/app/configs/config.json pokemongo-bot
```

Optionally you can set your timezone with the -e option (default is Etc/UTC). You can find an exhaustive list of timezone here: https://en.wikipedia.org/wiki/List_of_tz_database_time_zones
- Optionally you can set your timezone with the -e option (default is Etc/UTC). You can find an exhaustive list of timezone here: [https://en.wikipedia.org/wiki/List_of_tz_database_time_zones](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones).

```
docker run --name=bot1-pokego --rm -it -e TZ=Asia/Taipei -v $(pwd)/configs/config.json:/usr/src/app/configs/config.json pokemongo-bot
```

>In the case you configured authentification to be handled by auth.json file make sure you mount that file as a volume also
- In the case you configured authentication to be handled by auth.json file make sure you mount that file as a volume also.

>```
```
docker run --name=bot1-pokego --rm -it -v $(pwd)/configs/auth.json:/usr/src/app/configs/auth.json -v $(pwd)/configs/config.json:/usr/src/app/configs/config.json -v $(pwd)/web/:/usr/src/app/web/ pokemongo-bot
```

>or for a simplified version mount your whole configs/ subdir to /usr/src/app/configs
- For a simplified version mount your whole configs/ subdir to /usr/src/app/configs.

>```
```
docker run --name=bot1-pokego --rm -it -v $(pwd)/configs:/usr/src/app/configs -v $(pwd)/web/:/usr/src/app/web/ pokemongo-bot
```
>

Run a second container provided with the OpenPoGoBotWeb view:
- Run a second container provided with the OpenPoGoBotWeb view:

```
docker run --name=bot1-pokegoweb --rm -it --volumes-from bot1-pokego -p 8000:8000 -v $(pwd)/configs/userdata.js:/usr/src/app/web/config/userdata.js -w /usr/src/app/web python:2.7 python -m SimpleHTTPServer
```
The OpenPoGoWeb will be served on `http://<your host>:8000`

- The OpenPoGoWeb will be served on `http://<your host>:8000`

### Using proxy with docker:

- https proxy
```

```
docker run --name=bot1-pokego -e "https_proxy=https://PROXY_IP:PORT" --rm -it -v $(pwd)/configs:/usr/src/app/configs -v $(pwd)/web/:/usr/src/app/web/ pokemongocc-bot
```
- http proxy

* http proxy

```
docker run --name=bot1-pokego -e "http_proxy=http://PROXY_IP:PORT" --rm -it -v $(pwd)/configs:/usr/src/app/configs -v $(pwd)/web/:/usr/src/app/web/ pokemongo-bot
```
Expand All @@ -139,14 +142,14 @@ docker run --name=bot1-pokegoweb --rm -it --volumes-from bot1-pokego -p 8000:800
- Retrieve your host address:

```
docker-machine ip default
docker-machine ip default
```


Then, with your containers running and your host address, you can access the web view in your browser:
- Then, with your containers running and your host address, you can access the web view in your browser:

`http://<your host address>:8000` (e.g. http://192.168.99.100:8000)

`http://<your host address>:8000 (eg http://192.168.99.100:8000)`
```
#### Errors

- An error occurred trying to connect:
Expand All @@ -164,37 +167,37 @@ Make sure that the name of the image is correct.

### Using Docker compose

if docker-compose [installed](https://docs.docker.com/compose/install/) you can alternatively run the PokemonGo-Bot ecosystem with one simple command:
- If docker-compose [installed](https://docs.docker.com/compose/install/) you can alternatively run the PokemonGo-Bot ecosystem with one simple command:
(by using the docker-compose.yml configuration in this repo)

```
docker-compose up
```

An example of routing the bot's traffic through a tor proxy can be found within the docker-compose_tor.yml file. To use a different file, supply the file name to docker-compose. The d flag is used to run this in detached mode as the tor logs overwhelm any bot logs you might wish to view. The bot logs can still be seen through `docker logs` command.
- An example of routing the bot's traffic through a tor proxy can be found within the docker-compose_tor.yml file. To use a different file, supply the file name to docker-compose. The d flag is used to run this in detached mode as the tor logs overwhelm any bot logs you might wish to view. The bot logs can still be seen through `docker logs` command.

```
docker-compose -f docker-compose_tor.yml up -d
```

Also run one single service from the compose configuration is possible:
- Also run one single service from the compose configuration is possible:

```
docker-compose run --rm bot1-pokego
```

command to stop and remove all stopped containers: `docker-compose down`
- command to stop and remove all stopped containers: `docker-compose down`

TODO: Add infos / configuration for running multiple bot instances.

Do not push your image to a registry with your config.json and account details in it!

### Bug reporting when using docker:

Please include output of below command:
* Please include output of below command:

```
docker inspect --format='{{.Created}} {{.ContainerConfig.Labels}}' container_tag_or_id
```
container_tag_or_id being the final tag_id of container or the id of the intermediary layer at which the docker build failed.

`container_tag_or_id` being the final tag_id of container or the id of the intermediary layer at which the docker build failed.
2 changes: 1 addition & 1 deletion pokecli.py
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@
try:
import pkg_resources
pgoapi_version = pkg_resources.get_distribution("pgoapi").version
if pgoapi_version != '1.2.0':
if pgoapi_version != '1.2.1':
print "Run following command to get latest update: `pip install -r requirements.txt --upgrade`"
sys.exit(1)
except pkg_resources.DistributionNotFound:
Expand Down
14 changes: 7 additions & 7 deletions pokemongo_bot/cell_workers/complete_tutorial.py
Original file line number Diff line number Diff line change
Expand Up @@ -119,13 +119,13 @@ def _random_avatar(self):
# at the first choices in general, so fully
# random on the whole avatar space is not the way to go either
avatar['skin']=random.randint(0,3)
avatar['hair']=random.randint(0,3)
avatar['shirt']=random.randint(0,3)
avatar['pants']=random.randint(0,3)
avatar['hat']=random.randint(0,3)
avatar['shoes']=random.randint(0,3)
avatar['eyes']=random.randint(0,3)
avatar['backpack']=random.randint(0,3)
avatar['avartar_hair']=random.randint(0,3)
avatar['avartar_shirt']=random.randint(0,3)
avatar['avartar_pants']=random.randint(0,3)
avatar['avartar_hat']=random.randint(0,3)
avatar['avartar_shoes']=random.randint(0,3)
avatar['avartar_eyes']=random.randint(0,3)
avatar['avartar_backpack']=random.randint(0,3)
return avatar

def _set_avatar(self):
Expand Down
Loading

0 comments on commit 2d55b31

Please sign in to comment.