https://github.com/needle-tools/deploy-to-needle-cloud-action
Automatically deploy your spatial websites to Needle Cloud using Github Actions
https://github.com/needle-tools/deploy-to-needle-cloud-action
3d ar automatically ci continuous deployment engine github hosting ios needle quicklook spatial threejs usdz vr webgl webxr
Last synced: 5 days ago
JSON representation
Automatically deploy your spatial websites to Needle Cloud using Github Actions
- Host: GitHub
- URL: https://github.com/needle-tools/deploy-to-needle-cloud-action
- Owner: needle-tools
- Created: 2025-04-02T11:57:37.000Z (22 days ago)
- Default Branch: main
- Last Pushed: 2025-04-04T10:58:18.000Z (20 days ago)
- Last Synced: 2025-04-15T14:59:49.561Z (8 days ago)
- Topics: 3d, ar, automatically, ci, continuous, deployment, engine, github, hosting, ios, needle, quicklook, spatial, threejs, usdz, vr, webgl, webxr
- Language: JavaScript
- Homepage: https://github.com/marketplace/actions/deploy-to-needle-cloud
- Size: 287 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Deploy to Needle Cloud
Automatically deploy your spatial website to [Needle Cloud](https://cloud.needle.tools) with Github Actions
## Usage
1) [Create an access token](https://cloud.needle.tools/team) on Needle Cloud with `read/write` permissions
2) Add your access token in a repository secret and name it `NEEDLE_CLOUD_TOKEN`
3) Create a github workflow, e.g. `.github/workflows/deploy.yml`*INFO*: For usage with Needle Engine make sure to install `4.4.0-beta.2` *or newer*
## Options
|Input||
|-|-|
| `token`| **required**, Needle Cloud access token
| `name` | deployment name, if no name is provided then the repository name will be used
| `dir` | root directory of the website files, must contain an `index.html`. If no directory is provided the build directory from `needle.config.json` will be used
| **Output** | |
| `url` | URL to the deployed website |### Example
```yml
- name: Deploy to Needle Cloud
uses: needle-tools/deploy-to-needle-cloud-action@v1
id: deploy
with:
token: ${{ secrets.NEEDLE_CLOUD_TOKEN }}
name: vite-template
dir: ./dist
```## Full Example
Build and deploy vite based project to Needle Cloud. See the full project [here](https://github.com/needle-engine/vite-template).
```yml
name: Build and Deploy to Needle Cloudon:
push:
branches: [ main ]jobs:
build-and-deploy:
runs-on: ubuntu-lateststeps:
- name: Checkout repository
uses: actions/checkout@v4- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: '20.x'
cache: 'npm'- name: Install dependencies
run: npm ci# Build the web project
- name: Build web project
run: npm run build:production
env:
NEEDLE_CLOUD_TOKEN: ${{ secrets.NEEDLE_CLOUD_TOKEN }}# Deploy to Needle Cloud
- name: Deploy to Needle Cloud
uses: needle-tools/deploy-to-needle-cloud-action@v1
id: deploy
with:
token: ${{ secrets.NEEDLE_CLOUD_TOKEN }}
dir: ./dist
# name: vite-template # (optional, using the repository name if not provided)
env:
NODE_ENV: production
NEEDLE_CLOUD_TOKEN: ${{ secrets.NEEDLE_CLOUD_TOKEN }}# Display the deployment URL
- name: Display deployment URL
run: |
echo "::notice title=Deployment URL::Deployed to ${{ steps.deploy.outputs.url }}"# Add to GitHub step summary (appears at bottom of workflow run)
echo "## 🚀 Deployment Summary" >> $GITHUB_STEP_SUMMARY
echo "Application has been successfully deployed to Needle Cloud!" >> $GITHUB_STEP_SUMMARY
echo "**Deployment URL:** [${{ steps.deploy.outputs.url }}](${{ steps.deploy.outputs.url }})" >> $GITHUB_STEP_SUMMARY
```# Contact ✒️
[🌵 Needle](https://needle.tools) •
[Github](https://github.com/needle-tools) •
[Twitter](https://twitter.com/NeedleTools) •
[Discord](https://discord.needle.tools) •
[Forum](https://forum.needle.tools) •
[Youtube](https://www.youtube.com/@needle-tools)