Awesome
<div align="center"> <img src="website/static/img/AutoPR_Mark_color.png" alt="AutoPR logo" width=300 /> <h1>๐ณ AutoPR ๐ณ</h1>Run AI-powered workflows over your codebase
</div>๐ Features
๐ณ Living summaries of your code in nested READMEs
๐ TODOs kept track of in issues
โณ Keep history of an API call's result in git
๐ Summarize changes by adding a "summarize" label to a PR
๐ซต Custom actions configured in YAML
๐ Getting Started
Please see the installation guide.
๐ Maintainer Note
Though used internally, this project is currently not actively maintained.
Until v0.1.2, AutoPR autonomously generated pull requests from issues. If you'd still prefer to use AutoPR for this, set the following line in your github actions yaml:
uses: docker://ghcr.io/irgolic/autopr:v0.1.2
Below is an example of AutoPR's Living README:
<!-- Living README Summary -->๐ณ Living Summary
This folder contains various files and folders related to automating tasks and workflows. It includes a Dockerfile for setting up a Docker image, a license file specifying the terms of use, a Makefile for automating development tasks, an action configuration file for a pull request workflow, a shell script for executing a Python module, a lock file and a configuration file for a Python project using Poetry, JSON schemas for defining strict workflows and trigger configurations, and a JSON schema for defining workflow definitions. These files and folders provide functionality for automating tasks, managing actions and Git operations, and executing customizable workflows.
Dockerfile
๐๏ธ Sets up a Docker image based on the duffn/python-poetry:3.9-bullseye
image
๐ง Installs git from the bullseye-backports repository
๐ฅ Copies an entrypoint script and makes it executable
๐ฅ Copies the pyproject.toml
and poetry.lock
files
๐ง Activates the virtual environment and installs the project dependencies using Poetry
๐ฅ Copies the rest of the files to the /app
directory
๐ง Installs the application using Poetry
๐ Sets the entrypoint to /entrypoint.sh
for running the app
LICENSE.md
๐ This file contains the MIT License.
๐ The license grants permission to use, modify, and distribute the software.
๐ The license requires the copyright notice and permission notice to be included in all copies.
๐ซ The software is provided "as is" without warranty.
๐
The license is valid until 2023.
๐ผ The license is owned by Raphael Francis Ltd.
Makefile
๐ This file is a makefile-like configuration file.
๐ง It defines various targets and their associated commands.
๐ป The targets are: format
, type
, test
, schema
, and all
.
๐ง The format
target runs a command to format code using the black
tool.
๐ง The type
target runs a command to perform type checking using pyright
.
๐ง The test
target runs pytest on the autopr/tests
directory.
๐ง The schema
target runs a command to generate configuration entrypoints using autopr.models.config
.
๐ง The all
target runs all the targets in sequence: format
, type
, test
, and schema
.
๐ง This file is meant to automate common development tasks and ensure code quality.
action.yml
๐ This file is a configuration file for an automatic pull request workflow.
๐ง It specifies the details for running the workflow, such as the Docker image to use.
๐จ It also includes branding information, such as the icon and color to use.
๐ The file defines inputs required for the workflow, such as the GitHub token and base branch.
๐ฅ It includes a default loading GIF URL to display while the pull request is being generated.
๐ฟ The file defines a template for the name of the target branch.
๐ It specifies whether to overwrite existing branches and pull requests when creating from issues.
autopr/
This folder contains a collection of Python files and folders related to automating tasks and workflows. It includes files for actions and utilities, an entry point for GitHub Actions, logging configuration, the main service for running triggers and workflows, models for building and executing workflows, services for managing actions and Git operations, trigger configurations, and scripts and configuration files for managing workflows. These files and folders provide functionality for automating tasks, interacting with the GitHub platform, and executing customizable workflows.
entrypoint.sh
๐ The file is a shell script
๐ง It sets the Git configuration for a specific directory
โ๏ธ It sets the user email and name for Git commits
๐ฆ It activates a virtual environment
๐ It runs a Python module called autopr.gh_actions_entrypoint
poetry.lock
๐ This file is an executive summary of a project or report
๐ It provides a high-level overview of the main points
๐ It highlights key findings, conclusions, and recommendations
๐ It may include a summary of data or analysis
๐ฅ It is intended for someone who is new to the project or report
๐ซ It does not include trivial details or technical explanations
๐ก It gives a clear understanding of the purpose and scope of the project
๐ It provides a quick glance at the content without going into depth
๐ผ It serves as a starting point for further exploration or discussion
๐ It is concise and easy to read, even if the file is empty
pyproject.toml
๐ This file is a configuration file for a Python project using Poetry.
๐ It contains information about the project's name, version, and authors.
๐ The license of the project is specified as MIT.
๐ฆ It lists the packages and their dependencies required for the project.
๐งช There are separate dependencies for testing and development.
๐ง The build system used is Poetry.
๐ The file also includes configuration for the Pyright static type checker.
๐ It specifies the line length and target version for the Black code formatter.
strict_workflow_schema.json
๐ The file is a JSON schema describing a strict workflow definition.
๐ It defines various actions that can be performed within the workflow.
๐ Actions include commenting, setting issue titles, walking files, making API calls, running bash commands, and more.
๐ Each action has its own set of inputs and outputs.
๐ The workflow steps are defined as an array of actions.
๐ The schema also includes definitions for various data types and declarations used within the actions.
๐ The purpose of the file is to provide a standardized structure for defining and executing strict workflows.
๐๏ธ The schema can be used to validate and ensure the correctness of workflow definitions.
๐งฉ It allows for easy integration with other tools and systems that support the schema.
๐ The file can serve as a reference for understanding the structure and capabilities of strict workflows.
trigger_schema.json
๐ This file is a JSON document describing a trigger configuration for a workflow.
๐ It defines various trigger types such as label, comment, push, and cron triggers.
๐๏ธ Each trigger type has its own set of properties and can be customized.
๐ Triggers can be used to initiate specific actions or workflows based on certain events.
๐ The document also includes definitions for different action models and their properties.
๐งฉ These action models can be used within the triggers to specify the desired behavior.
๐ The file provides a comprehensive overview of the available triggers and action models.
๐ง It can be used as a reference guide for configuring and customizing workflows.
๐๏ธ The file structure is organized using nested objects and properties.
๐ It's important to review the specific trigger and action definitions to understand their functionality and usage.
workflow_schema.json
๐ This file is a JSON schema definition for a workflow definition.
๐ง It defines various types and properties for different actions and declarations used in the workflow.
๐ The schema includes definitions for actions like commenting, setting issue title, walking files, making API calls, running bash commands, etc.
๐ It also defines different types of declarations like template, variable, constant, and lambda declarations.
๐ The workflow definition includes a name, description, inputs, and outputs.
๐ข It consists of a list of steps which can be actions, workflow invocations, or conditional statements.
๐ Conditional statements can have if-else branches and support different conditions like lambda expressions and context checks.
๐ Workflow invocations can be either regular or iterable.
๐ Overall, this file provides a structured definition for creating and executing workflows with various actions and conditions.