diff --git a/.all-contributorsrc b/.all-contributorsrc index 8f5edc89..69e70535 100644 --- a/.all-contributorsrc +++ b/.all-contributorsrc @@ -403,6 +403,119 @@ "name": "v_a_r_s_a_n_i", "avatar_url": "https://avatars.githubusercontent.com/u/137641079?v=4", "profile": "https://github.com/Varsani2520", + + "login": "4darsh-Dev", + "name": "ADARSH MAURYA", + "avatar_url": "https://avatars.githubusercontent.com/u/109789509?v=4", + "profile": "https://linktr.ee/4darsh_dev", + "login": "Sanchitbajaj02", + "name": "Sanchit Bajaj", + "avatar_url": "https://avatars.githubusercontent.com/u/55249639?v=4", + "profile": "https://sanchitbajaj02.github.io/portfolio", + "login": "ChhaviRohilla", + "name": "Chhavi Rohilla", + "avatar_url": "https://avatars.githubusercontent.com/u/136676662?v=4", + "profile": "https://github.com/ChhaviRohilla", + }, + { + "login": "abhisheks008", + "name": "Abhishek Sharma", + "avatar_url": "https://avatars.githubusercontent.com/u/68724349?v=4", + "profile": "https://abhisheks008.bio.link/", + }, + { + "login": "sourabhkumar47", + "name": "Sourabh Kumar", + "avatar_url": "https://avatars.githubusercontent.com/u/81826285?v=4", + "profile": "http://sourabhkumar.tech/", + }, + { + "login": "Soumya-Kushwaha", + "name": "Soumya Kushwaha", + "avatar_url": "https://avatars.githubusercontent.com/u/87495134?v=4", + "profile": "https://github.com/Soumya-Kushwaha", + "contributions": [ + "review" + ] + }, + { + "login": "Jagpreet153", + "name": "Jagpreet Singh Khurana", + "avatar_url": "https://avatars.githubusercontent.com/u/119691733?v=4", + "profile": "https://github.com/Jagpreet153", + }, + { + "login": "hirapurekannu72", + "name": "hirapurekannu72", + "avatar_url": "https://avatars.githubusercontent.com/u/146826102?v=4", + "profile": "https://github.com/hirapurekannu72", + "contributions": [ + "review" + ] + }, + { + "login": "Krish-Depani", + "name": "Krish Depani", + "avatar_url": "https://avatars.githubusercontent.com/u/72994417?v=4", + "profile": "https://github.com/Krish-Depani", + "contributions": [ + "review" + ] + }, + { + "login": "Devamani11D", + "name": "Duddekunta Devamani", + "avatar_url": "https://avatars.githubusercontent.com/u/117567542?v=4", + "profile": "https://github.com/Devamani11D", + }, + { + "login": "Rohith2201", + "name": "J VENKATA LAKSHMI SAI ROHITH", + "avatar_url": "https://avatars.githubusercontent.com/u/94969985?v=4", + "profile": "https://julururohith.blogspot.com/", + }, + { + "login": "GauravKesh", + "name": "Gaurav Kesh Roushan", + "avatar_url": "https://avatars.githubusercontent.com/u/98611148?v=4", + "profile": "https://gkrcoder.vercel.app", + "contributions": [ + "review" + ] + }, + { + "login": "shaurya35", + "name": "Shaurya Jha", + "avatar_url": "https://avatars.githubusercontent.com/u/106850641?v=4", + "profile": "https://shauryacreativefolio.netlify.app/", + "contributions": [ + "review" + ] + }, + { + "login": "Luson045", + "name": "Luson Basumatary", + "avatar_url": "https://avatars.githubusercontent.com/u/131430087?v=4", + "profile": "https://github.com/Luson045", + }, + { + "login": "iitzIrFan", + "name": "iitzIrFan", + "avatar_url": "https://avatars.githubusercontent.com/u/138690953?v=4", + "profile": "https://irfan-shaikh-portfolio.vercel.app/", + "login": "vijaychandra1910", + "name": "VIJAY KUMAR CHANDRA", + "avatar_url": "https://avatars.githubusercontent.com/u/138502362?v=4", + "profile": "https://linktr.ee/vijay__19", + "contributions": [ + "review" + ] + }, + { + "login": "theashikagupta", + "name": "Ashika Gupta", + "avatar_url": "https://avatars.githubusercontent.com/u/136061047?v=4", + "profile": "https://github.com/theashikagupta", "contributions": [ "review" ] diff --git a/.github/workflows/allcontributor_autocommentor_active_issue.yml b/.github/workflows/allcontributor_autocommentor_active_issue.yml index 77f3f0d7..24d00a8c 100644 --- a/.github/workflows/allcontributor_autocommentor_active_issue.yml +++ b/.github/workflows/allcontributor_autocommentor_active_issue.yml @@ -1,9 +1,9 @@ -name: Comment on Active "Add Profile" Issues +name: Comment on Active Add Profile Issues on: workflow_dispatch: schedule: - - cron: '0 */3 * * *' + - cron: '0 */6 * * *' jobs: comment-on-active-issues: @@ -27,13 +27,27 @@ jobs: const issueCreator = issue.user.login; const commentMessage = `@all-contributors please add @${issueCreator} for review`; - await github.rest.issues.createComment({ + const { data: comments } = await github.rest.issues.listComments({ owner: context.repo.owner, repo: context.repo.repo, - issue_number: issue.number, - body: commentMessage + issue_number: issue.number }); - console.log(`Commented on issue #${issue.number}`); + const hasAllContributorsComment = comments.some(comment => + comment.body.includes('@all-contributors please add') + ); + + if (!hasAllContributorsComment) { + await github.rest.issues.createComment({ + owner: context.repo.owner, + repo: context.repo.repo, + issue_number: issue.number, + body: commentMessage + }); + + console.log(`Commented on issue #${issue.number}`); + } else { + console.log(`Skipped commenting on issue #${issue.number} - already has an all-contributors comment`); + } } } diff --git a/.github/workflows/allcontributor_autopr_merge_active.yml b/.github/workflows/allcontributor_autopr_merge_active.yml new file mode 100644 index 00000000..28a81a52 --- /dev/null +++ b/.github/workflows/allcontributor_autopr_merge_active.yml @@ -0,0 +1,46 @@ +name: Merge Active All-Contributors PRs + +on: + schedule: + - cron: '0 */6 * * *' + workflow_dispatch: + +jobs: + merge-active-prs: + runs-on: ubuntu-latest + permissions: + contents: write + pull-requests: write + + steps: + - name: Checkout repository + uses: actions/checkout@v3 + + - name: Merge active PRs + uses: actions/github-script@v6 + with: + github-token: ${{ secrets.GITHUB_TOKEN }} + script: | + const { data: pullRequests } = await github.rest.pulls.list({ + owner: context.repo.owner, + repo: context.repo.repo, + state: 'open', + sort: 'created', + direction: 'asc' + }); + + for (const pr of pullRequests) { + if (pr.user.login === 'allcontributors[bot]' && pr.mergeable_state === 'clean') { + try { + await github.rest.pulls.merge({ + owner: context.repo.owner, + repo: context.repo.repo, + pull_number: pr.number, + merge_method: 'squash' + }); + console.log(`Successfully merged PR #${pr.number}`); + } catch (error) { + console.error(`Failed to merge PR #${pr.number}: ${error.message}`); + } + } + } diff --git a/.github/workflows/codereview.yml b/.github/workflows/codereview.yml new file mode 100644 index 00000000..5457e775 --- /dev/null +++ b/.github/workflows/codereview.yml @@ -0,0 +1,48 @@ +name: Auto-Approve and Merge Pull Requests + +on: + pull_request: + types: [opened, synchronize, reopened] + schedule: + - cron: '0 */6 * * *' + workflow_dispatch: + +jobs: + auto-approve-and-merge: + runs-on: ubuntu-latest + permissions: + pull-requests: write + contents: write + + steps: + - name: Checkout repository + uses: actions/checkout@v3 + + - name: Install PyGithub + run: pip install PyGithub + + - name: Auto-approve and Merge Pull Requests + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + run: | + import os + from github import Github + def approve_and_merge_pr(pr): + pr.create_review(event='APPROVE', body='Automatically approved') + print(f"Approved PR #{pr.number}") + if pr.mergeable: + pr.merge(merge_method='squash') + print(f"Merged PR #{pr.number}") + else: + print(f"PR #{pr.number} is not mergeable") + g = Github(os.getenv('GITHUB_TOKEN')) + repo = g.get_repo(os.getenv('GITHUB_REPOSITORY')) + if os.getenv('GITHUB_EVENT_NAME') == 'pull_request': + pr_number = os.getenv('GITHUB_EVENT_PULL_REQUEST_NUMBER') + pr = repo.get_pull(int(pr_number)) + approve_and_merge_pr(pr) + else: + for pr in repo.get_pulls(state='open'): + approve_and_merge_pr(pr) + print("Auto-approval and merge process completed successfully.") + shell: python diff --git a/README.md b/README.md index a288577e..97011e25 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -