Skip to content
paperclip

GitHub Action

Get GitHub users email address

v2.1 Latest version

Get GitHub users email address

paperclip

Get GitHub users email address

Get a GitHub users email address

Installation

Copy and paste the following snippet into your .yml file.

              

- name: Get GitHub users email address

uses: KRANTHI0918/[email protected]

Learn more about this action in KRANTHI0918/get-github-email-by-username-action

Choose a version

get-github-email-by-username-action

GitHub Actions Plugin to get a GitHub user's email based on their username

Usage

Takes in a username as a required input and a Github personal access token (https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/creating-a-personal-access-token) as an optional input. If a personal access token (does not matter whose) is provided, it queries Github's Users API to find the public info available for the provided username in order to get their email. If this fails, or no auth token is provided, it attempts to search all public events related to the provided username, then tries to find their email in the API response and return it (fallback / no auth token method). For the fallback / no auth token method, the user it's searching for must have made a commit to a public repo during the current calendar year and had their email exposed to the public in their settings when they made the commit. Was originally created to email the author of a pull request if the build triggered in another repo (triggered by repository_dispatch) succeeded or failed. The PR author's username is obtained using ${{github.event.pull_request.user.login}}, this plugin then finds their email, their email gets passed in the repository_dispatch, an email is then sent to them about the status of the other pipeline using https://github.com/marketplace/actions/send-email.

Example

name: Test Get Email from Github Username
on:
  workflow_dispatch:

jobs:
  get_user_email:
    runs-on: ubuntu-latest
    name: A job to get a users email
    steps:
      - name: get email
        id: test
        uses: KRANTHI0918/[email protected]
        with:
          github-username: 'KRANTHI0918' # This is the input username
          token: 'token' # This is an optional input of a PAT to use a more reliable way to get a user's email
          
      # Use the output from the `test` step
      - name: Print the found email
        run: echo "The email is ${{ steps.test.outputs.email }}" # Example of how to access output email