Compare commits
	
		
			5 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 2aab71918a | ||
|  | 3f2f9d748e | ||
|  | 54c3312012 | ||
|  | dd576f44c6 | ||
|  | b2363ac606 | 
| @@ -17,6 +17,7 @@ INPUT_SHOW_TIME= | ||||
| INPUT_SHOW_TOTAL= | ||||
| INPUT_SHOW_MASKED_TIME= | ||||
| INPUT_STOP_AT_OTHER= | ||||
| INPUT_IGNORED_LANGUAGES= | ||||
| # commit | ||||
| INPUT_COMMIT_MESSAGE= | ||||
| INPUT_TARGET_BRANCH= | ||||
|   | ||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -107,6 +107,7 @@ poetry.lock | ||||
| #   However, this project does not rely on pdm for production. | ||||
| pdm.lock | ||||
| .pdm-python | ||||
| .pdm-build | ||||
|  | ||||
| # PEP 582; used by e.g. github.com/David-OConnor/pyflow | ||||
| __pypackages__/ | ||||
|   | ||||
| @@ -21,6 +21,7 @@ INPUT_TIME_RANGE=last_7_days | ||||
| INPUT_SHOW_MASKED_TIME=false | ||||
| INPUT_LANG_COUNT=0 | ||||
| INPUT_STOP_AT_OTHER=true | ||||
| INPUT_IGNORED_LANGUAGES= | ||||
| ``` | ||||
|  | ||||
| **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. | ||||
|  | ||||
| ```sh | ||||
| # Build | ||||
| $ podman-compose -p waka-readme -f ./docker-compose.yml up -d | ||||
| # Logs | ||||
| $ podman logs WakaReadmeDev | ||||
| # Build and watch logs | ||||
| $ podman-compose -p waka-readme -f ./docker-compose.yml up | ||||
| # Cleanup | ||||
| $ podman-compose -p waka-readme -f ./docker-compose.yml down | ||||
| ``` | ||||
|   | ||||
							
								
								
									
										32
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								README.md
									
									
									
									
									
								
							| @@ -93,7 +93,7 @@ A GitHub repository and a `README.md` file is required. We'll be making use of r | ||||
|       name: WakaReadme DevMetrics | ||||
|       runs-on: ubuntu-latest | ||||
|       steps: | ||||
|         - uses: athul/waka-readme@master | ||||
|         - uses: athul/waka-readme@master # this action name | ||||
|           with: | ||||
|             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 | ||||
|  | ||||
| | Environment flag   | Options (`Default`, `Other`, ...)                                       | Description                                                                       | | ||||
| | ------------------ | ----------------------------------------------------------------------- | --------------------------------------------------------------------------------- | | ||||
| | `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.                   | | ||||
| | `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                                            | | ||||
| | `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                                               | | ||||
| | `SHOW_TIME`        | `true`, `false`                                                         | Displays the amount of time spent for each language                               | | ||||
| | `SHOW_TOTAL`       | `false`, `true`                                                         | Show total coding time                                                            | | ||||
| | `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`)       | | ||||
| | Environment flag    | Options (`Default`, `Other`, ...)                                       | Description                                                                       | | ||||
| | ------------------- | ----------------------------------------------------------------------- | --------------------------------------------------------------------------------- | | ||||
| | `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.                   | | ||||
| | `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                                            | | ||||
| | `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                                               | | ||||
| | `SHOW_TIME`         | `true`, `false`                                                         | Displays the amount of time spent for each language                               | | ||||
| | `SHOW_TOTAL`        | `false`, `true`                                                         | Show total coding time                                                            | | ||||
| | `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`)       | | ||||
| | `IGNORED_LANGUAGES` | <code> </code>, `Binary YAML JSON TOML`                                 | Hide languages from your stats                                                    | | ||||
|  | ||||
| ### Commit Tweaks | ||||
|  | ||||
| @@ -159,7 +160,8 @@ jobs: | ||||
|     name: WakaReadme DevMetrics | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: athul/waka-readme@master | ||||
|         # this action name | ||||
|       - uses: athul/waka-readme@master # do NOT replace with anything else | ||||
|         with: | ||||
|           GH_TOKEN: ${{ secrets.GH_TOKEN }} # optional if on profile readme | ||||
|           WAKATIME_API_KEY: ${{ secrets.WAKATIME_API_KEY }} # required | ||||
| @@ -177,6 +179,7 @@ jobs: | ||||
|           SHOW_TOTAL: true # optional | ||||
|           SHOW_MASKED_TIME: false # optional | ||||
|           STOP_AT_OTHER: true # optional | ||||
|           IGNORED_LANGUAGES: YAML JSON TOML # optional | ||||
|           ### commit | ||||
|           COMMIT_MESSAGE: Updated waka-readme graph with new metrics # 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). | ||||
| - `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. | ||||
| - `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? | ||||
|  | ||||
|   | ||||
| @@ -62,6 +62,10 @@ inputs: | ||||
|     description: "Stop data retrieval when language marked 'Other' is reached" | ||||
|     default: "false" | ||||
|     required: false | ||||
|   IGNORED_LANGUAGES: | ||||
|     description: "Ignore space separated, listed languages" | ||||
|     default: "" | ||||
|     required: false | ||||
|  | ||||
|   # commit tweaks | ||||
|   COMMIT_MESSAGE: | ||||
|   | ||||
| @@ -5,7 +5,6 @@ services: | ||||
|       - .env.template | ||||
|     build: | ||||
|       context: . | ||||
|       dockerfile: dockerfile | ||||
|       dockerfile: containerfile | ||||
|     image: waka-readme:testing | ||||
|     container_name: WakaReadmeTesting | ||||
|     command: python -m unittest discover | ||||
|   | ||||
							
								
								
									
										51
									
								
								containerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								containerfile
									
									
									
									
									
										Normal 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/ | ||||
| @@ -16,6 +16,7 @@ ENV INPUT_GH_TOKEN \ | ||||
|     INPUT_SHOW_TOTAL \ | ||||
|     INPUT_SHOW_MASKED_TIME \ | ||||
|     INPUT_STOP_AT_OTHER \ | ||||
|     INPUT_IGNORED_LANGUAGES \ | ||||
|     # commit | ||||
|     INPUT_COMMIT_MESSAGE \ | ||||
|     INPUT_TARGET_BRANCH \ | ||||
|   | ||||
							
								
								
									
										15
									
								
								main.py
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								main.py
									
									
									
									
									
								
							| @@ -149,6 +149,7 @@ class WakaInput: | ||||
|     show_masked_time: str | bool = os.getenv("INPUT_SHOW_MASKED_TIME") or False | ||||
|     language_count: str | int = os.getenv("INPUT_LANG_COUNT") or 5 | ||||
|     stop_at_other: str | bool = os.getenv("INPUT_STOP_AT_OTHER") or False | ||||
|     ignored_languages: str = os.getenv("INPUT_IGNORED_LANGUAGES", "") | ||||
|     # # optional meta | ||||
|     target_branch: str = os.getenv("INPUT_TARGET_BRANCH", "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 | ||||
|  | ||||
|  | ||||
| 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. | ||||
|  | ||||
|     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) | ||||
|         # 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( | ||||
|             "Set INPUT_LANG_COUNT to -1 to retrieve all language" | ||||
|             + " or specify a positive number (ie. above 0)" | ||||
|         ) | ||||
|         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): | ||||
|         lang_name = str(lang["name"]) | ||||
|         # >>> add languages to filter here <<< | ||||
|         # if lang_name in {...}: continue | ||||
|         if ignored_languages and lang_name.lower() in ignored_languages: | ||||
|             continue | ||||
|         lang_time = str(lang["text"]) if wk_i.show_time else "" | ||||
|         lang_ratio = float(lang["percent"]) | ||||
|         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) | ||||
|     # preparing contents | ||||
|     try: | ||||
|         generated_content = prep_content( | ||||
|             waka_stats, int(wk_i.language_count), bool(wk_i.stop_at_other) | ||||
|         ) | ||||
|         generated_content = prep_content(waka_stats) | ||||
|     except (AttributeError, KeyError, ValueError) as err: | ||||
|         logger.error(f"Unable to read API data | {err}\n") | ||||
|         sys.exit(1) | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|  | ||||
| [project] | ||||
| name = "waka-readme" | ||||
| version = "0.2.4" | ||||
| version = "0.3.0" | ||||
| description = "Wakatime Weekly Metrics on your Profile Readme." | ||||
| authors = [{ name = "Athul Cyriac Ajay", email = "athul8720@gmail.com" }] | ||||
| license = { text = "MIT" } | ||||
| @@ -16,7 +16,7 @@ classifiers = [ | ||||
|     "Typing :: Typed", | ||||
| ] | ||||
| 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] | ||||
| Homepage = "https://github.com/athul/waka-readme" | ||||
| @@ -29,13 +29,14 @@ Changelog = "https://github.com/athul/waka-readme/commits/master" | ||||
| ############################# | ||||
|  | ||||
| [project.optional-dependencies] | ||||
| dev = ["loguru>=0.7.0", "python-dotenv>=1.0.0"] | ||||
| tooling = [ | ||||
|     "bandit>=1.7.5", | ||||
|     "black>=23.7.0", | ||||
|     "ruff>=0.0.284", | ||||
|     "pyright>=1.1.323", | ||||
| ] | ||||
| extra = ["loguru>=0.7.2", "python-dotenv>=1.0.0"] | ||||
|  | ||||
| ############################# | ||||
| # Development Dependencies  # | ||||
| ############################# | ||||
|  | ||||
| [tool.pdm.dev-dependencies] | ||||
| tooling = ["bandit>=1.7.5", "black>=23.10.0", "ruff>=0.1.1", "pyright>=1.1.332"] | ||||
|  | ||||
| #################### | ||||
| #  Configurations  # | ||||
|   | ||||
		Reference in New Issue
	
	Block a user