5 Commits

Author SHA1 Message Date
Jovial Joe Jayarson
2aab71918a Merge pull request #148 from yozachar/workshop
chore: monthly updates for Oct'23; bump version
2023-10-23 09:48:07 +05:30
Jovial Joe Jayarson
3f2f9d748e chore: monthly updates for Oct'23; bump version 2023-10-21 08:12:29 +05:30
Andrew Hong
54c3312012 feat: adds flag IGNORE_LANGUAGES (#146)
- feat: adds flag `IGNORE_LANGUAGES`  (#146)

---------

Co-authored-by: Jovial Joe Jayarson <jovial7joe@hotmail.com>
2023-10-21 07:58:43 +05:30
Jovial Joe Jayarson
dd576f44c6 Merge pull request #144 from joe733/workshop
chore: monthly updates for Sep'23; bump version
2023-09-19 16:23:00 +05:30
Jovial Joe Jayarson
b2363ac606 chore: monthly updates for Sep'23; bump version
- fix: 0 discovered test in container
- uses containerfile for testing
- update dependencies, bump version
2023-09-17 15:55:22 +05:30
10 changed files with 98 additions and 36 deletions

View File

@@ -17,6 +17,7 @@ INPUT_SHOW_TIME=
INPUT_SHOW_TOTAL= INPUT_SHOW_TOTAL=
INPUT_SHOW_MASKED_TIME= INPUT_SHOW_MASKED_TIME=
INPUT_STOP_AT_OTHER= INPUT_STOP_AT_OTHER=
INPUT_IGNORED_LANGUAGES=
# commit # commit
INPUT_COMMIT_MESSAGE= INPUT_COMMIT_MESSAGE=
INPUT_TARGET_BRANCH= INPUT_TARGET_BRANCH=

1
.gitignore vendored
View File

@@ -107,6 +107,7 @@ poetry.lock
# However, this project does not rely on pdm for production. # However, this project does not rely on pdm for production.
pdm.lock pdm.lock
.pdm-python .pdm-python
.pdm-build
# PEP 582; used by e.g. github.com/David-OConnor/pyflow # PEP 582; used by e.g. github.com/David-OConnor/pyflow
__pypackages__/ __pypackages__/

View File

@@ -21,6 +21,7 @@ INPUT_TIME_RANGE=last_7_days
INPUT_SHOW_MASKED_TIME=false INPUT_SHOW_MASKED_TIME=false
INPUT_LANG_COUNT=0 INPUT_LANG_COUNT=0
INPUT_STOP_AT_OTHER=true INPUT_STOP_AT_OTHER=true
INPUT_IGNORED_LANGUAGES=
``` ```
**NEVER commit this `.env` file!** **NEVER commit this `.env` file!**
@@ -32,10 +33,8 @@ INPUT_STOP_AT_OTHER=true
> Replace `podman` with `docker` everywhere, if you're using the latter. > Replace `podman` with `docker` everywhere, if you're using the latter.
```sh ```sh
# Build # Build and watch logs
$ podman-compose -p waka-readme -f ./docker-compose.yml up -d $ podman-compose -p waka-readme -f ./docker-compose.yml up
# Logs
$ podman logs WakaReadmeDev
# Cleanup # Cleanup
$ podman-compose -p waka-readme -f ./docker-compose.yml down $ podman-compose -p waka-readme -f ./docker-compose.yml down
``` ```

View File

@@ -93,7 +93,7 @@ A GitHub repository and a `README.md` file is required. We'll be making use of r
name: WakaReadme DevMetrics name: WakaReadme DevMetrics
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: athul/waka-readme@master - uses: athul/waka-readme@master # this action name
with: with:
WAKATIME_API_KEY: ${{ secrets.WAKATIME_API_KEY }} WAKATIME_API_KEY: ${{ secrets.WAKATIME_API_KEY }}
``` ```
@@ -113,18 +113,19 @@ There are many flags that you can modify as you see fit.
### Content Tweaks ### Content Tweaks
| Environment flag | Options (`Default`, `Other`, ...) | Description | | Environment flag | Options (`Default`, `Other`, ...) | Description |
| ------------------ | ----------------------------------------------------------------------- | --------------------------------------------------------------------------------- | | ------------------- | ----------------------------------------------------------------------- | --------------------------------------------------------------------------------- |
| `SHOW_TITLE` | `false`, `true` | Add title to waka-readme stats blob | | `SHOW_TITLE` | `false`, `true` | Add title to waka-readme stats blob |
| `SECTION_NAME` | `waka`, any alphanumeric string | The generator will look for section name to fill up the readme. | | `SECTION_NAME` | `waka`, any alphanumeric string | The generator will look for section name to fill up the readme. |
| `BLOCKS` | `░▒▓█`, `⣀⣄⣤⣦⣶⣷⣿`, `-#`, `=>`, you can be creative | Ascii art used to build stats graph | | `BLOCKS` | `░▒▓█`, `⣀⣄⣤⣦⣶⣷⣿`, `-#`, `=>`, you can be creative | Ascii art used to build stats graph |
| `CODE_LANG` | `txt`, `python` `ruby` `json` , you can use other languages also | Language syntax based highlighted text | | `CODE_LANG` | `txt`, `python` `ruby` `json` , you can use other languages also | Language syntax based highlighted text |
| `TIME_RANGE` | `last_7_days`, `last_30_days`, `last_6_months`, `last_year`, `all_time` | String representing a dispensation from which stats are aggregated | | `TIME_RANGE` | `last_7_days`, `last_30_days`, `last_6_months`, `last_year`, `all_time` | String representing a dispensation from which stats are aggregated |
| `LANG_COUNT` | `5`, any plausible number | Number of languages to be displayed | | `LANG_COUNT` | `5`, any plausible number | Number of languages to be displayed |
| `SHOW_TIME` | `true`, `false` | Displays the amount of time spent for each language | | `SHOW_TIME` | `true`, `false` | Displays the amount of time spent for each language |
| `SHOW_TOTAL` | `false`, `true` | Show total coding time | | `SHOW_TOTAL` | `false`, `true` | Show total coding time |
| `SHOW_MASKED_TIME` | `false`, `true` | Adds total coding time including unclassified languages (overrides: `SHOW_TOTAL`) | | `SHOW_MASKED_TIME` | `false`, `true` | Adds total coding time including unclassified languages (overrides: `SHOW_TOTAL`) |
| `STOP_AT_OTHER` | `false`, `true` | Stop when language marked as `Other` is retrieved (overrides: `LANG_COUNT`) | | `STOP_AT_OTHER` | `false`, `true` | Stop when language marked as `Other` is retrieved (overrides: `LANG_COUNT`) |
| `IGNORED_LANGUAGES` | <code> </code>, `Binary YAML JSON TOML` | Hide languages from your stats |
### Commit Tweaks ### Commit Tweaks
@@ -159,7 +160,8 @@ jobs:
name: WakaReadme DevMetrics name: WakaReadme DevMetrics
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: athul/waka-readme@master # this action name
- uses: athul/waka-readme@master # do NOT replace with anything else
with: with:
GH_TOKEN: ${{ secrets.GH_TOKEN }} # optional if on profile readme GH_TOKEN: ${{ secrets.GH_TOKEN }} # optional if on profile readme
WAKATIME_API_KEY: ${{ secrets.WAKATIME_API_KEY }} # required WAKATIME_API_KEY: ${{ secrets.WAKATIME_API_KEY }} # required
@@ -177,6 +179,7 @@ jobs:
SHOW_TOTAL: true # optional SHOW_TOTAL: true # optional
SHOW_MASKED_TIME: false # optional SHOW_MASKED_TIME: false # optional
STOP_AT_OTHER: true # optional STOP_AT_OTHER: true # optional
IGNORED_LANGUAGES: YAML JSON TOML # optional
### commit ### commit
COMMIT_MESSAGE: Updated waka-readme graph with new metrics # optional COMMIT_MESSAGE: Updated waka-readme graph with new metrics # optional
TARGET_BRANCH: master # optional TARGET_BRANCH: master # optional
@@ -213,6 +216,7 @@ Other 47 hrs 58 mins >------------------------ 03.05 %
- If you are using `GH_TOKEN`, make sure set the [fine grained token](https://github.com/settings/tokens?type=beta) scope to repository contents with `read-and-write` access. See [#141 (comment)](https://github.com/athul/waka-readme/issues/141#issuecomment-1679831949). - If you are using `GH_TOKEN`, make sure set the [fine grained token](https://github.com/settings/tokens?type=beta) scope to repository contents with `read-and-write` access. See [#141 (comment)](https://github.com/athul/waka-readme/issues/141#issuecomment-1679831949).
- `WAKATIME_API_KEY` is a **required** secret. All other environment variables are optional. - `WAKATIME_API_KEY` is a **required** secret. All other environment variables are optional.
- The above example does NOT show proper default values, refer [#Tweaks](#tweaks) for the same. - The above example does NOT show proper default values, refer [#Tweaks](#tweaks) for the same.
- `IGNORED_LANGUAGES` is suggested for [.NET](https://dotnet.microsoft.com) users, as WakaTime assumes you're working with `Binary`, while debugging.
## Why only the language stats (and not other data) from the API? ## Why only the language stats (and not other data) from the API?

View File

@@ -62,6 +62,10 @@ inputs:
description: "Stop data retrieval when language marked 'Other' is reached" description: "Stop data retrieval when language marked 'Other' is reached"
default: "false" default: "false"
required: false required: false
IGNORED_LANGUAGES:
description: "Ignore space separated, listed languages"
default: ""
required: false
# commit tweaks # commit tweaks
COMMIT_MESSAGE: COMMIT_MESSAGE:

View File

@@ -5,7 +5,6 @@ services:
- .env.template - .env.template
build: build:
context: . context: .
dockerfile: dockerfile dockerfile: containerfile
image: waka-readme:testing image: waka-readme:testing
container_name: WakaReadmeTesting container_name: WakaReadmeTesting
command: python -m unittest discover

51
containerfile Normal file
View File

@@ -0,0 +1,51 @@
FROM docker.io/python:3-slim
ENV INPUT_GH_TOKEN \
INPUT_WAKATIME_API_KEY \
# meta
INPUT_API_BASE_URL \
INPUT_REPOSITORY \
# content
INPUT_SHOW_TITLE \
INPUT_SECTION_NAME \
INPUT_BLOCKS \
INPUT_CODE_LANG \
INPUT_TIME_RANGE \
INPUT_LANG_COUNT \
INPUT_SHOW_TIME \
INPUT_SHOW_TOTAL \
INPUT_SHOW_MASKED_TIME \
INPUT_STOP_AT_OTHER \
INPUT_IGNORED_LANGUAGES \
# commit
INPUT_COMMIT_MESSAGE \
INPUT_TARGET_BRANCH \
INPUT_TARGET_PATH \
INPUT_COMMITTER_NAME \
INPUT_COMMITTER_EMAIL \
INPUT_AUTHOR_NAME \
INPUT_AUTHOR_EMAIL
ENV PATH="${PATH}:/root/.local/bin" \
# python
PYTHONFAULTHANDLER=1 \
PYTHONUNBUFFERED=1 \
PYTHONHASHSEED=random \
PYTHONDONTWRITEBYTECODE=1 \
# pip
PIP_DISABLE_PIP_VERSION_CHECK=1 \
PIP_NO_CACHE_DIR=1 \
PIP_DEFAULT_TIMEOUT=100
# copy project files
COPY --chown=root:root pyproject.toml main.py /app/
# install dependencies
RUN python -m pip install /app/
# copy tests
COPY --chown=root:root tests /app/tests/
# run tests
CMD python -m unittest discover /app/

View File

@@ -16,6 +16,7 @@ ENV INPUT_GH_TOKEN \
INPUT_SHOW_TOTAL \ INPUT_SHOW_TOTAL \
INPUT_SHOW_MASKED_TIME \ INPUT_SHOW_MASKED_TIME \
INPUT_STOP_AT_OTHER \ INPUT_STOP_AT_OTHER \
INPUT_IGNORED_LANGUAGES \
# commit # commit
INPUT_COMMIT_MESSAGE \ INPUT_COMMIT_MESSAGE \
INPUT_TARGET_BRANCH \ INPUT_TARGET_BRANCH \

15
main.py
View File

@@ -149,6 +149,7 @@ class WakaInput:
show_masked_time: str | bool = os.getenv("INPUT_SHOW_MASKED_TIME") or False show_masked_time: str | bool = os.getenv("INPUT_SHOW_MASKED_TIME") or False
language_count: str | int = os.getenv("INPUT_LANG_COUNT") or 5 language_count: str | int = os.getenv("INPUT_LANG_COUNT") or 5
stop_at_other: str | bool = os.getenv("INPUT_STOP_AT_OTHER") or False stop_at_other: str | bool = os.getenv("INPUT_STOP_AT_OTHER") or False
ignored_languages: str = os.getenv("INPUT_IGNORED_LANGUAGES", "")
# # optional meta # # optional meta
target_branch: str = os.getenv("INPUT_TARGET_BRANCH", "NOT_SET") target_branch: str = os.getenv("INPUT_TARGET_BRANCH", "NOT_SET")
target_path: str = os.getenv("INPUT_TARGET_PATH", "NOT_SET") target_path: str = os.getenv("INPUT_TARGET_PATH", "NOT_SET")
@@ -270,7 +271,7 @@ def make_graph(block_style: str, percent: float, gr_len: int, lg_nm: str = "", /
return graph_bar return graph_bar
def prep_content(stats: dict[str, Any], language_count: int = 5, stop_at_other: bool = False, /): def prep_content(stats: dict[str, Any], /):
"""WakaReadme Prepare Markdown. """WakaReadme Prepare Markdown.
Prepared markdown content from the fetched statistics. Prepared markdown content from the fetched statistics.
@@ -306,17 +307,19 @@ def prep_content(stats: dict[str, Any], language_count: int = 5, stop_at_other:
max((str(lng["name"]) for lng in lang_info), key=len) max((str(lng["name"]) for lng in lang_info), key=len)
# and then do not for get to set `pad_len` to say 13 :) # and then do not for get to set `pad_len` to say 13 :)
) )
if language_count == 0 and not stop_at_other: language_count, stop_at_other = int(wk_i.language_count), bool(wk_i.stop_at_other)
if language_count == 0 and not wk_i.stop_at_other:
logger.debug( logger.debug(
"Set INPUT_LANG_COUNT to -1 to retrieve all language" "Set INPUT_LANG_COUNT to -1 to retrieve all language"
+ " or specify a positive number (ie. above 0)" + " or specify a positive number (ie. above 0)"
) )
return contents.rstrip("\n") return contents.rstrip("\n")
ignored_languages = set[str](igl.lower() for igl in wk_i.ignored_languages.strip().split())
for idx, lang in enumerate(lang_info): for idx, lang in enumerate(lang_info):
lang_name = str(lang["name"]) lang_name = str(lang["name"])
# >>> add languages to filter here <<< if ignored_languages and lang_name.lower() in ignored_languages:
# if lang_name in {...}: continue continue
lang_time = str(lang["text"]) if wk_i.show_time else "" lang_time = str(lang["text"]) if wk_i.show_time else ""
lang_ratio = float(lang["percent"]) lang_ratio = float(lang["percent"])
lang_bar = make_graph(wk_i.block_style, lang_ratio, wk_i.graph_length, lang_name) lang_bar = make_graph(wk_i.block_style, lang_ratio, wk_i.graph_length, lang_name)
@@ -393,9 +396,7 @@ def churn(old_readme: str, /):
sys.exit(1) sys.exit(1)
# preparing contents # preparing contents
try: try:
generated_content = prep_content( generated_content = prep_content(waka_stats)
waka_stats, int(wk_i.language_count), bool(wk_i.stop_at_other)
)
except (AttributeError, KeyError, ValueError) as err: except (AttributeError, KeyError, ValueError) as err:
logger.error(f"Unable to read API data | {err}\n") logger.error(f"Unable to read API data | {err}\n")
sys.exit(1) sys.exit(1)

View File

@@ -4,7 +4,7 @@
[project] [project]
name = "waka-readme" name = "waka-readme"
version = "0.2.4" version = "0.3.0"
description = "Wakatime Weekly Metrics on your Profile Readme." description = "Wakatime Weekly Metrics on your Profile Readme."
authors = [{ name = "Athul Cyriac Ajay", email = "athul8720@gmail.com" }] authors = [{ name = "Athul Cyriac Ajay", email = "athul8720@gmail.com" }]
license = { text = "MIT" } license = { text = "MIT" }
@@ -16,7 +16,7 @@ classifiers = [
"Typing :: Typed", "Typing :: Typed",
] ]
requires-python = ">=3.11" requires-python = ">=3.11"
dependencies = ["faker>=19.3.0", "pygithub>=1.59.1", "requests>=2.31.0"] dependencies = ["faker>=19.11.0", "pygithub>=2.1.1", "requests>=2.31.0"]
[project.urls] [project.urls]
Homepage = "https://github.com/athul/waka-readme" Homepage = "https://github.com/athul/waka-readme"
@@ -29,13 +29,14 @@ Changelog = "https://github.com/athul/waka-readme/commits/master"
############################# #############################
[project.optional-dependencies] [project.optional-dependencies]
dev = ["loguru>=0.7.0", "python-dotenv>=1.0.0"] extra = ["loguru>=0.7.2", "python-dotenv>=1.0.0"]
tooling = [
"bandit>=1.7.5", #############################
"black>=23.7.0", # Development Dependencies #
"ruff>=0.0.284", #############################
"pyright>=1.1.323",
] [tool.pdm.dev-dependencies]
tooling = ["bandit>=1.7.5", "black>=23.10.0", "ruff>=0.1.1", "pyright>=1.1.332"]
#################### ####################
# Configurations # # Configurations #