Skip to content

Commit

Permalink
Merge pull request #6100 from SAHU-01/master
Browse files Browse the repository at this point in the history
Fixing broken pricing page
  • Loading branch information
SAHU-01 authored Dec 4, 2024
2 parents b84327f + e50c413 commit 937f56a
Show file tree
Hide file tree
Showing 5 changed files with 1,178 additions and 278 deletions.
90 changes: 49 additions & 41 deletions .github/workflows/feature-list.yml
Original file line number Diff line number Diff line change
@@ -1,9 +1,14 @@
name: Feature List

on:
workflow_dispatch: # Allows manual triggering of the workflow
workflow_dispatch:
inputs:
spreadsheet_uri:
description: 'Link of the spreadsheet containing subscription details.'
type: string
required: true
schedule:
- cron: '30 0 * * *' # Scheduled to run daily at 00:30 (12:30 AM)
- cron: '0 0 * * *'

permissions:
contents: write
Expand All @@ -13,8 +18,7 @@ jobs:
trigger-feature-list:
runs-on: ubuntu-latest
env:
FEATURES_FILE: 'src/sections/Pricing/feature_data.json'
SPREADSHEET_URL: 'http://docs.google.com/spreadsheets/d/1Ck_5q7U_vLSIDTtplugG3pCVC5zugXgTHtO7T7-yL8g/export?format=csv&gid=829069645&single=true&output=csv'
FEATURES_FILE: 'feature_data.json'

steps:
- name: Checkout current repository
Expand All @@ -28,52 +32,56 @@ jobs:
key: feature-data-sha
restore-keys: |
feature-data-sha
- name: Install Node.js
uses: actions/setup-node@v3
with:
node-version: 18

- name: Install dependencies
run: |
npm install csvtojson --legacy-peer-deps
- name: Fetch spreadsheet and check for updates
- name: Check for updates in source repository
id: check-updates
run: |
# Download the spreadsheet
curl -L $SPREADSHEET_URL -o spreadsheet.csv
# Generate a SHA hash of the file
sha256sum spreadsheet.csv > .sha-cache/latest-sha
# Compare the hash with the previously stored hash
if [ -f ".sha-cache/last-sha" ] && cmp --silent .sha-cache/latest-sha .sha-cache/last-sha; then
echo "No updates detected."
echo "has-updates=false" >> $GITHUB_OUTPUT
else
echo "Updates detected. Processing..."
cp .sha-cache/latest-sha .sha-cache/last-sha
# Convert CSV to JSON (Assume a script or tool to do this is present)
node -e "
const fs = require('fs');
const csv = require('csvtojson');
csv()
.fromFile('spreadsheet.csv')
.then(json => fs.writeFileSync(process.env.FEATURES_FILE, JSON.stringify(json, null, 2)));
"
echo "has-updates=true" >> $GITHUB_OUTPUT
fi
uses: actions/github-script@v7
with:
script: |
const { data: sourceFile } = await github.rest.repos.getContent({
owner: 'layer5labs',
repo: 'meshery-extensions-packages',
path: 'feature_data.json',
ref: 'master'
});
// Store the latest commit SHA
const latestSHA = sourceFile.sha;
const fs = require('fs');
// Check if we have a previous SHA
let hasUpdates = true;
const shaCachePath = '.sha-cache/latest-sha';
if (fs.existsSync(shaCachePath)) {
const lastSHA = fs.readFileSync(shaCachePath, 'utf8');
hasUpdates = lastSHA !== latestSHA;
}
if (hasUpdates) {
// Save the new SHA
fs.mkdirSync('.sha-cache', { recursive: true });
fs.writeFileSync(shaCachePath, latestSHA);
// Decode and save the content
const content = Buffer.from(sourceFile.content, 'base64').toString('utf8');
// Write the new content
fs.writeFileSync(process.env.FEATURES_FILE, content);
core.setOutput('has-updates', 'true');
} else {
core.setOutput('has-updates', 'false');
}
- name: Commit changes
if: steps.check-updates.outputs.has-updates == 'true'
uses: stefanzweifel/git-auto-commit-action@v5
with:
commit_message: "Updated feature data from spreadsheet"
commit_message: "Updated feature data from source repository"
file_pattern: ${{ env.FEATURES_FILE }}
branch: master
commit_options: "--signoff"
commit_user_name: l5io
commit_user_email: [email protected]
commit_author: 'l5io <[email protected]>'
commit_author: 'l5io <[email protected]>'
Loading

0 comments on commit 937f56a

Please sign in to comment.