diff --git a/.github/workflows/delete_workflow_runs.sh b/.github/workflows/delete_workflow_runs.sh new file mode 100755 index 00000000..422678a0 --- /dev/null +++ b/.github/workflows/delete_workflow_runs.sh @@ -0,0 +1,63 @@ +#!/bin/bash + +set -e + +if [ $# -eq 0 ]; then + echo "Error: No workflow name provided." + echo "Usage: $0 " + exit 1 +fi + +WORKFLOW_NAME="$1" + +echo "Fetching repository information..." +REPO_INFO=$(gh repo view --json nameWithOwner) +REPO=$(echo $REPO_INFO | jq -r .nameWithOwner) +echo "Repository: $REPO" + +echo "Searching for workflows with name: '$WORKFLOW_NAME'" +WORKFLOW_IDS=$(gh api "/repos/$REPO/actions/workflows" | jq -r ".workflows[] | select(.name == \"$WORKFLOW_NAME\") | .id") + +if [ -z "$WORKFLOW_IDS" ]; then + echo "No workflows found with name '$WORKFLOW_NAME'" + exit 1 +fi + +echo "Found workflow(s) with ID(s): $WORKFLOW_IDS" + +delete_runs() { + local workflow_id=$1 + local page=$2 + echo "Fetching runs for workflow $workflow_id (page $page)..." + RUNS=$(gh api "/repos/$REPO/actions/workflows/$workflow_id/runs?per_page=100&page=$page") + RUN_COUNT=$(echo $RUNS | jq '.workflow_runs | length') + + if [ "$RUN_COUNT" -eq 0 ]; then + return 1 + fi + + echo "Deleting $RUN_COUNT runs..." + echo $RUNS | jq -r '.workflow_runs[].id' | while read -r run_id; do + echo "Deleting run $run_id" + gh api -X DELETE "/repos/$REPO/actions/runs/$run_id" + done + + return 0 +} + +for WORKFLOW_ID in $WORKFLOW_IDS; do + echo "Processing workflow ID: $WORKFLOW_ID" + page=1 + while delete_runs $WORKFLOW_ID $page; do + ((page++)) + done + + echo "All runs deleted for workflow ID $WORKFLOW_ID" + + echo "Deleting the workflow itself..." + gh api -X DELETE "/repos/$REPO/actions/workflows/$WORKFLOW_ID" + + echo "Workflow with ID $WORKFLOW_ID has been deleted." +done + +echo "All workflows named '$WORKFLOW_NAME' and their runs have been deleted." diff --git a/.github/workflows/release.yaml b/.github/workflows/deploy_gcp_bootnodes.yaml similarity index 62% rename from .github/workflows/release.yaml rename to .github/workflows/deploy_gcp_bootnodes.yaml index 59c539d1..e43838c5 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/deploy_gcp_bootnodes.yaml @@ -1,18 +1,8 @@ -name: release - +name: Deploy GCP Testnet Bootnodes on: push: - branches: - - main - - test - - dev - - paths-ignore: - - 'docs/**' - - '**.md' - - '.github/workflows/build.yaml' - - '.github/workflows/gh-release.yaml' - - '.github/workflows/publish-to-docs.yaml' + tags: + - 'v*' # This will match any tag that starts with 'v' permissions: id-token: write @@ -22,73 +12,60 @@ jobs: build-and-release: runs-on: ubuntu-latest environment: - name: ${{ github.ref == 'refs/heads/main' && 'main' || github.ref == 'refs/heads/test' && 'test' || 'dev' }} + name: "test" #will expand to other envs later, currently "test" deploys to the 5 GCP bootnodes outputs: environment: ${{ steps.set-env.outputs.environment }} steps: - uses: actions/checkout@v4 with: fetch-depth: 0 - - name: Set up Go uses: actions/setup-go@v4 with: go-version: '1.21' - name: Set Version - run: echo "VERSION=$(git describe --tags --abbrev=0)" >> $GITHUB_ENV - + run: echo "VERSION=${GITHUB_REF#refs/tags/}" >> $GITHUB_ENV - name: Build Binary run: | make build - - id: auth uses: google-github-actions/auth@v2 with: workload_identity_provider: projects/784882329213/locations/global/workloadIdentityPools/github-oidc-pool/providers/github-oidc-provider - service_account: gh-masa-oracle-${{ github.ref_name }}@masa-chain.iam.gserviceaccount.com - + service_account: gh-masa-oracle-test@masa-chain.iam.gserviceaccount.com - name: Install Google Cloud SDK uses: google-github-actions/setup-gcloud@v2 with: version: 'latest' project_id: ${{ vars.GCP_PROJECT_ID }} - - name: Upload Binary and config for contracts npm modules to GCP run: | - BINARY_NAME=$(git rev-parse --short HEAD) - gsutil cp ./masa-node gs://${{ vars.GCP_BUCKET_NAME }}/$BINARY_NAME/masa-node - gsutil cp ./masa-node gs://${{ vars.GCP_BUCKET_NAME }}/masa-node + BINARY_NAME=${GITHUB_REF#refs/tags/} + gsutil cp ./bin/masa-node gs://${{ vars.GCP_BUCKET_NAME }}/$BINARY_NAME/masa-node + gsutil cp ./bin/masa-node gs://${{ vars.GCP_BUCKET_NAME }}/masa-node gsutil cp ./contracts/* gs://${{ vars.GCP_BUCKET_NAME }}/$BINARY_NAME/ gsutil cp ./contracts/* gs://${{ vars.GCP_BUCKET_NAME }}/ - - name: Set environment output - id: set-env - run: echo "::set-output name=environment::${{ github.ref_name }}" - deploy: needs: build-and-release runs-on: ubuntu-latest environment: - name: ${{ needs.build-and-release.outputs.environment }} + name: test steps: - id: auth uses: google-github-actions/auth@v2 with: workload_identity_provider: projects/784882329213/locations/global/workloadIdentityPools/github-oidc-pool/providers/github-oidc-provider - service_account: gh-masa-oracle-${{ github.ref_name }}@masa-chain.iam.gserviceaccount.com - + service_account: gh-masa-oracle-test@masa-chain.iam.gserviceaccount.com - name: Update Instance Metadata run: | - ENVIRONMENT="${{ github.ref_name }}" + ENVIRONMENT="test" echo "Looking for instances with env metadata: $ENVIRONMENT" INSTANCES=$(gcloud compute instances list --filter="metadata.items.ENV=$ENVIRONMENT" --format="get(name)") - echo "Found instances: $INSTANCES" - for INSTANCE in $INSTANCES; do ZONE=$(gcloud compute instances list --filter="name=($INSTANCE)" --format="get(zone)" --limit=1) echo "Updating instance: $INSTANCE in zone: $ZONE" - gcloud compute instances add-metadata $INSTANCE --metadata masa-oracle-redeploy=latest --zone=$(echo $ZONE | tr -d '\n') + gcloud compute instances add-metadata $INSTANCE --metadata masa-oracle-redeploy=${GITHUB_REF#refs/tags/} --zone=$(echo $ZONE | tr -d '\n') done - diff --git a/.github/workflows/gh-release.yaml b/.github/workflows/gh-release.yaml deleted file mode 100644 index 6636054d..00000000 --- a/.github/workflows/gh-release.yaml +++ /dev/null @@ -1,54 +0,0 @@ -name: Create Github Release - -on: - push: - branches: - - main - - test - - dev - - paths-ignore: - - 'docs/**' - - '**.md' - - '.github/workflows/build.yaml' - - '.github/workflows/release.yaml' - - '.github/workflows/publish-to-docs.yaml' - - -permissions: - id-token: write - contents: write - -jobs: - prepare: - runs-on: ubuntu-latest - outputs: - version: ${{ steps.extract_version.outputs.version }} - steps: - - name: Checkout code - uses: actions/checkout@v4 - - - name: Extract version from constants.go - id: extract_version - run: | - VERSION=$(grep 'Version = ' ./pkg/config/constants.go | awk '{print $NF}' | tr -d '"') - echo "Extracted version: $VERSION" - echo "::set-output name=version::$VERSION" - - release: - needs: prepare - runs-on: ubuntu-latest - steps: - - name: Checkout code - uses: actions/checkout@v4 - - name: Create Release - uses: actions/create-release@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - tag_name: ${{ needs.prepare.outputs.version }} - release_name: Release ${{ needs.prepare.outputs.version }} - body_path: ./RELEASE_NOTES.md - draft: false - prerelease: false - diff --git a/.github/workflows/publish-to-docs.yml b/.github/workflows/publish-to-docs.yml deleted file mode 100644 index a3b045dc..00000000 --- a/.github/workflows/publish-to-docs.yml +++ /dev/null @@ -1,34 +0,0 @@ -name: Publish to Docs - -on: - push: - branches: [ test ] # Change to main after mainnet is live and we publish masa-oracle to main (if desired) - paths: - - 'docs/**' - -jobs: - build: - runs-on: ubuntu-latest - container: pandoc/latex - steps: - - uses: actions/checkout@v4 - - name: Copy Readme - run: | - mkdir pub-docs - cp -r docs/welcome-to-masa pub-docs/ - cp -r docs/worker-node pub-docs/ - cp -r docs/oracle-node pub-docs/ - cp -r docs/validator-node pub-docs/ - cp -r docs/guides-and-tutorials pub-docs/ - cp RELEASE_NOTES.md pub-docs/ - - name: Pushes to another repository - uses: cpina/github-action-push-to-another-repository@main - env: - API_TOKEN_GITHUB: ${{ secrets.API_TOKEN_GITHUB }} - with: - source-directory: 'pub-docs' - target-directory: 'docs/masa-oracle' - destination-github-username: 'masa-finance' - destination-repository-name: 'docs' - user-email: 13647606+H34D@users.noreply.github.com - target-branch: main \ No newline at end of file diff --git a/.github/workflows/tests.yaml b/.github/workflows/tests.yaml index 674922be..5d9ea5ca 100644 --- a/.github/workflows/tests.yaml +++ b/.github/workflows/tests.yaml @@ -1,4 +1,4 @@ -name: Go +name: Run Go Tests on: push: @@ -24,4 +24,4 @@ jobs: run: go mod tidy - name: Run tests - run: go test ./... \ No newline at end of file + run: go test ./... diff --git a/docs/images/discord-add-bot-to-server.png b/docs/images/discord-add-bot-to-server.png new file mode 100644 index 00000000..6aab6f2f Binary files /dev/null and b/docs/images/discord-add-bot-to-server.png differ diff --git a/docs/images/discord-change-bot-permissions-2.png b/docs/images/discord-change-bot-permissions-2.png new file mode 100644 index 00000000..89eb02e6 Binary files /dev/null and b/docs/images/discord-change-bot-permissions-2.png differ diff --git a/docs/images/discord-change-bot-permissions.png b/docs/images/discord-change-bot-permissions.png new file mode 100644 index 00000000..9cefcf78 Binary files /dev/null and b/docs/images/discord-change-bot-permissions.png differ diff --git a/docs/images/discord-copy-bot-token.png b/docs/images/discord-copy-bot-token.png new file mode 100644 index 00000000..97f4b528 Binary files /dev/null and b/docs/images/discord-copy-bot-token.png differ diff --git a/docs/images/discord-create-a-new-application.png b/docs/images/discord-create-a-new-application.png new file mode 100644 index 00000000..712516ee Binary files /dev/null and b/docs/images/discord-create-a-new-application.png differ diff --git a/docs/images/discord-get-all-guilds.png b/docs/images/discord-get-all-guilds.png new file mode 100644 index 00000000..0888dc1c Binary files /dev/null and b/docs/images/discord-get-all-guilds.png differ diff --git a/docs/images/discord-get-guild-channels.png b/docs/images/discord-get-guild-channels.png new file mode 100644 index 00000000..1d68f2a8 Binary files /dev/null and b/docs/images/discord-get-guild-channels.png differ diff --git a/docs/images/discord-install-link.png b/docs/images/discord-install-link.png new file mode 100644 index 00000000..bca202f3 Binary files /dev/null and b/docs/images/discord-install-link.png differ diff --git a/docs/images/discord-message-content-intent.png b/docs/images/discord-message-content-intent.png new file mode 100644 index 00000000..fb9b6c72 Binary files /dev/null and b/docs/images/discord-message-content-intent.png differ diff --git a/docs/images/discord-verify-bot.png b/docs/images/discord-verify-bot.png new file mode 100644 index 00000000..0cecd23e Binary files /dev/null and b/docs/images/discord-verify-bot.png differ diff --git a/docs/chat-completion.md b/docs/oracle-node/chat-completion.md similarity index 100% rename from docs/chat-completion.md rename to docs/oracle-node/chat-completion.md diff --git a/docs/oracle-node/discord-data.md b/docs/oracle-node/discord-data.md index d5d28ea4..ba9dbb27 100644 --- a/docs/oracle-node/discord-data.md +++ b/docs/oracle-node/discord-data.md @@ -31,10 +31,22 @@ The Service Manager assesses the request and delegates the task to the appropria ## Discord Endpoints -The API provides one endpoint for interacting with Discord user data: +### Getting Guild and Channel IDs + +To get all guilds (and their IDs) you can use the `/data/discord/guilds/all` endpoint. + +> ![Get Guilds](/img/discord-get-all-guilds.png) + +With the guild ID you can then use the `/data/discord/guilds/{guildID}/channels` endpoint to get all channels for that guild. + +> ![Get Channels](/img/discord-get-guild-channels.png) + +With the guild ID you can then use the `/data/discord/guilds/{guildID}/channels` endpoint to get all channels for that guild. ### Retrieve User Profile +The API provides one endpoint for interacting with Discord user data: + The `/data/discord/users/{userID}` endpoint retrieves a Discord user's profile. This can be particularly useful for understanding user demographics, personalizing interactions, or for further analysis in combination with other data points. - **Endpoint:** `/data/discord/users/{userID}` @@ -63,6 +75,10 @@ Example response: ### Retrieve Messages from a Discord Channel +> **Important**: To retrieve message content, you must toggle "Message Content Intent" in the Discord Developer Portal under the `Bot` section. +> +> ![Message Content Intent](/img/discord-message-content-intent.png) + The `/data/discord/channels/{channelID}/messages` endpoint retrieves messages from a specified Discord channel. - **Endpoint:** `/data/discord/channels/{channelID}/messages` @@ -162,11 +178,11 @@ Imagine a decentralized AI agent, "CommunityEngageAI," designed to analyze engag ### How CommunityEngageAI Leverages AI -1. **Data Collection:** CommunityEngageAI sends queries to the various endpoints to fetch profiles of active community members, messages from channels, and other relevant data. +1 . **Data Collection:** CommunityEngageAI sends queries to the various endpoints to fetch profiles of active community members, messages from channels, and other relevant data. -2. **Engagement Analysis:** Upon retrieving the data, CommunityEngageAI employs AI models to analyze engagement patterns, identify key influencers, and understand user demographics. +2 . **Engagement Analysis:** Upon retrieving the data, CommunityEngageAI employs AI models to analyze engagement patterns, identify key influencers, and understand user demographics. -3. **Personalized Interactions:** Leveraging the insights gained, CommunityEngageAI customizes interactions with community members, tailoring messages and content to enhance engagement and user satisfaction. +3 . **Personalized Interactions:** Leveraging the insights gained, CommunityEngageAI customizes interactions with community members, tailoring messages and content to enhance engagement and user satisfaction. ### Conclusion diff --git a/docs/oracle-node/discord-sentiment.md b/docs/oracle-node/discord-sentiment.md index b838b550..d73e5a08 100644 --- a/docs/oracle-node/discord-sentiment.md +++ b/docs/oracle-node/discord-sentiment.md @@ -15,6 +15,11 @@ The Discord sentiment analysis feature extends the Masa Node's capabilities to i The sentiment analysis process begins by collecting Discord messages based on specific channel IDs, followed by sentiment evaluation using the chosen language models. The system is compatible with a variety of models, such as Claude and GPT variants, ensuring versatile and robust sentiment analysis. +> **Important**: To retrieve message content, you must toggle "Message Content Intent" in the Discord Developer Portal under the `Bot` section. +> +> ![Message Content Intent](/img/discord-message-content-intent.png) + + ### Models ```go diff --git a/docs/worker-node/discord-worker.md b/docs/worker-node/discord-worker.md index 3ab47577..3ba9f3c9 100644 --- a/docs/worker-node/discord-worker.md +++ b/docs/worker-node/discord-worker.md @@ -24,18 +24,63 @@ As a worker in the Masa Oracle Node network, your primary function is to process To become a worker focused on Discord data requests, you need to: - Have your Masa Oracle Node staked as outlined in the [Staking Guide for Masa Oracle Node](staking-guide.md). +- Create a Discord bot as outlined in the [Creating a Discord Bot](#creating-a-discord-bot) section. - Add your Discord bot token to your node's `.env` file. This is crucial for authenticating with the Discord API and fetching data. - Ensure your Masa Oracle Node is up and running, with network accessibility for receiving and processing requests. -## Retrieving Your Discord Bot Token +## Creating a Discord Bot + +### Create a new Bot Application To start processing Discord data requests, you need to retrieve your Discord bot token, which is essential for authenticating with the Discord API. This token will allow your bot to collect data on your guild. Here's how to get your token: 1 . Go to the [Discord Developer Portal](https://discord.com/developers/applications). + 2 . Log in with your Discord account credentials. + 3 . Click on the "New Application" button. Give your application a name and confirm the creation. -4 . Navigate to the "Bot" tab on the left-hand side and click on "Reset Token". -5 . Under the "TOKEN" section, click on "Copy" to get your bot token. + +> ![Create a New Application](/img/discord-create-a-new-application.png) + +### Update Bot permissions and install + +1 . Go to the “Guild Install” section + +2 . Select on dropdown where is says “applications.commands and select “bot” + +> ![Update Bot Permissions](/img/discord-change-bot-permissions.png) + +3 . On the added permission dropdown after selecting bot, select “administrator” + +4 . Save changes on the bottom floating bar. + +> ![Save Bot Permissions](/img/discord-change-bot-permissions-2.png) + +5 . Copy the install link + +> ![Copy Install Link](/img/discord-install-link.png) + +6 . Go to a new tab on your browser and paste the link and then hit enter + +7 . You will go to Discord and see a modal click on add to server + +8 . Select add to server dropdown and select the guild to add your new bot to your guild. + +> ![Add Bot to Server](/img/discord-add-bot-to-server.png) + +9 . Click “Continue” + +10 . Click Authorize to add your bot. Congrats screen and should see Bot on Discord now! + +> ![Bot Added](/img/discord-verify-bot.png) + +### Retrieving Your Discord Bot Token + +1 . Navigate to the "Bot" tab on the left-hand side and click on "Reset Token". + +2 . Under the "TOKEN" section, click on "Copy" to get your bot token. + +> ![Copy Token](/img/discord-copy-bot-token.png) ### Adding Discord Credentials @@ -48,7 +93,7 @@ DISCORD_BOT_TOKEN='your_discord_bot_token' DISCORD_SCRAPER=true ``` -3 . Save the `.env` file and restart your node to apply the changes. +3 . Save the `.env` file and restart your node (`make run`) to apply the changes. ### 3) Verifying Node Configuration