Fix: Ensure all skills are tracked as files, not submodules
This commit is contained in:
57
skills/loki-mode/.github/workflows/claude-code-review.yml
vendored
Normal file
57
skills/loki-mode/.github/workflows/claude-code-review.yml
vendored
Normal file
@@ -0,0 +1,57 @@
|
||||
name: Claude Code Review
|
||||
|
||||
on:
|
||||
pull_request:
|
||||
types: [opened, synchronize]
|
||||
# Optional: Only run on specific file changes
|
||||
# paths:
|
||||
# - "src/**/*.ts"
|
||||
# - "src/**/*.tsx"
|
||||
# - "src/**/*.js"
|
||||
# - "src/**/*.jsx"
|
||||
|
||||
jobs:
|
||||
claude-review:
|
||||
# Optional: Filter by PR author
|
||||
# if: |
|
||||
# github.event.pull_request.user.login == 'external-contributor' ||
|
||||
# github.event.pull_request.user.login == 'new-developer' ||
|
||||
# github.event.pull_request.author_association == 'FIRST_TIME_CONTRIBUTOR'
|
||||
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: read
|
||||
pull-requests: read
|
||||
issues: read
|
||||
id-token: write
|
||||
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 1
|
||||
|
||||
- name: Run Claude Code Review
|
||||
id: claude-review
|
||||
uses: anthropics/claude-code-action@v1
|
||||
with:
|
||||
claude_code_oauth_token: ${{ secrets.CLAUDE_CODE_OAUTH_TOKEN }}
|
||||
prompt: |
|
||||
REPO: ${{ github.repository }}
|
||||
PR NUMBER: ${{ github.event.pull_request.number }}
|
||||
|
||||
Please review this pull request and provide feedback on:
|
||||
- Code quality and best practices
|
||||
- Potential bugs or issues
|
||||
- Performance considerations
|
||||
- Security concerns
|
||||
- Test coverage
|
||||
|
||||
Use the repository's CLAUDE.md for guidance on style and conventions. Be constructive and helpful in your feedback.
|
||||
|
||||
Use `gh pr comment` with your Bash tool to leave your review as a comment on the PR.
|
||||
|
||||
# See https://github.com/anthropics/claude-code-action/blob/main/docs/usage.md
|
||||
# or https://code.claude.com/docs/en/cli-reference for available options
|
||||
claude_args: '--allowed-tools "Bash(gh issue view:*),Bash(gh search:*),Bash(gh issue list:*),Bash(gh pr comment:*),Bash(gh pr diff:*),Bash(gh pr view:*),Bash(gh pr list:*)"'
|
||||
|
||||
50
skills/loki-mode/.github/workflows/claude.yml
vendored
Normal file
50
skills/loki-mode/.github/workflows/claude.yml
vendored
Normal file
@@ -0,0 +1,50 @@
|
||||
name: Claude Code
|
||||
|
||||
on:
|
||||
issue_comment:
|
||||
types: [created]
|
||||
pull_request_review_comment:
|
||||
types: [created]
|
||||
issues:
|
||||
types: [opened, assigned]
|
||||
pull_request_review:
|
||||
types: [submitted]
|
||||
|
||||
jobs:
|
||||
claude:
|
||||
if: |
|
||||
(github.event_name == 'issue_comment' && contains(github.event.comment.body, '@claude')) ||
|
||||
(github.event_name == 'pull_request_review_comment' && contains(github.event.comment.body, '@claude')) ||
|
||||
(github.event_name == 'pull_request_review' && contains(github.event.review.body, '@claude')) ||
|
||||
(github.event_name == 'issues' && (contains(github.event.issue.body, '@claude') || contains(github.event.issue.title, '@claude')))
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: read
|
||||
pull-requests: read
|
||||
issues: read
|
||||
id-token: write
|
||||
actions: read # Required for Claude to read CI results on PRs
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 1
|
||||
|
||||
- name: Run Claude Code
|
||||
id: claude
|
||||
uses: anthropics/claude-code-action@v1
|
||||
with:
|
||||
claude_code_oauth_token: ${{ secrets.CLAUDE_CODE_OAUTH_TOKEN }}
|
||||
|
||||
# This is an optional setting that allows Claude to read CI results on PRs
|
||||
additional_permissions: |
|
||||
actions: read
|
||||
|
||||
# Optional: Give a custom prompt to Claude. If this is not specified, Claude will perform the instructions specified in the comment that tagged it.
|
||||
# prompt: 'Update the pull request description to include a summary of changes.'
|
||||
|
||||
# Optional: Add claude_args to customize behavior and configuration
|
||||
# See https://github.com/anthropics/claude-code-action/blob/main/docs/usage.md
|
||||
# or https://code.claude.com/docs/en/cli-reference for available options
|
||||
# claude_args: '--allowed-tools Bash(gh pr:*)'
|
||||
|
||||
128
skills/loki-mode/.github/workflows/release.yml
vendored
Normal file
128
skills/loki-mode/.github/workflows/release.yml
vendored
Normal file
@@ -0,0 +1,128 @@
|
||||
name: Release
|
||||
|
||||
on:
|
||||
push:
|
||||
paths:
|
||||
- 'VERSION'
|
||||
branches:
|
||||
- main
|
||||
|
||||
jobs:
|
||||
release:
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: write
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 0
|
||||
|
||||
- name: Read version
|
||||
id: version
|
||||
run: |
|
||||
VERSION=$(cat VERSION | tr -d '\n')
|
||||
echo "version=$VERSION" >> $GITHUB_OUTPUT
|
||||
echo "tag=v$VERSION" >> $GITHUB_OUTPUT
|
||||
|
||||
- name: Check if tag exists
|
||||
id: check_tag
|
||||
run: |
|
||||
if git rev-parse "v${{ steps.version.outputs.version }}" >/dev/null 2>&1; then
|
||||
echo "exists=true" >> $GITHUB_OUTPUT
|
||||
else
|
||||
echo "exists=false" >> $GITHUB_OUTPUT
|
||||
fi
|
||||
|
||||
- name: Create release artifacts
|
||||
if: steps.check_tag.outputs.exists == 'false'
|
||||
run: |
|
||||
mkdir -p release
|
||||
|
||||
# ============================================
|
||||
# Artifact 1: loki-mode.zip (for Claude.ai website)
|
||||
# SKILL.md at ROOT level for direct upload
|
||||
# ============================================
|
||||
mkdir -p release/skill-root
|
||||
cp SKILL.md release/skill-root/
|
||||
cp -r references release/skill-root/
|
||||
|
||||
cd release/skill-root
|
||||
zip -r ../loki-mode-${{ steps.version.outputs.version }}.zip .
|
||||
cd ../..
|
||||
|
||||
# Also create .skill file (same as zip, different extension)
|
||||
cp release/loki-mode-${{ steps.version.outputs.version }}.zip release/loki-mode-${{ steps.version.outputs.version }}.skill
|
||||
|
||||
# ============================================
|
||||
# Artifact 2: loki-mode-api.zip (for console.anthropic.com)
|
||||
# SKILL.md inside loki-mode/ folder (API requires folder wrapper)
|
||||
# ============================================
|
||||
mkdir -p release/api-package/loki-mode
|
||||
cp SKILL.md release/api-package/loki-mode/
|
||||
cp -r references release/api-package/loki-mode/
|
||||
|
||||
cd release/api-package
|
||||
zip -r ../loki-mode-api-${{ steps.version.outputs.version }}.zip loki-mode
|
||||
cd ../..
|
||||
|
||||
# ============================================
|
||||
# Artifact 3: loki-mode-claude-code.zip
|
||||
# For Claude Code: full package with loki-mode/ folder
|
||||
# Extract to ~/.claude/skills/
|
||||
# ============================================
|
||||
mkdir -p release/loki-mode
|
||||
cp SKILL.md release/loki-mode/
|
||||
cp README.md release/loki-mode/
|
||||
cp LICENSE release/loki-mode/ 2>/dev/null || true
|
||||
cp VERSION release/loki-mode/
|
||||
cp CHANGELOG.md release/loki-mode/
|
||||
cp -r references release/loki-mode/
|
||||
cp -r examples release/loki-mode/
|
||||
cp -r tests release/loki-mode/
|
||||
cp -r scripts release/loki-mode/
|
||||
cp -r autonomy release/loki-mode/
|
||||
|
||||
cd release
|
||||
zip -r loki-mode-claude-code-${{ steps.version.outputs.version }}.zip loki-mode
|
||||
tar -czvf loki-mode-claude-code-${{ steps.version.outputs.version }}.tar.gz loki-mode
|
||||
cd ..
|
||||
|
||||
- name: Create Git Tag
|
||||
if: steps.check_tag.outputs.exists == 'false'
|
||||
run: |
|
||||
git config user.name "github-actions[bot]"
|
||||
git config user.email "github-actions[bot]@users.noreply.github.com"
|
||||
git tag -a "v${{ steps.version.outputs.version }}" -m "Release v${{ steps.version.outputs.version }}"
|
||||
git push origin "v${{ steps.version.outputs.version }}"
|
||||
|
||||
- name: Extract changelog for this version
|
||||
if: steps.check_tag.outputs.exists == 'false'
|
||||
id: changelog
|
||||
run: |
|
||||
VERSION="${{ steps.version.outputs.version }}"
|
||||
CHANGELOG=$(awk "/^## \[$VERSION\]/{flag=1; next} /^## \[/{flag=0} flag" CHANGELOG.md)
|
||||
if [ -z "$CHANGELOG" ]; then
|
||||
CHANGELOG="Release v$VERSION"
|
||||
fi
|
||||
echo "$CHANGELOG" > changelog_body.txt
|
||||
|
||||
- name: Create GitHub Release
|
||||
if: steps.check_tag.outputs.exists == 'false'
|
||||
env:
|
||||
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
run: |
|
||||
gh release create "v${{ steps.version.outputs.version }}" \
|
||||
release/loki-mode-${{ steps.version.outputs.version }}.zip \
|
||||
release/loki-mode-${{ steps.version.outputs.version }}.skill \
|
||||
release/loki-mode-api-${{ steps.version.outputs.version }}.zip \
|
||||
release/loki-mode-claude-code-${{ steps.version.outputs.version }}.zip \
|
||||
release/loki-mode-claude-code-${{ steps.version.outputs.version }}.tar.gz \
|
||||
--title "Loki Mode v${{ steps.version.outputs.version }}" \
|
||||
--notes-file changelog_body.txt
|
||||
|
||||
- name: Skip message
|
||||
if: steps.check_tag.outputs.exists == 'true'
|
||||
run: |
|
||||
echo "Tag v${{ steps.version.outputs.version }} already exists. Skipping release."
|
||||
Reference in New Issue
Block a user