mirror of
https://github.com/vitodeploy/vito.git
synced 2025-07-01 14:06:15 +00:00
Compare commits
87 Commits
Author | SHA1 | Date | |
---|---|---|---|
2318e1b1df | |||
65898b0ee6 | |||
3124f8c795 | |||
76059aff3c | |||
ff4d560e44 | |||
dda345f565 | |||
564b97e2aa | |||
4e5f975917 | |||
f3500497d0 | |||
996df64386 | |||
e98e974e20 | |||
2a670146d8 | |||
f483f7fdca | |||
7882d2022c | |||
03be2d3ee2 | |||
f89e7af34e | |||
7886e2a113 | |||
72352aad8d | |||
48ae561ea4 | |||
0f06d81aac | |||
493cbb0849 | |||
c22bb1fa80 | |||
babf59350b | |||
5a12ed76bb | |||
269ee8d962 | |||
a060a06e73 | |||
49137a757b | |||
97e20206e8 | |||
176ff3bbc4 | |||
b2440586d6 | |||
4b8e798e66 | |||
6143eb94b4 | |||
e52903c649 | |||
1a5cf4c57a | |||
d8ece27964 | |||
f54c754971 | |||
7cda14cb76 | |||
3bf3f7eebc | |||
e17fdbb1a0 | |||
e99146209e | |||
1223ea1499 | |||
2356e44f5b | |||
8c7c3d2192 | |||
e2b9d18a71 | |||
75e554ad74 | |||
4d59529767 | |||
ea31d0978f | |||
ee4e9e5452 | |||
48c12e26b2 | |||
72f68b5917 | |||
a889cf11a2 | |||
75a4fde8de | |||
fd67097884 | |||
705d029a63 | |||
7be63384d4 | |||
dd78c86a60 | |||
262c5e040d | |||
ea396786e4 | |||
6966f06b1a | |||
53e20cbc2a | |||
270928af13 | |||
1e4a944acb | |||
d702b95e0c | |||
7b723bcba5 | |||
8b58834a31 | |||
cdbde063f0 | |||
a73476c1dd | |||
465951fd1e | |||
b63ddfc568 | |||
bfdf3533fd | |||
c1ae58772c | |||
5947ae80bb | |||
93a7bf9c3a | |||
a0940d4581 | |||
e976709522 | |||
5aa100519e | |||
ab43dfb2a6 | |||
a320e52dbf | |||
20c6b58866 | |||
f5c9d6701b | |||
ba069a2db0 | |||
8b86ff23c9 | |||
dfdd50beb7 | |||
924920e6e8 | |||
da1043185a | |||
ea3d64607a | |||
db81583884 |
42
.github/workflows/code-quality.yml
vendored
Normal file
42
.github/workflows/code-quality.yml
vendored
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
name: code-quality
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- 2.x
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- 2.x
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
tests:
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
fail-fast: true
|
||||||
|
matrix:
|
||||||
|
php: [ 8.2 ]
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Setup PHP
|
||||||
|
uses: shivammathur/setup-php@v2
|
||||||
|
with:
|
||||||
|
php-version: ${{ matrix.php }}
|
||||||
|
|
||||||
|
- name: Cache Composer packages
|
||||||
|
id: composer-cache
|
||||||
|
uses: actions/cache@v4
|
||||||
|
with:
|
||||||
|
path: vendor
|
||||||
|
key: ${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-php-
|
||||||
|
|
||||||
|
- name: Install dependencies
|
||||||
|
if: steps.composer-cache.outputs.cache-hit != 'true'
|
||||||
|
run: composer install --prefer-dist --no-progress --no-suggest
|
||||||
|
|
||||||
|
- name: Run PHPStan
|
||||||
|
run: ./vendor/bin/phpstan analyse
|
6
.github/workflows/code-style.yml
vendored
6
.github/workflows/code-style.yml
vendored
@ -19,7 +19,7 @@ jobs:
|
|||||||
node-version: [ "20.x" ]
|
node-version: [ "20.x" ]
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
@ -28,7 +28,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Cache Composer packages
|
- name: Cache Composer packages
|
||||||
id: composer-cache
|
id: composer-cache
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v4
|
||||||
with:
|
with:
|
||||||
path: vendor
|
path: vendor
|
||||||
key: ${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }}
|
key: ${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }}
|
||||||
@ -43,7 +43,7 @@ jobs:
|
|||||||
run: ./vendor/bin/pint --test
|
run: ./vendor/bin/pint --test
|
||||||
|
|
||||||
- name: Setup Node.js
|
- name: Setup Node.js
|
||||||
uses: actions/setup-node@v2
|
uses: actions/setup-node@v4
|
||||||
with:
|
with:
|
||||||
node-version: "20.x"
|
node-version: "20.x"
|
||||||
|
|
||||||
|
@ -1,36 +1,34 @@
|
|||||||
name: Build and push Docker image
|
name: Docker Latest
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
workflow_dispatch:
|
||||||
branches:
|
# push:
|
||||||
- 1.x
|
# branches:
|
||||||
- 2.x
|
# - 2.x
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-and-push:
|
build-and-push:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout code
|
- name: Checkout code
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Set up QEMU
|
- name: Set up QEMU
|
||||||
uses: docker/setup-qemu-action@v1
|
uses: docker/setup-qemu-action@v2
|
||||||
|
|
||||||
- name: Set up Docker Buildx
|
- name: Set up Docker Buildx
|
||||||
uses: docker/setup-buildx-action@v1
|
uses: docker/setup-buildx-action@v2
|
||||||
|
|
||||||
- name: Login to Docker Hub
|
- name: Login to Docker Hub
|
||||||
uses: docker/login-action@v2
|
uses: docker/login-action@v3
|
||||||
with:
|
with:
|
||||||
username: ${{ secrets.DOCKER_USERNAME }}
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
|
||||||
- name: Build and push Docker image
|
- name: Build and push to the latest tag
|
||||||
run: |
|
run: |
|
||||||
docker buildx build . \
|
docker buildx build . \
|
||||||
-f docker/Dockerfile \
|
-f docker/Dockerfile \
|
||||||
-t vitodeploy/vito:${{ github.head_ref || github.ref_name }} \
|
-t vitodeploy/vito:latest \
|
||||||
--build-arg="RELEASE=0" \
|
|
||||||
--platform linux/amd64,linux/arm64 \
|
--platform linux/amd64,linux/arm64 \
|
||||||
--no-cache \
|
|
||||||
--push
|
--push
|
32
.github/workflows/docker-release.yml
vendored
32
.github/workflows/docker-release.yml
vendored
@ -1,44 +1,52 @@
|
|||||||
name: Build and push Docker image
|
name: Docker Release
|
||||||
|
|
||||||
on:
|
on:
|
||||||
release:
|
workflow_dispatch:
|
||||||
types: [ created ]
|
# release:
|
||||||
|
# types: [ created ]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-and-push:
|
build-and-push:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout code
|
- name: Checkout code
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Set up QEMU
|
- name: Set up QEMU
|
||||||
uses: docker/setup-qemu-action@v1
|
uses: docker/setup-qemu-action@v2
|
||||||
|
|
||||||
- name: Set up Docker Buildx
|
- name: Set up Docker Buildx
|
||||||
uses: docker/setup-buildx-action@v1
|
uses: docker/setup-buildx-action@v2
|
||||||
|
|
||||||
- name: Login to Docker Hub
|
- name: Login to Docker Hub
|
||||||
uses: docker/login-action@v2
|
uses: docker/login-action@v3
|
||||||
with:
|
with:
|
||||||
username: ${{ secrets.DOCKER_USERNAME }}
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
|
||||||
- name: Build and push Docker image
|
- name: Build and push to the release tag
|
||||||
run: |
|
run: |
|
||||||
docker buildx build . \
|
docker buildx build . \
|
||||||
-f docker/Dockerfile \
|
-f docker/Dockerfile \
|
||||||
-t vitodeploy/vito:${{ github.event.release.tag_name }} \
|
-t vitodeploy/vito:${{ github.event.release.tag_name }} \
|
||||||
--build-arg="RELEASE=0" \
|
|
||||||
--platform linux/amd64,linux/arm64 \
|
--platform linux/amd64,linux/arm64 \
|
||||||
--no-cache \
|
--no-cache \
|
||||||
--push
|
--push
|
||||||
|
|
||||||
- name: Build and push latest tag
|
- name: Build and push to the 1.x tag
|
||||||
|
if: startsWith(github.event.release.target_commitish, '1.x')
|
||||||
|
run: |
|
||||||
|
docker buildx build . \
|
||||||
|
-f docker/Dockerfile \
|
||||||
|
-t vitodeploy/vito:1.x \
|
||||||
|
--platform linux/amd64,linux/arm64 \
|
||||||
|
--push
|
||||||
|
|
||||||
|
- name: Build and push to the 2.x tag
|
||||||
if: startsWith(github.event.release.target_commitish, '2.x')
|
if: startsWith(github.event.release.target_commitish, '2.x')
|
||||||
run: |
|
run: |
|
||||||
docker buildx build . \
|
docker buildx build . \
|
||||||
-f docker/Dockerfile \
|
-f docker/Dockerfile \
|
||||||
-t vitodeploy/vito:latest \
|
-t vitodeploy/vito:2.x \
|
||||||
--build-arg="RELEASE=0" \
|
|
||||||
--platform linux/amd64,linux/arm64 \
|
--platform linux/amd64,linux/arm64 \
|
||||||
--push
|
--push
|
||||||
|
8
.github/workflows/tests.yml
vendored
8
.github/workflows/tests.yml
vendored
@ -18,7 +18,7 @@ jobs:
|
|||||||
php: [ 8.2 ]
|
php: [ 8.2 ]
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
@ -27,12 +27,13 @@ jobs:
|
|||||||
|
|
||||||
- name: Cache Composer packages
|
- name: Cache Composer packages
|
||||||
id: composer-cache
|
id: composer-cache
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v4
|
||||||
with:
|
with:
|
||||||
path: vendor
|
path: vendor
|
||||||
key: ${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }}
|
key: ${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }}
|
||||||
restore-keys: |
|
restore-keys: |
|
||||||
${{ runner.os }}-php-
|
${{ runner.os }}-php-
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
if: steps.composer-cache.outputs.cache-hit != 'true'
|
if: steps.composer-cache.outputs.cache-hit != 'true'
|
||||||
run: composer install --prefer-dist --no-progress --no-suggest
|
run: composer install --prefer-dist --no-progress --no-suggest
|
||||||
@ -40,5 +41,8 @@ jobs:
|
|||||||
- name: Create sqlite database
|
- name: Create sqlite database
|
||||||
run: touch storage/database-test.sqlite
|
run: touch storage/database-test.sqlite
|
||||||
|
|
||||||
|
- name: Set up the .env file
|
||||||
|
run: touch .env
|
||||||
|
|
||||||
- name: Run test suite
|
- name: Run test suite
|
||||||
run: php artisan test
|
run: php artisan test
|
||||||
|
@ -12,3 +12,4 @@ sail
|
|||||||
*.yml
|
*.yml
|
||||||
!*.blade.php
|
!*.blade.php
|
||||||
!*.sh
|
!*.sh
|
||||||
|
resources/views/ssh/
|
||||||
|
@ -35,7 +35,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -43,7 +43,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -60,7 +60,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 6ed1gv5ak6hEPcaV8D3Z4bf'
|
- 'Bearer eDa6Vdh1Z4vc35bP8E6gafk'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -97,7 +97,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -105,7 +105,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
@ -113,7 +113,7 @@ endpoints:
|
|||||||
name: command
|
name: command
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: qui
|
example: quia
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -142,7 +142,7 @@ endpoints:
|
|||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
command: qui
|
command: quia
|
||||||
user: root
|
user: root
|
||||||
frequency: '* * * * *'
|
frequency: '* * * * *'
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
@ -157,7 +157,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer VEfc5h3gva68PkZ46Deabd1'
|
- 'Bearer 66EeZvdh3kVaDP8f4ga5c1b'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -194,7 +194,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -204,7 +204,7 @@ endpoints:
|
|||||||
name: cronJob_id
|
name: cronJob_id
|
||||||
description: 'The ID of the cronJob.'
|
description: 'The ID of the cronJob.'
|
||||||
required: true
|
required: true
|
||||||
example: 5
|
example: 6
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -212,8 +212,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
cronJob_id: 5
|
cronJob_id: 6
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -230,7 +230,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 614DaP5vZ6edcaVEgfhk83b'
|
- 'Bearer D4c3Z65ebv8E16fahaVgPdk'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -267,7 +267,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -277,7 +277,7 @@ endpoints:
|
|||||||
name: cronJob_id
|
name: cronJob_id
|
||||||
description: 'The ID of the cronJob.'
|
description: 'The ID of the cronJob.'
|
||||||
required: true
|
required: true
|
||||||
example: 5
|
example: 13
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -285,8 +285,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
cronJob_id: 5
|
cronJob_id: 13
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -295,7 +295,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -303,7 +303,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer gDV6bZ1dEckvf45P86eaha3'
|
- 'Bearer h3cP4aZa1v8feDdEg5b6k6V'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -35,7 +35,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -43,7 +43,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -52,7 +52,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"server_id":null,"name":"clockman","status":"ready","created_at":null,"updated_at":null},{"id":null,"server_id":null,"name":"wvonrueden","status":"ready","created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"server_id":null,"name":"leffler.esther","status":"ready","created_at":null,"updated_at":null},{"id":null,"server_id":null,"name":"rhoda.rutherford","status":"ready","created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -60,7 +60,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer efEV4g86bd5PZac6vak3Dh1'
|
- 'Bearer E1VdfegZah4k86b53Dc6Pva'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -97,7 +97,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -105,7 +105,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
@ -113,19 +113,41 @@ endpoints:
|
|||||||
name: name
|
name: name
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: nesciunt
|
example: quisquam
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
charset:
|
||||||
|
name: charset
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: omnis
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
collation:
|
||||||
|
name: collation
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: at
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
name: nesciunt
|
name: quisquam
|
||||||
|
charset: omnis
|
||||||
|
collation: at
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"name":"johanna76","status":"ready","created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"name":"csawayn","status":"ready","created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -133,7 +155,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 3E6VD14dvaekbaZfh6Pg8c5'
|
- 'Bearer PVgkZ35ca4afd1EbD8ehv66'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -170,7 +192,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -180,7 +202,7 @@ endpoints:
|
|||||||
name: id
|
name: id
|
||||||
description: 'The ID of the database.'
|
description: 'The ID of the database.'
|
||||||
required: true
|
required: true
|
||||||
example: 6
|
example: 8
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -188,8 +210,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
id: 6
|
id: 8
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -198,7 +220,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"name":"chloe.huel","status":"ready","created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"name":"sandrine43","status":"ready","created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -206,7 +228,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer fb5hVc38e1aDP6ZvkgEda46'
|
- 'Bearer EP64D8g51adf6hbceavVZ3k'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -243,7 +265,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -253,7 +275,7 @@ endpoints:
|
|||||||
name: database_id
|
name: database_id
|
||||||
description: 'The ID of the database.'
|
description: 'The ID of the database.'
|
||||||
required: true
|
required: true
|
||||||
example: 6
|
example: 8
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -261,8 +283,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
database_id: 6
|
database_id: 8
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -271,7 +293,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -279,7 +301,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer cPVbhaZkfg5aEv46D183ed6'
|
- 'Bearer 8dgEk3Zv1eaVP66bDhf4ac5'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -35,7 +35,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -43,7 +43,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -52,7 +52,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"server_id":null,"username":"nyasia68","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"username":"madyson20","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"server_id":null,"username":"letha64","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"username":"hagenes.lurline","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -60,7 +60,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer egc5VaDdvabfP6843k61hZE'
|
- 'Bearer d4g15bV3Pa6hDvck6eaEf8Z'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -97,7 +97,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -105,7 +105,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
@ -113,7 +113,7 @@ endpoints:
|
|||||||
name: username
|
name: username
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: dignissimos
|
example: qui
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -123,7 +123,7 @@ endpoints:
|
|||||||
name: password
|
name: password
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: OK+XEG2)
|
example: 'xYv*3,#HQ=5<w!'
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -140,14 +140,14 @@ endpoints:
|
|||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
username: dignissimos
|
username: qui
|
||||||
password: OK+XEG2)
|
password: 'xYv*3,#HQ=5<w!'
|
||||||
host: '%'
|
host: '%'
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"username":"amya.nitzsche","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"username":"marcelle95","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -155,7 +155,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 31hgfcvEb6Pkaa48D6dZ5Ve'
|
- 'Bearer 3vZ6f6kagacDEhV1Pde5b84'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -192,7 +192,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -202,7 +202,7 @@ endpoints:
|
|||||||
name: databaseUser_id
|
name: databaseUser_id
|
||||||
description: 'The ID of the databaseUser.'
|
description: 'The ID of the databaseUser.'
|
||||||
required: true
|
required: true
|
||||||
example: 4
|
example: 1
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -210,8 +210,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
databaseUser_id: 4
|
databaseUser_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -220,7 +220,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"username":"bergstrom.ericka","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"username":"brandi53","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -228,7 +228,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer aDv48631h5af6EdkcVbPZeg'
|
- 'Bearer af3b5ac6dP8ZV4vE1hk6eDg'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -265,7 +265,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -283,7 +283,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
databaseUser_id: 4
|
databaseUser_id: 4
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
@ -292,19 +292,19 @@ endpoints:
|
|||||||
name: databases
|
name: databases
|
||||||
description: 'Array of database names to link to the user.'
|
description: 'Array of database names to link to the user.'
|
||||||
required: true
|
required: true
|
||||||
example: accusantium
|
example: maiores
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
databases: accusantium
|
databases: maiores
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"username":"fmurray","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"username":"kschmidt","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -312,7 +312,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer cf8ZPhV1k3d5DaEva46beg6'
|
- 'Bearer b6f3Ed641gaZDcVa5k8vePh'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -349,7 +349,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -359,7 +359,7 @@ endpoints:
|
|||||||
name: databaseUser_id
|
name: databaseUser_id
|
||||||
description: 'The ID of the databaseUser.'
|
description: 'The ID of the databaseUser.'
|
||||||
required: true
|
required: true
|
||||||
example: 4
|
example: 20
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -367,8 +367,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
databaseUser_id: 4
|
databaseUser_id: 20
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -377,7 +377,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -385,7 +385,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer hdEvkbaPVf4cZ65a8631eDg'
|
- 'Bearer Zka6fh15g6eaV8vE34cDPdb'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -35,7 +35,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -43,7 +43,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -52,7 +52,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"server_id":null,"type":"allow","protocol":"tcp","port":18074,"source":"189.27.156.82","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"type":"allow","protocol":"tcp","port":41088,"source":"86.177.121.87","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"name":"ut","server_id":null,"type":"allow","protocol":"tcp","port":35499,"source":"177.130.54.250","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null},{"id":null,"name":"totam","server_id":null,"type":"allow","protocol":"tcp","port":29448,"source":"181.194.26.13","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -60,7 +60,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer vhkc4aPa6ZdeV8D3Ef156gb'
|
- 'Bearer eD368kaZfVEab4v61ghdP5c'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -97,7 +97,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -105,10 +105,20 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: sapiente
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
type:
|
type:
|
||||||
name: type
|
name: type
|
||||||
description: ''
|
description: ''
|
||||||
@ -125,7 +135,7 @@ endpoints:
|
|||||||
name: protocol
|
name: protocol
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: udp
|
example: tcp
|
||||||
type: string
|
type: string
|
||||||
enumValues:
|
enumValues:
|
||||||
- tcp
|
- tcp
|
||||||
@ -137,7 +147,7 @@ endpoints:
|
|||||||
name: port
|
name: port
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: voluptates
|
example: et
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -146,8 +156,8 @@ endpoints:
|
|||||||
source:
|
source:
|
||||||
name: source
|
name: source
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: false
|
||||||
example: saepe
|
example: doloribus
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -164,16 +174,17 @@ endpoints:
|
|||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
|
name: sapiente
|
||||||
type: allow
|
type: allow
|
||||||
protocol: udp
|
protocol: tcp
|
||||||
port: voluptates
|
port: et
|
||||||
source: saepe
|
source: doloribus
|
||||||
mask: '0'
|
mask: '0'
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"type":"allow","protocol":"tcp","port":61992,"source":"47.222.76.48","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"name":"omnis","server_id":null,"type":"allow","protocol":"tcp","port":54634,"source":"246.242.9.65","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -181,7 +192,150 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 1cEb5P66VeDkf8aahg3Zdv4'
|
- 'Bearer 3184PbED6aacZveV6hf5dgk'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- PUT
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/firewall-rules/{firewallRule_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: firewall-rules
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: edit
|
||||||
|
description: 'Update an existing firewall rule.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
firewallRule_id:
|
||||||
|
name: firewallRule_id
|
||||||
|
description: 'The ID of the firewallRule.'
|
||||||
|
required: true
|
||||||
|
example: 85
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
firewallRule_id: 85
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters:
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: et
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
type:
|
||||||
|
name: type
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: allow
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- allow
|
||||||
|
- deny
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
protocol:
|
||||||
|
name: protocol
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: tcp
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- tcp
|
||||||
|
- udp
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
port:
|
||||||
|
name: port
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: aut
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
source:
|
||||||
|
name: source
|
||||||
|
description: ''
|
||||||
|
required: false
|
||||||
|
example: et
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
mask:
|
||||||
|
name: mask
|
||||||
|
description: 'Mask for source IP.'
|
||||||
|
required: true
|
||||||
|
example: '0'
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanBodyParameters:
|
||||||
|
name: et
|
||||||
|
type: allow
|
||||||
|
protocol: tcp
|
||||||
|
port: aut
|
||||||
|
source: et
|
||||||
|
mask: '0'
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":null,"name":"consequatur","server_id":null,"type":"allow","protocol":"tcp","port":879,"source":"206.106.27.116","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer ad46E3egPDc51aV6hb8vkZf'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -218,7 +372,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -228,7 +382,7 @@ endpoints:
|
|||||||
name: firewallRule_id
|
name: firewallRule_id
|
||||||
description: 'The ID of the firewallRule.'
|
description: 'The ID of the firewallRule.'
|
||||||
required: true
|
required: true
|
||||||
example: 7
|
example: 85
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -236,8 +390,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
firewallRule_id: 7
|
firewallRule_id: 85
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -246,7 +400,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"type":"allow","protocol":"tcp","port":43107,"source":"135.73.216.16","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"name":"dolores","server_id":null,"type":"allow","protocol":"tcp","port":4691,"source":"147.108.28.144","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -254,7 +408,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 6VaPhkD5vd1Z8e6E3cba4gf'
|
- 'Bearer 6gkvbDae15a6f43EVPdZh8c'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -291,7 +445,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -301,7 +455,7 @@ endpoints:
|
|||||||
name: firewallRule_id
|
name: firewallRule_id
|
||||||
description: 'The ID of the firewallRule.'
|
description: 'The ID of the firewallRule.'
|
||||||
required: true
|
required: true
|
||||||
example: 7
|
example: 85
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -309,8 +463,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
firewallRule_id: 7
|
firewallRule_id: 85
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -319,7 +473,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -327,7 +481,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer v81d5Efch636aVgZebaPkD4'
|
- 'Bearer ZVd1fk5E3e48hDvaa6g6cPb'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -29,7 +29,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"success":true,"version":"2.0.0"}'
|
content: '{"success":true,"version":"2.4.0"}'
|
||||||
headers:
|
headers:
|
||||||
cache-control: 'no-cache, private'
|
cache-control: 'no-cache, private'
|
||||||
content-type: application/json
|
content-type: application/json
|
||||||
|
@ -30,7 +30,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":29,"name":"Zachary Lueilwitz","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"},{"id":30,"name":"Mrs. Kiarra Heller IV","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":3,"name":"Mr. Drake Nader","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"},{"id":4,"name":"Wilhelmine Jacobson","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -38,7 +38,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer eb14DEPv6cdah65VfZgka38'
|
- 'Bearer fbPE6haeDZ8v1gV5ak463dc'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -69,19 +69,19 @@ endpoints:
|
|||||||
name: name
|
name: name
|
||||||
description: 'The name of the project.'
|
description: 'The name of the project.'
|
||||||
required: true
|
required: true
|
||||||
example: quos
|
example: dignissimos
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
name: quos
|
name: dignissimos
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":29,"name":"Hershel Spinka","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":3,"name":"Pattie Cole","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -89,7 +89,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer V1E3566Pf4gkvh8dDZabeca'
|
- 'Bearer 6ZkedcEfa5V6Dv4ab8P3g1h'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -132,7 +132,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":29,"name":"Emery Kiehn","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":3,"name":"Mr. Elias Bauch","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -140,7 +140,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer haD6e36VZbkf4P8aEcvd15g'
|
- 'Bearer P6ka4Zaefgh8Ec3dV15v6bD'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -182,19 +182,19 @@ endpoints:
|
|||||||
name: name
|
name: name
|
||||||
description: 'The name of the project.'
|
description: 'The name of the project.'
|
||||||
required: true
|
required: true
|
||||||
example: ut
|
example: sunt
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
name: ut
|
name: sunt
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":29,"name":"Mable Prohaska","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":3,"name":"Elfrieda Jakubowski","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -202,7 +202,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer V14kPa5deva8Ebgc36f6hDZ'
|
- 'Bearer ecaDZkf5E4vgP1V86d6hb3a'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -245,7 +245,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -253,7 +253,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer k1D68d5ePavVZag6h4fb3cE'
|
- 'Bearer h5gZ63DPVbcevE4faka86d1'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -1,19 +1,19 @@
|
|||||||
## Autogenerated by Scribe. DO NOT MODIFY.
|
## Autogenerated by Scribe. DO NOT MODIFY.
|
||||||
|
|
||||||
name: servers
|
name: redirects
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers'
|
uri: 'api/projects/{project_id}/servers/{server_id}/sites/{site_id}/redirects'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: servers
|
groupName: redirects
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: list
|
title: index
|
||||||
description: 'Get all servers in a project.'
|
description: 'Get all redirects.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -31,8 +31,30 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
site_id:
|
||||||
|
name: site_id
|
||||||
|
description: 'The ID of the site.'
|
||||||
|
required: true
|
||||||
|
example: 44
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
site_id: 44
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -41,7 +63,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Dorthy Toy","ssh_user":"vito","ip":"172.132.95.155","local_ip":"118.57.197.65","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null},{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Carrie Sporer","ssh_user":"vito","ip":"184.242.162.173","local_ip":"135.244.50.22","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"site_id":null,"mode":307,"from":"ipsum","to":"http:\/\/fritsch.biz\/","status":"ready","created_at":null,"updated_at":null},{"id":null,"site_id":null,"mode":302,"from":"culpa","to":"http:\/\/www.huels.net\/aut-ut-ut-porro-non-rerum-voluptatum.html","status":"ready","created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -49,7 +71,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 8VE41PdZcvb6kgafD635ahe'
|
- 'Bearer cV16fevgEZhPadD43685akb'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -57,14 +79,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- POST
|
- POST
|
||||||
uri: 'api/projects/{project_id}/servers'
|
uri: 'api/projects/{project_id}/servers/{server_id}/sites/{site_id}/redirects'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: servers
|
groupName: redirects
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: create
|
title: create
|
||||||
description: 'Create a new server.'
|
description: 'Create a new redirect.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -82,178 +104,76 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
site_id:
|
||||||
|
name: site_id
|
||||||
|
description: 'The ID of the site.'
|
||||||
|
required: true
|
||||||
|
example: 44
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
site_id: 44
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
provider:
|
from:
|
||||||
name: provider
|
name: from
|
||||||
description: 'The server provider type'
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: et
|
example: odit
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
server_provider:
|
to:
|
||||||
name: server_provider
|
name: to
|
||||||
description: 'If the provider is not custom, the ID of the server provider profile'
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: digitalocean
|
example: incidunt
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
mode:
|
||||||
|
name: mode
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: 301
|
||||||
type: string
|
type: string
|
||||||
enumValues:
|
enumValues:
|
||||||
- custom
|
- 301
|
||||||
- hetzner
|
- 302
|
||||||
- digitalocean
|
- 307
|
||||||
- linode
|
- 308
|
||||||
- vultr
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
region:
|
|
||||||
name: region
|
|
||||||
description: 'Provider region if the provider is not custom'
|
|
||||||
required: true
|
|
||||||
example: inventore
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
plan:
|
|
||||||
name: plan
|
|
||||||
description: 'Provider plan if the provider is not custom'
|
|
||||||
required: true
|
|
||||||
example: atque
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
ip:
|
|
||||||
name: ip
|
|
||||||
description: 'SSH IP address if the provider is custom'
|
|
||||||
required: true
|
|
||||||
example: quam
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
port:
|
|
||||||
name: port
|
|
||||||
description: 'SSH Port if the provider is custom'
|
|
||||||
required: true
|
|
||||||
example: nemo
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
name:
|
|
||||||
name: name
|
|
||||||
description: 'The name of the server.'
|
|
||||||
required: true
|
|
||||||
example: perspiciatis
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
os:
|
|
||||||
name: os
|
|
||||||
description: 'The os of the server'
|
|
||||||
required: true
|
|
||||||
example: similique
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
type:
|
|
||||||
name: type
|
|
||||||
description: 'Server type'
|
|
||||||
required: true
|
|
||||||
example: regular
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- regular
|
|
||||||
- database
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
webserver:
|
|
||||||
name: webserver
|
|
||||||
description: 'Web server'
|
|
||||||
required: true
|
|
||||||
example: none
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- none
|
|
||||||
- nginx
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
database:
|
|
||||||
name: database
|
|
||||||
description: Database
|
|
||||||
required: true
|
|
||||||
example: none
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- none
|
|
||||||
- mysql57
|
|
||||||
- mysql80
|
|
||||||
- mariadb103
|
|
||||||
- mariadb104
|
|
||||||
- mariadb103
|
|
||||||
- postgresql12
|
|
||||||
- postgresql13
|
|
||||||
- postgresql14
|
|
||||||
- postgresql15
|
|
||||||
- postgresql16
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
php:
|
|
||||||
name: php
|
|
||||||
description: 'PHP version'
|
|
||||||
required: true
|
|
||||||
example: '8.1'
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- '7.0'
|
|
||||||
- '7.1'
|
|
||||||
- '7.2'
|
|
||||||
- '7.3'
|
|
||||||
- '7.4'
|
|
||||||
- '8.0'
|
|
||||||
- '8.1'
|
|
||||||
- '8.2'
|
|
||||||
- '8.3'
|
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
provider: et
|
from: odit
|
||||||
server_provider: digitalocean
|
to: incidunt
|
||||||
region: inventore
|
mode: 301
|
||||||
plan: atque
|
|
||||||
ip: quam
|
|
||||||
port: nemo
|
|
||||||
name: perspiciatis
|
|
||||||
os: similique
|
|
||||||
type: regular
|
|
||||||
webserver: none
|
|
||||||
database: none
|
|
||||||
php: '8.1'
|
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Flo Beer PhD","ssh_user":"vito","ip":"168.238.14.230","local_ip":"40.232.73.41","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -261,193 +181,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer Z8g36aaV4E1bdcPfehDv65k'
|
- 'Bearer ZD45hPk638abev61EVcagdf'
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- GET
|
|
||||||
uri: 'api/projects/{project_id}/servers/{id}'
|
|
||||||
metadata:
|
|
||||||
groupName: servers
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: show
|
|
||||||
description: 'Get a server by ID.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
id:
|
|
||||||
name: id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
id: 3
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 200
|
|
||||||
content: '{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Stephany Ankunding","ssh_user":"vito","ip":"145.28.94.46","local_ip":"69.133.44.100","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer adD3EfP5hZ4vgbkV861eca6'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/reboot'
|
|
||||||
metadata:
|
|
||||||
groupName: servers
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: reboot
|
|
||||||
description: 'Reboot a server.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer P3ec6aagD4hbdV5fEk168vZ'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/upgrade'
|
|
||||||
metadata:
|
|
||||||
groupName: servers
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: upgrade
|
|
||||||
description: 'Upgrade server.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer P34ZV6D1bEegdvac8f5kh6a'
|
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -455,14 +189,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- DELETE
|
- DELETE
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/sites/{site_id}/redirects/{redirect_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: servers
|
groupName: redirects
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: delete
|
title: delete
|
||||||
description: 'Delete server.'
|
description: 'Delete a redirect.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -484,7 +218,27 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
site_id:
|
||||||
|
name: site_id
|
||||||
|
description: 'The ID of the site.'
|
||||||
|
required: true
|
||||||
|
example: 44
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
redirect_id:
|
||||||
|
name: redirect_id
|
||||||
|
description: 'The ID of the redirect.'
|
||||||
|
required: true
|
||||||
|
example: 9
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -492,7 +246,9 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
|
site_id: 44
|
||||||
|
redirect_id: 9
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -501,7 +257,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -509,7 +265,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer ha6v5V41afkdPgcZbDEe386'
|
- 'Bearer Ec3fDgdbae615aPh8k6vV4Z'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -1,19 +1,19 @@
|
|||||||
## Autogenerated by Scribe. DO NOT MODIFY.
|
## Autogenerated by Scribe. DO NOT MODIFY.
|
||||||
|
|
||||||
name: server-providers
|
name: servers
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/server-providers'
|
uri: 'api/projects/{project_id}/servers'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: server-providers
|
groupName: servers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: list
|
title: list
|
||||||
description: ''
|
description: 'Get all servers in a project.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -41,7 +41,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":2,"project_id":null,"global":true,"name":"dolor","provider":"digitalocean","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"},{"id":3,"project_id":null,"global":true,"name":"enim","provider":"digitalocean","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Miss Bonita Vandervort IV","ssh_user":"vito","ip":"120.222.195.212","local_ip":"138.119.37.248","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null},{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Dr. Shanie Batz IV","ssh_user":"vito","ip":"241.88.138.163","local_ip":"138.226.232.93","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -49,7 +49,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 1a6kb58vEP3fZdVhcea64gD'
|
- 'Bearer Pg1Vk6cvadD8eb3ZhaEf564'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -57,14 +57,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- POST
|
- POST
|
||||||
uri: 'api/projects/{project_id}/server-providers'
|
uri: 'api/projects/{project_id}/servers'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: server-providers
|
groupName: servers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: create
|
title: create
|
||||||
description: ''
|
description: 'Create a new server.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -89,9 +89,64 @@ endpoints:
|
|||||||
bodyParameters:
|
bodyParameters:
|
||||||
provider:
|
provider:
|
||||||
name: provider
|
name: provider
|
||||||
description: 'The provider (aws, linode, hetzner, digitalocean, vultr, ...)'
|
description: 'The server provider type'
|
||||||
required: true
|
required: true
|
||||||
example: autem
|
example: fugiat
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_provider:
|
||||||
|
name: server_provider
|
||||||
|
description: 'If the provider is not custom, the ID of the server provider profile'
|
||||||
|
required: true
|
||||||
|
example: digitalocean
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- custom
|
||||||
|
- hetzner
|
||||||
|
- digitalocean
|
||||||
|
- linode
|
||||||
|
- vultr
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
region:
|
||||||
|
name: region
|
||||||
|
description: 'Provider region if the provider is not custom'
|
||||||
|
required: true
|
||||||
|
example: itaque
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
plan:
|
||||||
|
name: plan
|
||||||
|
description: 'Provider plan if the provider is not custom'
|
||||||
|
required: true
|
||||||
|
example: voluptatum
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
ip:
|
||||||
|
name: ip
|
||||||
|
description: 'SSH IP address if the provider is custom'
|
||||||
|
required: true
|
||||||
|
example: ut
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
port:
|
||||||
|
name: port
|
||||||
|
description: 'SSH Port if the provider is custom'
|
||||||
|
required: true
|
||||||
|
example: reiciendis
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -99,55 +154,93 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
name:
|
name:
|
||||||
name: name
|
name: name
|
||||||
description: 'The name of the server provider.'
|
description: 'The name of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: enim
|
example: et
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
token:
|
os:
|
||||||
name: token
|
name: os
|
||||||
description: 'The token if provider requires api token'
|
description: 'The os of the server'
|
||||||
required: true
|
required: true
|
||||||
example: culpa
|
example: vel
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
key:
|
webserver:
|
||||||
name: key
|
name: webserver
|
||||||
description: 'The key if provider requires key'
|
description: 'Web server'
|
||||||
required: true
|
required: true
|
||||||
example: sit
|
example: nginx
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues:
|
||||||
|
- none
|
||||||
|
- nginx
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
secret:
|
database:
|
||||||
name: secret
|
name: database
|
||||||
description: 'The secret if provider requires key'
|
description: Database
|
||||||
required: true
|
required: true
|
||||||
example: voluptates
|
example: mysql80
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues:
|
||||||
|
- none
|
||||||
|
- mysql57
|
||||||
|
- mysql80
|
||||||
|
- mariadb103
|
||||||
|
- mariadb104
|
||||||
|
- mariadb103
|
||||||
|
- postgresql12
|
||||||
|
- postgresql13
|
||||||
|
- postgresql14
|
||||||
|
- postgresql15
|
||||||
|
- postgresql16
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
php:
|
||||||
|
name: php
|
||||||
|
description: 'PHP version'
|
||||||
|
required: true
|
||||||
|
example: '7.2'
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- '7.0'
|
||||||
|
- '7.1'
|
||||||
|
- '7.2'
|
||||||
|
- '7.3'
|
||||||
|
- '7.4'
|
||||||
|
- '8.0'
|
||||||
|
- '8.1'
|
||||||
|
- '8.2'
|
||||||
|
- '8.3'
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
provider: autem
|
provider: fugiat
|
||||||
name: enim
|
server_provider: digitalocean
|
||||||
token: culpa
|
region: itaque
|
||||||
key: sit
|
plan: voluptatum
|
||||||
secret: voluptates
|
ip: ut
|
||||||
|
port: reiciendis
|
||||||
|
name: et
|
||||||
|
os: vel
|
||||||
|
webserver: nginx
|
||||||
|
database: mysql80
|
||||||
|
php: '7.2'
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":2,"project_id":null,"global":true,"name":"eligendi","provider":"aws","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Jeromy Mann","ssh_user":"vito","ip":"128.70.209.89","local_ip":"150.217.250.187","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -155,7 +248,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer PD3ZcaVdvgfa5k4be8E6h16'
|
- 'Bearer 5E61e4vfcgDbVkZd68aah3P'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -163,14 +256,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
uri: 'api/projects/{project_id}/servers/{id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: server-providers
|
groupName: servers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: show
|
title: show
|
||||||
description: ''
|
description: 'Get a server by ID.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -188,11 +281,11 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
serverProvider_id:
|
id:
|
||||||
name: serverProvider_id
|
name: id
|
||||||
description: 'The ID of the serverProvider.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 1
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -200,7 +293,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
serverProvider_id: 1
|
id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -209,7 +302,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":2,"project_id":null,"global":true,"name":"architecto","provider":"digitalocean","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Miss Maya Schaden I","ssh_user":"vito","ip":"44.57.83.39","local_ip":"46.22.92.58","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -217,22 +310,22 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer DP45bg1aEadh8Z6Vke63fcv'
|
- 'Bearer hV3debf65aPD4E1ckag8Z6v'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
custom: []
|
custom: []
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- PUT
|
- POST
|
||||||
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/reboot'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: server-providers
|
groupName: servers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: update
|
title: reboot
|
||||||
description: ''
|
description: 'Reboot a server.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -250,11 +343,11 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
serverProvider_id:
|
server_id:
|
||||||
name: serverProvider_id
|
name: server_id
|
||||||
description: 'The ID of the serverProvider.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 1
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -262,93 +355,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
serverProvider_id: 1
|
server_id: 29
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters:
|
|
||||||
name:
|
|
||||||
name: name
|
|
||||||
description: 'The name of the server provider.'
|
|
||||||
required: true
|
|
||||||
example: minus
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
global:
|
|
||||||
name: global
|
|
||||||
description: 'Accessible in all projects'
|
|
||||||
required: true
|
|
||||||
example: false
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- true
|
|
||||||
- false
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanBodyParameters:
|
|
||||||
name: minus
|
|
||||||
global: false
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 200
|
|
||||||
content: '{"id":2,"project_id":null,"global":true,"name":"reiciendis","provider":"hetzner","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer bv1kdegh6fP8V56ZE4acaD3'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- DELETE
|
|
||||||
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
|
||||||
metadata:
|
|
||||||
groupName: server-providers
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: delete
|
|
||||||
description: ''
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
serverProvider_id:
|
|
||||||
name: serverProvider_id
|
|
||||||
description: 'The ID of the serverProvider.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
serverProvider_id: 1
|
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -357,7 +364,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -365,7 +372,131 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer k6hb43Vf5Z1dv8aaeEDcg6P'
|
- 'Bearer b61aD6538PacZEkeghfvV4d'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/upgrade'
|
||||||
|
metadata:
|
||||||
|
groupName: servers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: upgrade
|
||||||
|
description: 'Upgrade server.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer dEZaa6cePVf3k86g45vbD1h'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- DELETE
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: servers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: delete
|
||||||
|
description: 'Delete server.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer 6aDkZEfdP16V58gb43avhec'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -1,19 +1,19 @@
|
|||||||
## Autogenerated by Scribe. DO NOT MODIFY.
|
## Autogenerated by Scribe. DO NOT MODIFY.
|
||||||
|
|
||||||
name: ssh-keys
|
name: server-providers
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys'
|
uri: 'api/projects/{project_id}/server-providers'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: ssh-keys
|
groupName: server-providers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: list
|
title: list
|
||||||
description: 'Get all ssh keys.'
|
description: ''
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -31,19 +31,8 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -52,7 +41,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"user":null,"name":"Dr. Reanna Braun","created_at":null,"updated_at":null},{"id":null,"user":null,"name":"Norene Fritsch","created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":3,"project_id":null,"global":true,"name":"aut","provider":"hetzner","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"},{"id":4,"project_id":null,"global":true,"name":"qui","provider":"aws","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -60,7 +49,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer dV1gcvfZ46Eh8ebaP5Da63k'
|
- 'Bearer 3evaP8h6VEZkbfgaD6d1c45'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -68,14 +57,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- POST
|
- POST
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys'
|
uri: 'api/projects/{project_id}/server-providers'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: ssh-keys
|
groupName: server-providers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: create
|
title: create
|
||||||
description: 'Deploy ssh key to server.'
|
description: ''
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -93,27 +82,16 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
key_id:
|
provider:
|
||||||
name: key_id
|
name: provider
|
||||||
description: 'The ID of the key.'
|
description: 'The provider (aws, linode, hetzner, digitalocean, vultr, ...)'
|
||||||
required: true
|
required: true
|
||||||
example: vero
|
example: corrupti
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -121,33 +99,55 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
name:
|
name:
|
||||||
name: name
|
name: name
|
||||||
description: 'Key name, required if key_id is not provided.'
|
description: 'The name of the server provider.'
|
||||||
required: true
|
required: true
|
||||||
example: voluptates
|
example: est
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
public_key:
|
token:
|
||||||
name: public_key
|
name: token
|
||||||
description: 'Public Key, required if key_id is not provided.'
|
description: 'The token if provider requires api token'
|
||||||
required: true
|
required: true
|
||||||
example: dolor
|
example: rerum
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
key:
|
||||||
|
name: key
|
||||||
|
description: 'The key if provider requires key'
|
||||||
|
required: true
|
||||||
|
example: ut
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
secret:
|
||||||
|
name: secret
|
||||||
|
description: 'The secret if provider requires key'
|
||||||
|
required: true
|
||||||
|
example: sed
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
key_id: vero
|
provider: corrupti
|
||||||
name: voluptates
|
name: est
|
||||||
public_key: dolor
|
token: rerum
|
||||||
|
key: ut
|
||||||
|
secret: sed
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"user":null,"name":"Sophia D''Amore","created_at":null,"updated_at":null}'
|
content: '{"id":3,"project_id":null,"global":true,"name":"voluptas","provider":"vultr","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -155,22 +155,22 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer gkadV36a5f8E6vhb14ZceDP'
|
- 'Bearer 6g6vfEck83VaPhd5Zabe1D4'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
custom: []
|
custom: []
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- DELETE
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys/{sshKey_id}'
|
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: ssh-keys
|
groupName: server-providers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: delete
|
title: show
|
||||||
description: 'Delete ssh key from server.'
|
description: ''
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -188,21 +188,11 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
server_id:
|
serverProvider_id:
|
||||||
name: server_id
|
name: serverProvider_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the serverProvider.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 1
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
sshKey_id:
|
|
||||||
name: sshKey_id
|
|
||||||
description: 'The ID of the sshKey.'
|
|
||||||
required: true
|
|
||||||
example: 4
|
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -210,8 +200,155 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
serverProvider_id: 1
|
||||||
sshKey_id: 4
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":3,"project_id":null,"global":true,"name":"et","provider":"digitalocean","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer va63cDe8dPf5Z4Vahb1E6kg'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- PUT
|
||||||
|
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: server-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: update
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
serverProvider_id:
|
||||||
|
name: serverProvider_id
|
||||||
|
description: 'The ID of the serverProvider.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
serverProvider_id: 1
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters:
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: 'The name of the server provider.'
|
||||||
|
required: true
|
||||||
|
example: earum
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
global:
|
||||||
|
name: global
|
||||||
|
description: 'Accessible in all projects'
|
||||||
|
required: true
|
||||||
|
example: false
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- true
|
||||||
|
- false
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanBodyParameters:
|
||||||
|
name: earum
|
||||||
|
global: false
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":3,"project_id":null,"global":true,"name":"architecto","provider":"digitalocean","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer 4e1dghaV6D856P3ZbfkcEva'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- DELETE
|
||||||
|
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: server-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: delete
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
serverProvider_id:
|
||||||
|
name: serverProvider_id
|
||||||
|
description: 'The ID of the serverProvider.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
serverProvider_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -220,7 +357,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -228,7 +365,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer PfchD4Zge386abadE5kV61v'
|
- 'Bearer fcVa8ev63gP5DaZbkdhE461'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -1,19 +1,19 @@
|
|||||||
## Autogenerated by Scribe. DO NOT MODIFY.
|
## Autogenerated by Scribe. DO NOT MODIFY.
|
||||||
|
|
||||||
name: services
|
name: ssh-keys
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services'
|
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: services
|
groupName: ssh-keys
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: list
|
title: list
|
||||||
description: 'Get all services.'
|
description: 'Get all ssh keys.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -35,7 +35,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -43,7 +43,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -52,7 +52,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"user":null,"name":"Santa Goyette","created_at":null,"updated_at":null},{"id":null,"user":null,"name":"Cecil Cummings","created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -60,22 +60,22 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer h6bDec51ak84ZVafgv3PE6d'
|
- 'Bearer 165aZvb46PhacEfke83dVgD'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
custom: []
|
custom: []
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- POST
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: services
|
groupName: ssh-keys
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: show
|
title: create
|
||||||
description: 'Get a service by ID.'
|
description: 'Deploy ssh key to server.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -97,17 +97,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
id:
|
|
||||||
name: id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -115,17 +105,49 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
id: 27
|
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters:
|
||||||
cleanBodyParameters: []
|
key_id:
|
||||||
|
name: key_id
|
||||||
|
description: 'The ID of the key.'
|
||||||
|
required: true
|
||||||
|
example: explicabo
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: 'Key name, required if key_id is not provided.'
|
||||||
|
required: true
|
||||||
|
example: deleniti
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
public_key:
|
||||||
|
name: public_key
|
||||||
|
description: 'Public Key, required if key_id is not provided.'
|
||||||
|
required: true
|
||||||
|
example: sapiente
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanBodyParameters:
|
||||||
|
key_id: explicabo
|
||||||
|
name: deleniti
|
||||||
|
public_key: sapiente
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"user":null,"name":"Mr. Reagan Jacobson V","created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -133,372 +155,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer da4V3kfgZ6a86PchevED5b1'
|
- 'Bearer deDkf4E13PZb6cgaV58ha6v'
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/start'
|
|
||||||
metadata:
|
|
||||||
groupName: services
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: start
|
|
||||||
description: 'Start service.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
service_id:
|
|
||||||
name: service_id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
service_id: 27
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer 86fdV5D6gv1E3ekaPZac4hb'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/stop'
|
|
||||||
metadata:
|
|
||||||
groupName: services
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: stop
|
|
||||||
description: 'Stop service.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
service_id:
|
|
||||||
name: service_id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
service_id: 27
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer kPZ563E1Vfgh4cbDad8vae6'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/restart'
|
|
||||||
metadata:
|
|
||||||
groupName: services
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: restart
|
|
||||||
description: 'Restart service.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
service_id:
|
|
||||||
name: service_id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
service_id: 27
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer fd14PaDb58gchv3ZVeaEk66'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/enable'
|
|
||||||
metadata:
|
|
||||||
groupName: services
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: enable
|
|
||||||
description: 'Enable service.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
service_id:
|
|
||||||
name: service_id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
service_id: 27
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer Dv1aVe6hZfkagdE356b4cP8'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/disable'
|
|
||||||
metadata:
|
|
||||||
groupName: services
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: disable
|
|
||||||
description: 'Disable service.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
service_id:
|
|
||||||
name: service_id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
service_id: 27
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer 6bdDc4Eah3ZV18kf6Pveag5'
|
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -506,14 +163,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- DELETE
|
- DELETE
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys/{sshKey_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: services
|
groupName: ssh-keys
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: delete
|
title: delete
|
||||||
description: 'Delete service.'
|
description: 'Delete ssh key from server.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -535,17 +192,17 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
service_id:
|
sshKey_id:
|
||||||
name: service_id
|
name: sshKey_id
|
||||||
description: 'The ID of the service.'
|
description: 'The ID of the sshKey.'
|
||||||
required: true
|
required: true
|
||||||
example: 27
|
example: 1
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -553,8 +210,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
service_id: 27
|
sshKey_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -563,7 +220,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -571,7 +228,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 36kf84v6bVhE5gdPDeZ1caa'
|
- 'Bearer ec48fgVdZ6ah3kvPD16E5ab'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -1,19 +1,19 @@
|
|||||||
## Autogenerated by Scribe. DO NOT MODIFY.
|
## Autogenerated by Scribe. DO NOT MODIFY.
|
||||||
|
|
||||||
name: sites
|
name: services
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/sites'
|
uri: 'api/projects/{project_id}/servers/{server_id}/services'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: sites
|
groupName: services
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: list
|
title: list
|
||||||
description: 'Get all sites.'
|
description: 'Get all services.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -35,7 +35,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -43,7 +43,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -52,7 +52,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"server_id":null,"source_control_id":null,"type":"laravel","type_data":null,"domain":"test.com","aliases":null,"web_directory":"\/","path":"\/home","php_version":"8.2","repository":null,"branch":"main","status":"ready","port":null,"progress":100,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"source_control_id":null,"type":"laravel","type_data":null,"domain":"test.com","aliases":null,"web_directory":"\/","path":"\/home","php_version":"8.2","repository":null,"branch":"main","status":"ready","port":null,"progress":100,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -60,186 +60,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer gaeE86fd1aZP53Vvc6Dhbk4'
|
- 'Bearer gVEce46k8aZfaP3d15vbhD6'
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/sites'
|
|
||||||
metadata:
|
|
||||||
groupName: sites
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: create
|
|
||||||
description: 'Create a new site.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters:
|
|
||||||
type:
|
|
||||||
name: type
|
|
||||||
description: ''
|
|
||||||
required: true
|
|
||||||
example: wordpress
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- php
|
|
||||||
- php-blank
|
|
||||||
- phpmyadmin
|
|
||||||
- laravel
|
|
||||||
- wordpress
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
domain:
|
|
||||||
name: domain
|
|
||||||
description: ''
|
|
||||||
required: true
|
|
||||||
example: quo
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
aliases:
|
|
||||||
name: aliases
|
|
||||||
description: ''
|
|
||||||
required: true
|
|
||||||
example:
|
|
||||||
- dolorum
|
|
||||||
type: 'string[]'
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
php_version:
|
|
||||||
name: php_version
|
|
||||||
description: 'One of the installed PHP Versions'
|
|
||||||
required: true
|
|
||||||
example: '7.4'
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
web_directory:
|
|
||||||
name: web_directory
|
|
||||||
description: 'Required for PHP and Laravel sites'
|
|
||||||
required: true
|
|
||||||
example: public
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
source_control:
|
|
||||||
name: source_control
|
|
||||||
description: 'Source control ID, Required for Sites which support source control'
|
|
||||||
required: true
|
|
||||||
example: explicabo
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
repository:
|
|
||||||
name: repository
|
|
||||||
description: 'Repository, Required for Sites which support source control'
|
|
||||||
required: true
|
|
||||||
example: organization/repository
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
branch:
|
|
||||||
name: branch
|
|
||||||
description: 'Branch, Required for Sites which support source control'
|
|
||||||
required: true
|
|
||||||
example: main
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
composer:
|
|
||||||
name: composer
|
|
||||||
description: 'Run composer if site supports composer'
|
|
||||||
required: true
|
|
||||||
example: true
|
|
||||||
type: boolean
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
version:
|
|
||||||
name: version
|
|
||||||
description: 'Version, if the site type requires a version like PHPMyAdmin'
|
|
||||||
required: true
|
|
||||||
example: 5.2.1
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanBodyParameters:
|
|
||||||
type: wordpress
|
|
||||||
domain: quo
|
|
||||||
aliases:
|
|
||||||
- dolorum
|
|
||||||
php_version: '7.4'
|
|
||||||
web_directory: public
|
|
||||||
source_control: explicabo
|
|
||||||
repository: organization/repository
|
|
||||||
branch: main
|
|
||||||
composer: true
|
|
||||||
version: 5.2.1
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 200
|
|
||||||
content: '{"id":null,"server_id":null,"source_control_id":null,"type":"laravel","type_data":null,"domain":"test.com","aliases":null,"web_directory":"\/","path":"\/home","php_version":"8.2","repository":null,"branch":"main","status":"ready","port":null,"progress":100,"created_at":null,"updated_at":null}'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer efDd36cab6vZEaV4hkP851g'
|
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -247,14 +68,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/sites/{id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: sites
|
groupName: services
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: show
|
title: show
|
||||||
description: 'Get a site by ID.'
|
description: 'Get a service by ID.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -276,7 +97,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -284,9 +105,9 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
id:
|
id:
|
||||||
name: id
|
name: id
|
||||||
description: 'The ID of the site.'
|
description: 'The ID of the service.'
|
||||||
required: true
|
required: true
|
||||||
example: 8
|
example: 169
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -294,8 +115,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
id: 8
|
id: 169
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -304,7 +125,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"source_control_id":null,"type":"laravel","type_data":null,"domain":"test.com","aliases":null,"web_directory":"\/","path":"\/home","php_version":"8.2","repository":null,"branch":"main","status":"ready","port":null,"progress":100,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -312,22 +133,22 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer bVkf841ava5gE6DPch36Zde'
|
- 'Bearer Ef8D5gbV6cadk3Zh1vP46ea'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
custom: []
|
custom: []
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- DELETE
|
- POST
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/sites/{site_id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/start'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: sites
|
groupName: services
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: delete
|
title: start
|
||||||
description: 'Delete site.'
|
description: 'Start service.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -349,17 +170,17 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
site_id:
|
service_id:
|
||||||
name: site_id
|
name: service_id
|
||||||
description: 'The ID of the site.'
|
description: 'The ID of the service.'
|
||||||
required: true
|
required: true
|
||||||
example: 8
|
example: 169
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -367,8 +188,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
site_id: 8
|
service_id: 169
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -377,7 +198,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -385,7 +206,372 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer gfVZbEP5Ddah6k13ae6c8v4'
|
- 'Bearer b3DckZ8g6ha6aPe4f5V1vdE'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/stop'
|
||||||
|
metadata:
|
||||||
|
groupName: services
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: stop
|
||||||
|
description: 'Stop service.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
service_id:
|
||||||
|
name: service_id
|
||||||
|
description: 'The ID of the service.'
|
||||||
|
required: true
|
||||||
|
example: 169
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
service_id: 169
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer 1e8aZbfvE5643DacgkPhdV6'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/restart'
|
||||||
|
metadata:
|
||||||
|
groupName: services
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: restart
|
||||||
|
description: 'Restart service.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
service_id:
|
||||||
|
name: service_id
|
||||||
|
description: 'The ID of the service.'
|
||||||
|
required: true
|
||||||
|
example: 169
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
service_id: 169
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer c46baVZEg5dv1Pfe8Dha6k3'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/enable'
|
||||||
|
metadata:
|
||||||
|
groupName: services
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: enable
|
||||||
|
description: 'Enable service.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
service_id:
|
||||||
|
name: service_id
|
||||||
|
description: 'The ID of the service.'
|
||||||
|
required: true
|
||||||
|
example: 169
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
service_id: 169
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer EvcehkDbdV43f61P86Za5ga'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/disable'
|
||||||
|
metadata:
|
||||||
|
groupName: services
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: disable
|
||||||
|
description: 'Disable service.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
service_id:
|
||||||
|
name: service_id
|
||||||
|
description: 'The ID of the service.'
|
||||||
|
required: true
|
||||||
|
example: 169
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
service_id: 169
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer k8E5gf6d4h31bevaa6cVPZD'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- DELETE
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: services
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: delete
|
||||||
|
description: 'Delete service.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
service_id:
|
||||||
|
name: service_id
|
||||||
|
description: 'The ID of the service.'
|
||||||
|
required: true
|
||||||
|
example: 169
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
service_id: 169
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer Pekav16cd5ag486ZfD3EVbh'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1,14 +1,14 @@
|
|||||||
## Autogenerated by Scribe. DO NOT MODIFY.
|
## Autogenerated by Scribe. DO NOT MODIFY.
|
||||||
|
|
||||||
name: storage-providers
|
name: source-controls
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/storage-providers'
|
uri: 'api/projects/{project_id}/source-controls'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: storage-providers
|
groupName: source-controls
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
@ -41,7 +41,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":3,"project_id":null,"global":true,"name":"et","provider":"local","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"},{"id":4,"project_id":null,"global":true,"name":"sed","provider":"local","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":5,"project_id":null,"global":true,"name":"Zella Robel","provider":"github","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"},{"id":6,"project_id":null,"global":true,"name":"Jairo Williamson","provider":"github","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -49,7 +49,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 1dbV3vkh6EPD5g48cafeZ6a'
|
- 'Bearer e3f4ag8hkb5vZcDadPEV661'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -57,9 +57,9 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- POST
|
- POST
|
||||||
uri: 'api/projects/{project_id}/storage-providers'
|
uri: 'api/projects/{project_id}/source-controls'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: storage-providers
|
groupName: source-controls
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
@ -89,11 +89,14 @@ endpoints:
|
|||||||
bodyParameters:
|
bodyParameters:
|
||||||
provider:
|
provider:
|
||||||
name: provider
|
name: provider
|
||||||
description: 'The provider (aws, linode, hetzner, digitalocean, vultr, ...)'
|
description: 'The provider'
|
||||||
required: true
|
required: true
|
||||||
example: quod
|
example: gitlab
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues:
|
||||||
|
- gitlab
|
||||||
|
- github
|
||||||
|
- bitbucket
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
@ -101,7 +104,7 @@ endpoints:
|
|||||||
name: name
|
name: name
|
||||||
description: 'The name of the storage provider.'
|
description: 'The name of the storage provider.'
|
||||||
required: true
|
required: true
|
||||||
example: commodi
|
example: molestias
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -111,43 +114,54 @@ endpoints:
|
|||||||
name: token
|
name: token
|
||||||
description: 'The token if provider requires api token'
|
description: 'The token if provider requires api token'
|
||||||
required: true
|
required: true
|
||||||
example: ipsum
|
example: in
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
key:
|
url:
|
||||||
name: key
|
name: url
|
||||||
description: 'The key if provider requires key'
|
description: 'The URL if the provider is Gitlab and it is self-hosted'
|
||||||
required: true
|
required: true
|
||||||
example: ratione
|
example: 'https://www.white.com/aperiam-dolor-nemo-qui-rerum-quod-quas'
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
secret:
|
username:
|
||||||
name: secret
|
name: username
|
||||||
description: 'The secret if provider requires key'
|
description: 'The username if the provider is Bitbucket'
|
||||||
required: true
|
required: true
|
||||||
example: iste
|
example: consectetur
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
password:
|
||||||
|
name: password
|
||||||
|
description: 'The password if the provider is Bitbucket'
|
||||||
|
required: true
|
||||||
|
example: 'y*P4_]ZdjE_:'
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
provider: quod
|
provider: gitlab
|
||||||
name: commodi
|
name: molestias
|
||||||
token: ipsum
|
token: in
|
||||||
key: ratione
|
url: 'https://www.white.com/aperiam-dolor-nemo-qui-rerum-quod-quas'
|
||||||
secret: iste
|
username: consectetur
|
||||||
|
password: 'y*P4_]ZdjE_:'
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":3,"project_id":null,"global":true,"name":"est","provider":"dropbox","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":5,"project_id":null,"global":true,"name":"Miss Claudine Goyette","provider":"github","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -155,7 +169,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer abehv36kP4D658VafgdZE1c'
|
- 'Bearer DfegP56vkEa364Zbhda8V1c'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -163,9 +177,9 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
uri: 'api/projects/{project_id}/source-controls/{sourceControl_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: storage-providers
|
groupName: source-controls
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
@ -188,9 +202,9 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
storageProvider_id:
|
sourceControl_id:
|
||||||
name: storageProvider_id
|
name: sourceControl_id
|
||||||
description: 'The ID of the storageProvider.'
|
description: 'The ID of the sourceControl.'
|
||||||
required: true
|
required: true
|
||||||
example: 1
|
example: 1
|
||||||
type: integer
|
type: integer
|
||||||
@ -200,7 +214,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
storageProvider_id: 1
|
sourceControl_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -209,7 +223,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":3,"project_id":null,"global":true,"name":"officia","provider":"ftp","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":5,"project_id":null,"global":true,"name":"Mona Stark","provider":"github","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -217,7 +231,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer bda64P5c1gEDe8V3Z6vhkaf'
|
- 'Bearer ePc6fb65vh1Z4aakE3Dgd8V'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -225,9 +239,9 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- PUT
|
- PUT
|
||||||
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
uri: 'api/projects/{project_id}/source-controls/{sourceControl_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: storage-providers
|
groupName: source-controls
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
@ -250,9 +264,9 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
storageProvider_id:
|
sourceControl_id:
|
||||||
name: storageProvider_id
|
name: sourceControl_id
|
||||||
description: 'The ID of the storageProvider.'
|
description: 'The ID of the sourceControl.'
|
||||||
required: true
|
required: true
|
||||||
example: 1
|
example: 1
|
||||||
type: integer
|
type: integer
|
||||||
@ -262,7 +276,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
storageProvider_id: 1
|
sourceControl_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
@ -270,7 +284,47 @@ endpoints:
|
|||||||
name: name
|
name: name
|
||||||
description: 'The name of the storage provider.'
|
description: 'The name of the storage provider.'
|
||||||
required: true
|
required: true
|
||||||
example: iusto
|
example: non
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
token:
|
||||||
|
name: token
|
||||||
|
description: 'The token if provider requires api token'
|
||||||
|
required: true
|
||||||
|
example: sunt
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
url:
|
||||||
|
name: url
|
||||||
|
description: 'The URL if the provider is Gitlab and it is self-hosted'
|
||||||
|
required: true
|
||||||
|
example: 'https://www.frami.org/ex-at-minus-rerum-quo-minus-ea'
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
username:
|
||||||
|
name: username
|
||||||
|
description: 'The username if the provider is Bitbucket'
|
||||||
|
required: true
|
||||||
|
example: natus
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
password:
|
||||||
|
name: password
|
||||||
|
description: 'The password if the provider is Bitbucket'
|
||||||
|
required: true
|
||||||
|
example: 'A^">*m{p]DI'
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -289,13 +343,17 @@ endpoints:
|
|||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
name: iusto
|
name: non
|
||||||
|
token: sunt
|
||||||
|
url: 'https://www.frami.org/ex-at-minus-rerum-quo-minus-ea'
|
||||||
|
username: natus
|
||||||
|
password: 'A^">*m{p]DI'
|
||||||
global: true
|
global: true
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":3,"project_id":null,"global":true,"name":"rerum","provider":"ftp","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":5,"project_id":null,"global":true,"name":"Neha Little","provider":"github","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -303,7 +361,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer aEP35hVakDdf814eZvg66cb'
|
- 'Bearer v3f6aaPk61Ze8hVdDbE5g4c'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -311,9 +369,9 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- DELETE
|
- DELETE
|
||||||
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
uri: 'api/projects/{project_id}/source-controls/{sourceControl_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: storage-providers
|
groupName: source-controls
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
@ -336,9 +394,9 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
storageProvider_id:
|
sourceControl_id:
|
||||||
name: storageProvider_id
|
name: sourceControl_id
|
||||||
description: 'The ID of the storageProvider.'
|
description: 'The ID of the sourceControl.'
|
||||||
required: true
|
required: true
|
||||||
example: 1
|
example: 1
|
||||||
type: integer
|
type: integer
|
||||||
@ -348,7 +406,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
storageProvider_id: 1
|
sourceControl_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -357,7 +415,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -365,7 +423,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer Dah3PgE5d64fcbe8a16VkvZ'
|
- 'Bearer fgk61vD68E4cZhP3bV5adea'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
372
.scribe/endpoints.cache/13.yaml
Normal file
372
.scribe/endpoints.cache/13.yaml
Normal file
@ -0,0 +1,372 @@
|
|||||||
|
## Autogenerated by Scribe. DO NOT MODIFY.
|
||||||
|
|
||||||
|
name: storage-providers
|
||||||
|
description: ''
|
||||||
|
endpoints:
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- GET
|
||||||
|
uri: 'api/projects/{project_id}/storage-providers'
|
||||||
|
metadata:
|
||||||
|
groupName: storage-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: list
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"data":[{"id":5,"project_id":null,"global":true,"name":"veritatis","provider":"ftp","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"},{"id":6,"project_id":null,"global":true,"name":"voluptas","provider":"dropbox","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer fgh4eV31dP58kvaDEaZbc66'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/storage-providers'
|
||||||
|
metadata:
|
||||||
|
groupName: storage-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: create
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters:
|
||||||
|
provider:
|
||||||
|
name: provider
|
||||||
|
description: 'The provider (aws, linode, hetzner, digitalocean, vultr, ...)'
|
||||||
|
required: true
|
||||||
|
example: ab
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: 'The name of the storage provider.'
|
||||||
|
required: true
|
||||||
|
example: quo
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
token:
|
||||||
|
name: token
|
||||||
|
description: 'The token if provider requires api token'
|
||||||
|
required: true
|
||||||
|
example: in
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
key:
|
||||||
|
name: key
|
||||||
|
description: 'The key if provider requires key'
|
||||||
|
required: true
|
||||||
|
example: sunt
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
secret:
|
||||||
|
name: secret
|
||||||
|
description: 'The secret if provider requires key'
|
||||||
|
required: true
|
||||||
|
example: molestias
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanBodyParameters:
|
||||||
|
provider: ab
|
||||||
|
name: quo
|
||||||
|
token: in
|
||||||
|
key: sunt
|
||||||
|
secret: molestias
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":5,"project_id":null,"global":true,"name":"asperiores","provider":"dropbox","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer e584613dkZaPDEVvgcahbf6'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- GET
|
||||||
|
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: storage-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: show
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
storageProvider_id:
|
||||||
|
name: storageProvider_id
|
||||||
|
description: 'The ID of the storageProvider.'
|
||||||
|
required: true
|
||||||
|
example: 3
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
storageProvider_id: 3
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":5,"project_id":null,"global":true,"name":"ipsum","provider":"local","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer h6Zk6834dDce5fbPa1VvagE'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- PUT
|
||||||
|
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: storage-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: update
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
storageProvider_id:
|
||||||
|
name: storageProvider_id
|
||||||
|
description: 'The ID of the storageProvider.'
|
||||||
|
required: true
|
||||||
|
example: 3
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
storageProvider_id: 3
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters:
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: 'The name of the storage provider.'
|
||||||
|
required: true
|
||||||
|
example: voluptas
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
global:
|
||||||
|
name: global
|
||||||
|
description: 'Accessible in all projects'
|
||||||
|
required: true
|
||||||
|
example: true
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- true
|
||||||
|
- false
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanBodyParameters:
|
||||||
|
name: voluptas
|
||||||
|
global: true
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":5,"project_id":null,"global":true,"name":"minima","provider":"ftp","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer ak6fgd1Eba48chvPV3e5Z6D'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- DELETE
|
||||||
|
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: storage-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: delete
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
storageProvider_id:
|
||||||
|
name: storageProvider_id
|
||||||
|
description: 'The ID of the storageProvider.'
|
||||||
|
required: true
|
||||||
|
example: 3
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
storageProvider_id: 3
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer PcaDbh6ZE4aV1e8fdv56k3g'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
@ -33,7 +33,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -41,7 +41,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -58,7 +58,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 6ed1gv5ak6hEPcaV8D3Z4bf'
|
- 'Bearer eDa6Vdh1Z4vc35bP8E6gafk'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -95,7 +95,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -103,7 +103,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
@ -111,7 +111,7 @@ endpoints:
|
|||||||
name: command
|
name: command
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: qui
|
example: quia
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -140,7 +140,7 @@ endpoints:
|
|||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
command: qui
|
command: quia
|
||||||
user: root
|
user: root
|
||||||
frequency: '* * * * *'
|
frequency: '* * * * *'
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
@ -155,7 +155,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer VEfc5h3gva68PkZ46Deabd1'
|
- 'Bearer 66EeZvdh3kVaDP8f4ga5c1b'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -192,7 +192,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -202,7 +202,7 @@ endpoints:
|
|||||||
name: cronJob_id
|
name: cronJob_id
|
||||||
description: 'The ID of the cronJob.'
|
description: 'The ID of the cronJob.'
|
||||||
required: true
|
required: true
|
||||||
example: 5
|
example: 6
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -210,8 +210,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
cronJob_id: 5
|
cronJob_id: 6
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -228,7 +228,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 614DaP5vZ6edcaVEgfhk83b'
|
- 'Bearer D4c3Z65ebv8E16fahaVgPdk'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -265,7 +265,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -275,7 +275,7 @@ endpoints:
|
|||||||
name: cronJob_id
|
name: cronJob_id
|
||||||
description: 'The ID of the cronJob.'
|
description: 'The ID of the cronJob.'
|
||||||
required: true
|
required: true
|
||||||
example: 5
|
example: 13
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -283,8 +283,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
cronJob_id: 5
|
cronJob_id: 13
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -293,7 +293,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -301,7 +301,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer gDV6bZ1dEckvf45P86eaha3'
|
- 'Bearer h3cP4aZa1v8feDdEg5b6k6V'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -33,7 +33,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -41,7 +41,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -50,7 +50,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"server_id":null,"name":"clockman","status":"ready","created_at":null,"updated_at":null},{"id":null,"server_id":null,"name":"wvonrueden","status":"ready","created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"server_id":null,"name":"leffler.esther","status":"ready","created_at":null,"updated_at":null},{"id":null,"server_id":null,"name":"rhoda.rutherford","status":"ready","created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -58,7 +58,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer efEV4g86bd5PZac6vak3Dh1'
|
- 'Bearer E1VdfegZah4k86b53Dc6Pva'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -95,7 +95,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -103,7 +103,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
@ -111,19 +111,41 @@ endpoints:
|
|||||||
name: name
|
name: name
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: nesciunt
|
example: quisquam
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
charset:
|
||||||
|
name: charset
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: omnis
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
collation:
|
||||||
|
name: collation
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: at
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
name: nesciunt
|
name: quisquam
|
||||||
|
charset: omnis
|
||||||
|
collation: at
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"name":"johanna76","status":"ready","created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"name":"csawayn","status":"ready","created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -131,7 +153,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 3E6VD14dvaekbaZfh6Pg8c5'
|
- 'Bearer PVgkZ35ca4afd1EbD8ehv66'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -168,7 +190,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -178,7 +200,7 @@ endpoints:
|
|||||||
name: id
|
name: id
|
||||||
description: 'The ID of the database.'
|
description: 'The ID of the database.'
|
||||||
required: true
|
required: true
|
||||||
example: 6
|
example: 8
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -186,8 +208,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
id: 6
|
id: 8
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -196,7 +218,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"name":"chloe.huel","status":"ready","created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"name":"sandrine43","status":"ready","created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -204,7 +226,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer fb5hVc38e1aDP6ZvkgEda46'
|
- 'Bearer EP64D8g51adf6hbceavVZ3k'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -241,7 +263,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -251,7 +273,7 @@ endpoints:
|
|||||||
name: database_id
|
name: database_id
|
||||||
description: 'The ID of the database.'
|
description: 'The ID of the database.'
|
||||||
required: true
|
required: true
|
||||||
example: 6
|
example: 8
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -259,8 +281,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
database_id: 6
|
database_id: 8
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -269,7 +291,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -277,7 +299,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer cPVbhaZkfg5aEv46D183ed6'
|
- 'Bearer 8dgEk3Zv1eaVP66bDhf4ac5'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -33,7 +33,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -41,7 +41,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -50,7 +50,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"server_id":null,"username":"nyasia68","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"username":"madyson20","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"server_id":null,"username":"letha64","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"username":"hagenes.lurline","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -58,7 +58,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer egc5VaDdvabfP6843k61hZE'
|
- 'Bearer d4g15bV3Pa6hDvck6eaEf8Z'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -95,7 +95,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -103,7 +103,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
@ -111,7 +111,7 @@ endpoints:
|
|||||||
name: username
|
name: username
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: dignissimos
|
example: qui
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -121,7 +121,7 @@ endpoints:
|
|||||||
name: password
|
name: password
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: OK+XEG2)
|
example: 'xYv*3,#HQ=5<w!'
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -138,14 +138,14 @@ endpoints:
|
|||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
username: dignissimos
|
username: qui
|
||||||
password: OK+XEG2)
|
password: 'xYv*3,#HQ=5<w!'
|
||||||
host: '%'
|
host: '%'
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"username":"amya.nitzsche","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"username":"marcelle95","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -153,7 +153,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 31hgfcvEb6Pkaa48D6dZ5Ve'
|
- 'Bearer 3vZ6f6kagacDEhV1Pde5b84'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -190,7 +190,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -200,7 +200,7 @@ endpoints:
|
|||||||
name: databaseUser_id
|
name: databaseUser_id
|
||||||
description: 'The ID of the databaseUser.'
|
description: 'The ID of the databaseUser.'
|
||||||
required: true
|
required: true
|
||||||
example: 4
|
example: 1
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -208,8 +208,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
databaseUser_id: 4
|
databaseUser_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -218,7 +218,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"username":"bergstrom.ericka","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"username":"brandi53","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -226,7 +226,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer aDv48631h5af6EdkcVbPZeg'
|
- 'Bearer af3b5ac6dP8ZV4vE1hk6eDg'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -263,7 +263,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -281,7 +281,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
databaseUser_id: 4
|
databaseUser_id: 4
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
@ -290,19 +290,19 @@ endpoints:
|
|||||||
name: databases
|
name: databases
|
||||||
description: 'Array of database names to link to the user.'
|
description: 'Array of database names to link to the user.'
|
||||||
required: true
|
required: true
|
||||||
example: accusantium
|
example: maiores
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
databases: accusantium
|
databases: maiores
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"username":"fmurray","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"username":"kschmidt","databases":[],"host":"%","status":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -310,7 +310,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer cf8ZPhV1k3d5DaEva46beg6'
|
- 'Bearer b6f3Ed641gaZDcVa5k8vePh'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -347,7 +347,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -357,7 +357,7 @@ endpoints:
|
|||||||
name: databaseUser_id
|
name: databaseUser_id
|
||||||
description: 'The ID of the databaseUser.'
|
description: 'The ID of the databaseUser.'
|
||||||
required: true
|
required: true
|
||||||
example: 4
|
example: 20
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -365,8 +365,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
databaseUser_id: 4
|
databaseUser_id: 20
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -375,7 +375,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -383,7 +383,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer hdEvkbaPVf4cZ65a8631eDg'
|
- 'Bearer Zka6fh15g6eaV8vE34cDPdb'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -33,7 +33,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -41,7 +41,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -50,7 +50,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"server_id":null,"type":"allow","protocol":"tcp","port":18074,"source":"189.27.156.82","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"type":"allow","protocol":"tcp","port":41088,"source":"86.177.121.87","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"name":"ut","server_id":null,"type":"allow","protocol":"tcp","port":35499,"source":"177.130.54.250","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null},{"id":null,"name":"totam","server_id":null,"type":"allow","protocol":"tcp","port":29448,"source":"181.194.26.13","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -58,7 +58,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer vhkc4aPa6ZdeV8D3Ef156gb'
|
- 'Bearer eD368kaZfVEab4v61ghdP5c'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -95,7 +95,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -103,10 +103,20 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: sapiente
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
type:
|
type:
|
||||||
name: type
|
name: type
|
||||||
description: ''
|
description: ''
|
||||||
@ -123,7 +133,7 @@ endpoints:
|
|||||||
name: protocol
|
name: protocol
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: udp
|
example: tcp
|
||||||
type: string
|
type: string
|
||||||
enumValues:
|
enumValues:
|
||||||
- tcp
|
- tcp
|
||||||
@ -135,7 +145,7 @@ endpoints:
|
|||||||
name: port
|
name: port
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: voluptates
|
example: et
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -144,8 +154,8 @@ endpoints:
|
|||||||
source:
|
source:
|
||||||
name: source
|
name: source
|
||||||
description: ''
|
description: ''
|
||||||
required: true
|
required: false
|
||||||
example: saepe
|
example: doloribus
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -162,16 +172,17 @@ endpoints:
|
|||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
|
name: sapiente
|
||||||
type: allow
|
type: allow
|
||||||
protocol: udp
|
protocol: tcp
|
||||||
port: voluptates
|
port: et
|
||||||
source: saepe
|
source: doloribus
|
||||||
mask: '0'
|
mask: '0'
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"type":"allow","protocol":"tcp","port":61992,"source":"47.222.76.48","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"name":"omnis","server_id":null,"type":"allow","protocol":"tcp","port":54634,"source":"246.242.9.65","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -179,7 +190,150 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 1cEb5P66VeDkf8aahg3Zdv4'
|
- 'Bearer 3184PbED6aacZveV6hf5dgk'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- PUT
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/firewall-rules/{firewallRule_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: firewall-rules
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: edit
|
||||||
|
description: 'Update an existing firewall rule.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
firewallRule_id:
|
||||||
|
name: firewallRule_id
|
||||||
|
description: 'The ID of the firewallRule.'
|
||||||
|
required: true
|
||||||
|
example: 85
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
firewallRule_id: 85
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters:
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: et
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
type:
|
||||||
|
name: type
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: allow
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- allow
|
||||||
|
- deny
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
protocol:
|
||||||
|
name: protocol
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: tcp
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- tcp
|
||||||
|
- udp
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
port:
|
||||||
|
name: port
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: aut
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
source:
|
||||||
|
name: source
|
||||||
|
description: ''
|
||||||
|
required: false
|
||||||
|
example: et
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
mask:
|
||||||
|
name: mask
|
||||||
|
description: 'Mask for source IP.'
|
||||||
|
required: true
|
||||||
|
example: '0'
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanBodyParameters:
|
||||||
|
name: et
|
||||||
|
type: allow
|
||||||
|
protocol: tcp
|
||||||
|
port: aut
|
||||||
|
source: et
|
||||||
|
mask: '0'
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":null,"name":"consequatur","server_id":null,"type":"allow","protocol":"tcp","port":879,"source":"206.106.27.116","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer ad46E3egPDc51aV6hb8vkZf'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -216,7 +370,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -226,7 +380,7 @@ endpoints:
|
|||||||
name: firewallRule_id
|
name: firewallRule_id
|
||||||
description: 'The ID of the firewallRule.'
|
description: 'The ID of the firewallRule.'
|
||||||
required: true
|
required: true
|
||||||
example: 7
|
example: 85
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -234,8 +388,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
firewallRule_id: 7
|
firewallRule_id: 85
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -244,7 +398,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"type":"allow","protocol":"tcp","port":43107,"source":"135.73.216.16","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"name":"dolores","server_id":null,"type":"allow","protocol":"tcp","port":4691,"source":"147.108.28.144","mask":24,"note":"test","status":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -252,7 +406,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 6VaPhkD5vd1Z8e6E3cba4gf'
|
- 'Bearer 6gkvbDae15a6f43EVPdZh8c'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -289,7 +443,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -299,7 +453,7 @@ endpoints:
|
|||||||
name: firewallRule_id
|
name: firewallRule_id
|
||||||
description: 'The ID of the firewallRule.'
|
description: 'The ID of the firewallRule.'
|
||||||
required: true
|
required: true
|
||||||
example: 7
|
example: 85
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -307,8 +461,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
firewallRule_id: 7
|
firewallRule_id: 85
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -317,7 +471,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -325,7 +479,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer v81d5Efch636aVgZebaPkD4'
|
- 'Bearer ZVd1fk5E3e48hDvaa6g6cPb'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -27,7 +27,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"success":true,"version":"2.0.0"}'
|
content: '{"success":true,"version":"2.4.0"}'
|
||||||
headers:
|
headers:
|
||||||
cache-control: 'no-cache, private'
|
cache-control: 'no-cache, private'
|
||||||
content-type: application/json
|
content-type: application/json
|
||||||
|
@ -28,7 +28,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":29,"name":"Zachary Lueilwitz","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"},{"id":30,"name":"Mrs. Kiarra Heller IV","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":3,"name":"Mr. Drake Nader","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"},{"id":4,"name":"Wilhelmine Jacobson","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -36,7 +36,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer eb14DEPv6cdah65VfZgka38'
|
- 'Bearer fbPE6haeDZ8v1gV5ak463dc'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -67,19 +67,19 @@ endpoints:
|
|||||||
name: name
|
name: name
|
||||||
description: 'The name of the project.'
|
description: 'The name of the project.'
|
||||||
required: true
|
required: true
|
||||||
example: quos
|
example: dignissimos
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
name: quos
|
name: dignissimos
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":29,"name":"Hershel Spinka","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":3,"name":"Pattie Cole","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -87,7 +87,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer V1E3566Pf4gkvh8dDZabeca'
|
- 'Bearer 6ZkedcEfa5V6Dv4ab8P3g1h'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -130,7 +130,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":29,"name":"Emery Kiehn","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":3,"name":"Mr. Elias Bauch","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -138,7 +138,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer haD6e36VZbkf4P8aEcvd15g'
|
- 'Bearer P6ka4Zaefgh8Ec3dV15v6bD'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -180,19 +180,19 @@ endpoints:
|
|||||||
name: name
|
name: name
|
||||||
description: 'The name of the project.'
|
description: 'The name of the project.'
|
||||||
required: true
|
required: true
|
||||||
example: ut
|
example: sunt
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
name: ut
|
name: sunt
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":29,"name":"Mable Prohaska","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":3,"name":"Elfrieda Jakubowski","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -200,7 +200,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer V14kPa5deva8Ebgc36f6hDZ'
|
- 'Bearer ecaDZkf5E4vgP1V86d6hb3a'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -243,7 +243,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -251,7 +251,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer k1D68d5ePavVZag6h4fb3cE'
|
- 'Bearer h5gZ63DPVbcevE4faka86d1'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
name: servers
|
name: redirects
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers'
|
uri: 'api/projects/{project_id}/servers/{server_id}/sites/{site_id}/redirects'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: servers
|
groupName: redirects
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: list
|
title: index
|
||||||
description: 'Get all servers in a project.'
|
description: 'Get all redirects.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -29,8 +29,30 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
site_id:
|
||||||
|
name: site_id
|
||||||
|
description: 'The ID of the site.'
|
||||||
|
required: true
|
||||||
|
example: 44
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
site_id: 44
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -39,7 +61,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Dorthy Toy","ssh_user":"vito","ip":"172.132.95.155","local_ip":"118.57.197.65","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null},{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Carrie Sporer","ssh_user":"vito","ip":"184.242.162.173","local_ip":"135.244.50.22","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"site_id":null,"mode":307,"from":"ipsum","to":"http:\/\/fritsch.biz\/","status":"ready","created_at":null,"updated_at":null},{"id":null,"site_id":null,"mode":302,"from":"culpa","to":"http:\/\/www.huels.net\/aut-ut-ut-porro-non-rerum-voluptatum.html","status":"ready","created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -47,7 +69,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 8VE41PdZcvb6kgafD635ahe'
|
- 'Bearer cV16fevgEZhPadD43685akb'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -55,14 +77,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- POST
|
- POST
|
||||||
uri: 'api/projects/{project_id}/servers'
|
uri: 'api/projects/{project_id}/servers/{server_id}/sites/{site_id}/redirects'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: servers
|
groupName: redirects
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: create
|
title: create
|
||||||
description: 'Create a new server.'
|
description: 'Create a new redirect.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -80,178 +102,76 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
site_id:
|
||||||
|
name: site_id
|
||||||
|
description: 'The ID of the site.'
|
||||||
|
required: true
|
||||||
|
example: 44
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
site_id: 44
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
provider:
|
from:
|
||||||
name: provider
|
name: from
|
||||||
description: 'The server provider type'
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: et
|
example: odit
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
server_provider:
|
to:
|
||||||
name: server_provider
|
name: to
|
||||||
description: 'If the provider is not custom, the ID of the server provider profile'
|
description: ''
|
||||||
required: true
|
required: true
|
||||||
example: digitalocean
|
example: incidunt
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
mode:
|
||||||
|
name: mode
|
||||||
|
description: ''
|
||||||
|
required: true
|
||||||
|
example: 301
|
||||||
type: string
|
type: string
|
||||||
enumValues:
|
enumValues:
|
||||||
- custom
|
- 301
|
||||||
- hetzner
|
- 302
|
||||||
- digitalocean
|
- 307
|
||||||
- linode
|
- 308
|
||||||
- vultr
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
region:
|
|
||||||
name: region
|
|
||||||
description: 'Provider region if the provider is not custom'
|
|
||||||
required: true
|
|
||||||
example: inventore
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
plan:
|
|
||||||
name: plan
|
|
||||||
description: 'Provider plan if the provider is not custom'
|
|
||||||
required: true
|
|
||||||
example: atque
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
ip:
|
|
||||||
name: ip
|
|
||||||
description: 'SSH IP address if the provider is custom'
|
|
||||||
required: true
|
|
||||||
example: quam
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
port:
|
|
||||||
name: port
|
|
||||||
description: 'SSH Port if the provider is custom'
|
|
||||||
required: true
|
|
||||||
example: nemo
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
name:
|
|
||||||
name: name
|
|
||||||
description: 'The name of the server.'
|
|
||||||
required: true
|
|
||||||
example: perspiciatis
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
os:
|
|
||||||
name: os
|
|
||||||
description: 'The os of the server'
|
|
||||||
required: true
|
|
||||||
example: similique
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
type:
|
|
||||||
name: type
|
|
||||||
description: 'Server type'
|
|
||||||
required: true
|
|
||||||
example: regular
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- regular
|
|
||||||
- database
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
webserver:
|
|
||||||
name: webserver
|
|
||||||
description: 'Web server'
|
|
||||||
required: true
|
|
||||||
example: none
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- none
|
|
||||||
- nginx
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
database:
|
|
||||||
name: database
|
|
||||||
description: Database
|
|
||||||
required: true
|
|
||||||
example: none
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- none
|
|
||||||
- mysql57
|
|
||||||
- mysql80
|
|
||||||
- mariadb103
|
|
||||||
- mariadb104
|
|
||||||
- mariadb103
|
|
||||||
- postgresql12
|
|
||||||
- postgresql13
|
|
||||||
- postgresql14
|
|
||||||
- postgresql15
|
|
||||||
- postgresql16
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
php:
|
|
||||||
name: php
|
|
||||||
description: 'PHP version'
|
|
||||||
required: true
|
|
||||||
example: '8.1'
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- '7.0'
|
|
||||||
- '7.1'
|
|
||||||
- '7.2'
|
|
||||||
- '7.3'
|
|
||||||
- '7.4'
|
|
||||||
- '8.0'
|
|
||||||
- '8.1'
|
|
||||||
- '8.2'
|
|
||||||
- '8.3'
|
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
provider: et
|
from: odit
|
||||||
server_provider: digitalocean
|
to: incidunt
|
||||||
region: inventore
|
mode: 301
|
||||||
plan: atque
|
|
||||||
ip: quam
|
|
||||||
port: nemo
|
|
||||||
name: perspiciatis
|
|
||||||
os: similique
|
|
||||||
type: regular
|
|
||||||
webserver: none
|
|
||||||
database: none
|
|
||||||
php: '8.1'
|
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Flo Beer PhD","ssh_user":"vito","ip":"168.238.14.230","local_ip":"40.232.73.41","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -259,193 +179,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer Z8g36aaV4E1bdcPfehDv65k'
|
- 'Bearer ZD45hPk638abev61EVcagdf'
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- GET
|
|
||||||
uri: 'api/projects/{project_id}/servers/{id}'
|
|
||||||
metadata:
|
|
||||||
groupName: servers
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: show
|
|
||||||
description: 'Get a server by ID.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
id:
|
|
||||||
name: id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
id: 3
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 200
|
|
||||||
content: '{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Stephany Ankunding","ssh_user":"vito","ip":"145.28.94.46","local_ip":"69.133.44.100","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer adD3EfP5hZ4vgbkV861eca6'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/reboot'
|
|
||||||
metadata:
|
|
||||||
groupName: servers
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: reboot
|
|
||||||
description: 'Reboot a server.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer P3ec6aagD4hbdV5fEk168vZ'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/upgrade'
|
|
||||||
metadata:
|
|
||||||
groupName: servers
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: upgrade
|
|
||||||
description: 'Upgrade server.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer P34ZV6D1bEegdvac8f5kh6a'
|
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -453,14 +187,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- DELETE
|
- DELETE
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/sites/{site_id}/redirects/{redirect_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: servers
|
groupName: redirects
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: delete
|
title: delete
|
||||||
description: 'Delete server.'
|
description: 'Delete a redirect.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -482,7 +216,27 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
site_id:
|
||||||
|
name: site_id
|
||||||
|
description: 'The ID of the site.'
|
||||||
|
required: true
|
||||||
|
example: 44
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
redirect_id:
|
||||||
|
name: redirect_id
|
||||||
|
description: 'The ID of the redirect.'
|
||||||
|
required: true
|
||||||
|
example: 9
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -490,7 +244,9 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
|
site_id: 44
|
||||||
|
redirect_id: 9
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -499,7 +255,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -507,7 +263,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer ha6v5V41afkdPgcZbDEe386'
|
- 'Bearer Ec3fDgdbae615aPh8k6vV4Z'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
name: server-providers
|
name: servers
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/server-providers'
|
uri: 'api/projects/{project_id}/servers'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: server-providers
|
groupName: servers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: list
|
title: list
|
||||||
description: ''
|
description: 'Get all servers in a project.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -39,7 +39,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":2,"project_id":null,"global":true,"name":"dolor","provider":"digitalocean","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"},{"id":3,"project_id":null,"global":true,"name":"enim","provider":"digitalocean","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Miss Bonita Vandervort IV","ssh_user":"vito","ip":"120.222.195.212","local_ip":"138.119.37.248","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null},{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Dr. Shanie Batz IV","ssh_user":"vito","ip":"241.88.138.163","local_ip":"138.226.232.93","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -47,7 +47,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 1a6kb58vEP3fZdVhcea64gD'
|
- 'Bearer Pg1Vk6cvadD8eb3ZhaEf564'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -55,14 +55,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- POST
|
- POST
|
||||||
uri: 'api/projects/{project_id}/server-providers'
|
uri: 'api/projects/{project_id}/servers'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: server-providers
|
groupName: servers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: create
|
title: create
|
||||||
description: ''
|
description: 'Create a new server.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -87,9 +87,64 @@ endpoints:
|
|||||||
bodyParameters:
|
bodyParameters:
|
||||||
provider:
|
provider:
|
||||||
name: provider
|
name: provider
|
||||||
description: 'The provider (aws, linode, hetzner, digitalocean, vultr, ...)'
|
description: 'The server provider type'
|
||||||
required: true
|
required: true
|
||||||
example: autem
|
example: fugiat
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_provider:
|
||||||
|
name: server_provider
|
||||||
|
description: 'If the provider is not custom, the ID of the server provider profile'
|
||||||
|
required: true
|
||||||
|
example: digitalocean
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- custom
|
||||||
|
- hetzner
|
||||||
|
- digitalocean
|
||||||
|
- linode
|
||||||
|
- vultr
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
region:
|
||||||
|
name: region
|
||||||
|
description: 'Provider region if the provider is not custom'
|
||||||
|
required: true
|
||||||
|
example: itaque
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
plan:
|
||||||
|
name: plan
|
||||||
|
description: 'Provider plan if the provider is not custom'
|
||||||
|
required: true
|
||||||
|
example: voluptatum
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
ip:
|
||||||
|
name: ip
|
||||||
|
description: 'SSH IP address if the provider is custom'
|
||||||
|
required: true
|
||||||
|
example: ut
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
port:
|
||||||
|
name: port
|
||||||
|
description: 'SSH Port if the provider is custom'
|
||||||
|
required: true
|
||||||
|
example: reiciendis
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -97,55 +152,93 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
name:
|
name:
|
||||||
name: name
|
name: name
|
||||||
description: 'The name of the server provider.'
|
description: 'The name of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: enim
|
example: et
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
token:
|
os:
|
||||||
name: token
|
name: os
|
||||||
description: 'The token if provider requires api token'
|
description: 'The os of the server'
|
||||||
required: true
|
required: true
|
||||||
example: culpa
|
example: vel
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
key:
|
webserver:
|
||||||
name: key
|
name: webserver
|
||||||
description: 'The key if provider requires key'
|
description: 'Web server'
|
||||||
required: true
|
required: true
|
||||||
example: sit
|
example: nginx
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues:
|
||||||
|
- none
|
||||||
|
- nginx
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
secret:
|
database:
|
||||||
name: secret
|
name: database
|
||||||
description: 'The secret if provider requires key'
|
description: Database
|
||||||
required: true
|
required: true
|
||||||
example: voluptates
|
example: mysql80
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues:
|
||||||
|
- none
|
||||||
|
- mysql57
|
||||||
|
- mysql80
|
||||||
|
- mariadb103
|
||||||
|
- mariadb104
|
||||||
|
- mariadb103
|
||||||
|
- postgresql12
|
||||||
|
- postgresql13
|
||||||
|
- postgresql14
|
||||||
|
- postgresql15
|
||||||
|
- postgresql16
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
php:
|
||||||
|
name: php
|
||||||
|
description: 'PHP version'
|
||||||
|
required: true
|
||||||
|
example: '7.2'
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- '7.0'
|
||||||
|
- '7.1'
|
||||||
|
- '7.2'
|
||||||
|
- '7.3'
|
||||||
|
- '7.4'
|
||||||
|
- '8.0'
|
||||||
|
- '8.1'
|
||||||
|
- '8.2'
|
||||||
|
- '8.3'
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
provider: autem
|
provider: fugiat
|
||||||
name: enim
|
server_provider: digitalocean
|
||||||
token: culpa
|
region: itaque
|
||||||
key: sit
|
plan: voluptatum
|
||||||
secret: voluptates
|
ip: ut
|
||||||
|
port: reiciendis
|
||||||
|
name: et
|
||||||
|
os: vel
|
||||||
|
webserver: nginx
|
||||||
|
database: mysql80
|
||||||
|
php: '7.2'
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":2,"project_id":null,"global":true,"name":"eligendi","provider":"aws","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Jeromy Mann","ssh_user":"vito","ip":"128.70.209.89","local_ip":"150.217.250.187","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -153,7 +246,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer PD3ZcaVdvgfa5k4be8E6h16'
|
- 'Bearer 5E61e4vfcgDbVkZd68aah3P'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -161,14 +254,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
uri: 'api/projects/{project_id}/servers/{id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: server-providers
|
groupName: servers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: show
|
title: show
|
||||||
description: ''
|
description: 'Get a server by ID.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -186,11 +279,11 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
serverProvider_id:
|
id:
|
||||||
name: serverProvider_id
|
name: id
|
||||||
description: 'The ID of the serverProvider.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 1
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -198,7 +291,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
serverProvider_id: 1
|
id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -207,7 +300,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":2,"project_id":null,"global":true,"name":"architecto","provider":"digitalocean","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":null,"project_id":null,"user_id":null,"provider_id":null,"name":"Miss Maya Schaden I","ssh_user":"vito","ip":"44.57.83.39","local_ip":"46.22.92.58","port":22,"os":"ubuntu_22","type":"regular","type_data":null,"provider":"custom","provider_data":null,"public_key":"test","status":"ready","auto_update":null,"available_updates":0,"security_updates":null,"progress":100,"progress_step":null,"updates":null,"last_update_check":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -215,22 +308,22 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer DP45bg1aEadh8Z6Vke63fcv'
|
- 'Bearer hV3debf65aPD4E1ckag8Z6v'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
custom: []
|
custom: []
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- PUT
|
- POST
|
||||||
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/reboot'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: server-providers
|
groupName: servers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: update
|
title: reboot
|
||||||
description: ''
|
description: 'Reboot a server.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -248,11 +341,11 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
serverProvider_id:
|
server_id:
|
||||||
name: serverProvider_id
|
name: server_id
|
||||||
description: 'The ID of the serverProvider.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 1
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -260,93 +353,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
serverProvider_id: 1
|
server_id: 29
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters:
|
|
||||||
name:
|
|
||||||
name: name
|
|
||||||
description: 'The name of the server provider.'
|
|
||||||
required: true
|
|
||||||
example: minus
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
global:
|
|
||||||
name: global
|
|
||||||
description: 'Accessible in all projects'
|
|
||||||
required: true
|
|
||||||
example: false
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- true
|
|
||||||
- false
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanBodyParameters:
|
|
||||||
name: minus
|
|
||||||
global: false
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 200
|
|
||||||
content: '{"id":2,"project_id":null,"global":true,"name":"reiciendis","provider":"hetzner","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer bv1kdegh6fP8V56ZE4acaD3'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- DELETE
|
|
||||||
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
|
||||||
metadata:
|
|
||||||
groupName: server-providers
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: delete
|
|
||||||
description: ''
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
serverProvider_id:
|
|
||||||
name: serverProvider_id
|
|
||||||
description: 'The ID of the serverProvider.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
serverProvider_id: 1
|
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -355,7 +362,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -363,7 +370,131 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer k6hb43Vf5Z1dv8aaeEDcg6P'
|
- 'Bearer b61aD6538PacZEkeghfvV4d'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/upgrade'
|
||||||
|
metadata:
|
||||||
|
groupName: servers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: upgrade
|
||||||
|
description: 'Upgrade server.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer dEZaa6cePVf3k86g45vbD1h'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- DELETE
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: servers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: delete
|
||||||
|
description: 'Delete server.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer 6aDkZEfdP16V58gb43avhec'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
name: ssh-keys
|
name: server-providers
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys'
|
uri: 'api/projects/{project_id}/server-providers'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: ssh-keys
|
groupName: server-providers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: list
|
title: list
|
||||||
description: 'Get all ssh keys.'
|
description: ''
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -29,19 +29,8 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -50,7 +39,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"user":null,"name":"Dr. Reanna Braun","created_at":null,"updated_at":null},{"id":null,"user":null,"name":"Norene Fritsch","created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":3,"project_id":null,"global":true,"name":"aut","provider":"hetzner","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"},{"id":4,"project_id":null,"global":true,"name":"qui","provider":"aws","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -58,7 +47,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer dV1gcvfZ46Eh8ebaP5Da63k'
|
- 'Bearer 3evaP8h6VEZkbfgaD6d1c45'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -66,14 +55,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- POST
|
- POST
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys'
|
uri: 'api/projects/{project_id}/server-providers'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: ssh-keys
|
groupName: server-providers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: create
|
title: create
|
||||||
description: 'Deploy ssh key to server.'
|
description: ''
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -91,27 +80,16 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
key_id:
|
provider:
|
||||||
name: key_id
|
name: provider
|
||||||
description: 'The ID of the key.'
|
description: 'The provider (aws, linode, hetzner, digitalocean, vultr, ...)'
|
||||||
required: true
|
required: true
|
||||||
example: vero
|
example: corrupti
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -119,33 +97,55 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
name:
|
name:
|
||||||
name: name
|
name: name
|
||||||
description: 'Key name, required if key_id is not provided.'
|
description: 'The name of the server provider.'
|
||||||
required: true
|
required: true
|
||||||
example: voluptates
|
example: est
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
public_key:
|
token:
|
||||||
name: public_key
|
name: token
|
||||||
description: 'Public Key, required if key_id is not provided.'
|
description: 'The token if provider requires api token'
|
||||||
required: true
|
required: true
|
||||||
example: dolor
|
example: rerum
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
key:
|
||||||
|
name: key
|
||||||
|
description: 'The key if provider requires key'
|
||||||
|
required: true
|
||||||
|
example: ut
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
secret:
|
||||||
|
name: secret
|
||||||
|
description: 'The secret if provider requires key'
|
||||||
|
required: true
|
||||||
|
example: sed
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
key_id: vero
|
provider: corrupti
|
||||||
name: voluptates
|
name: est
|
||||||
public_key: dolor
|
token: rerum
|
||||||
|
key: ut
|
||||||
|
secret: sed
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"user":null,"name":"Sophia D''Amore","created_at":null,"updated_at":null}'
|
content: '{"id":3,"project_id":null,"global":true,"name":"voluptas","provider":"vultr","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -153,22 +153,22 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer gkadV36a5f8E6vhb14ZceDP'
|
- 'Bearer 6g6vfEck83VaPhd5Zabe1D4'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
custom: []
|
custom: []
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- DELETE
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys/{sshKey_id}'
|
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: ssh-keys
|
groupName: server-providers
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: delete
|
title: show
|
||||||
description: 'Delete ssh key from server.'
|
description: ''
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -186,21 +186,11 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
server_id:
|
serverProvider_id:
|
||||||
name: server_id
|
name: serverProvider_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the serverProvider.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 1
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
sshKey_id:
|
|
||||||
name: sshKey_id
|
|
||||||
description: 'The ID of the sshKey.'
|
|
||||||
required: true
|
|
||||||
example: 4
|
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -208,8 +198,155 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
serverProvider_id: 1
|
||||||
sshKey_id: 4
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":3,"project_id":null,"global":true,"name":"et","provider":"digitalocean","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer va63cDe8dPf5Z4Vahb1E6kg'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- PUT
|
||||||
|
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: server-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: update
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
serverProvider_id:
|
||||||
|
name: serverProvider_id
|
||||||
|
description: 'The ID of the serverProvider.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
serverProvider_id: 1
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters:
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: 'The name of the server provider.'
|
||||||
|
required: true
|
||||||
|
example: earum
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
global:
|
||||||
|
name: global
|
||||||
|
description: 'Accessible in all projects'
|
||||||
|
required: true
|
||||||
|
example: false
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- true
|
||||||
|
- false
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanBodyParameters:
|
||||||
|
name: earum
|
||||||
|
global: false
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":3,"project_id":null,"global":true,"name":"architecto","provider":"digitalocean","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer 4e1dghaV6D856P3ZbfkcEva'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- DELETE
|
||||||
|
uri: 'api/projects/{project_id}/server-providers/{serverProvider_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: server-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: delete
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
serverProvider_id:
|
||||||
|
name: serverProvider_id
|
||||||
|
description: 'The ID of the serverProvider.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
serverProvider_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -218,7 +355,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -226,7 +363,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer PfchD4Zge386abadE5kV61v'
|
- 'Bearer fcVa8ev63gP5DaZbkdhE461'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
name: services
|
name: ssh-keys
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services'
|
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: services
|
groupName: ssh-keys
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: list
|
title: list
|
||||||
description: 'Get all services.'
|
description: 'Get all ssh keys.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -33,7 +33,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -41,7 +41,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -50,7 +50,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"user":null,"name":"Santa Goyette","created_at":null,"updated_at":null},{"id":null,"user":null,"name":"Cecil Cummings","created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -58,22 +58,22 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer h6bDec51ak84ZVafgv3PE6d'
|
- 'Bearer 165aZvb46PhacEfke83dVgD'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
custom: []
|
custom: []
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- POST
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: services
|
groupName: ssh-keys
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: show
|
title: create
|
||||||
description: 'Get a service by ID.'
|
description: 'Deploy ssh key to server.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -95,17 +95,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
id:
|
|
||||||
name: id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -113,17 +103,49 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
id: 27
|
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters:
|
||||||
cleanBodyParameters: []
|
key_id:
|
||||||
|
name: key_id
|
||||||
|
description: 'The ID of the key.'
|
||||||
|
required: true
|
||||||
|
example: explicabo
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: 'Key name, required if key_id is not provided.'
|
||||||
|
required: true
|
||||||
|
example: deleniti
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
public_key:
|
||||||
|
name: public_key
|
||||||
|
description: 'Public Key, required if key_id is not provided.'
|
||||||
|
required: true
|
||||||
|
example: sapiente
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanBodyParameters:
|
||||||
|
key_id: explicabo
|
||||||
|
name: deleniti
|
||||||
|
public_key: sapiente
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"user":null,"name":"Mr. Reagan Jacobson V","created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -131,372 +153,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer da4V3kfgZ6a86PchevED5b1'
|
- 'Bearer deDkf4E13PZb6cgaV58ha6v'
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/start'
|
|
||||||
metadata:
|
|
||||||
groupName: services
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: start
|
|
||||||
description: 'Start service.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
service_id:
|
|
||||||
name: service_id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
service_id: 27
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer 86fdV5D6gv1E3ekaPZac4hb'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/stop'
|
|
||||||
metadata:
|
|
||||||
groupName: services
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: stop
|
|
||||||
description: 'Stop service.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
service_id:
|
|
||||||
name: service_id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
service_id: 27
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer kPZ563E1Vfgh4cbDad8vae6'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/restart'
|
|
||||||
metadata:
|
|
||||||
groupName: services
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: restart
|
|
||||||
description: 'Restart service.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
service_id:
|
|
||||||
name: service_id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
service_id: 27
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer fd14PaDb58gchv3ZVeaEk66'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/enable'
|
|
||||||
metadata:
|
|
||||||
groupName: services
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: enable
|
|
||||||
description: 'Enable service.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
service_id:
|
|
||||||
name: service_id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
service_id: 27
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer Dv1aVe6hZfkagdE356b4cP8'
|
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/disable'
|
|
||||||
metadata:
|
|
||||||
groupName: services
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: disable
|
|
||||||
description: 'Disable service.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
service_id:
|
|
||||||
name: service_id
|
|
||||||
description: 'The ID of the service.'
|
|
||||||
required: true
|
|
||||||
example: 27
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
service_id: 27
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters: []
|
|
||||||
cleanBodyParameters: []
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 204
|
|
||||||
content: 'null'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer 6bdDc4Eah3ZV18kf6Pveag5'
|
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -504,14 +161,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- DELETE
|
- DELETE
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/ssh-keys/{sshKey_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: services
|
groupName: ssh-keys
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: delete
|
title: delete
|
||||||
description: 'Delete service.'
|
description: 'Delete ssh key from server.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -533,17 +190,17 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
service_id:
|
sshKey_id:
|
||||||
name: service_id
|
name: sshKey_id
|
||||||
description: 'The ID of the service.'
|
description: 'The ID of the sshKey.'
|
||||||
required: true
|
required: true
|
||||||
example: 27
|
example: 1
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -551,8 +208,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
service_id: 27
|
sshKey_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -561,7 +218,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -569,7 +226,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 36kf84v6bVhE5gdPDeZ1caa'
|
- 'Bearer ec48fgVdZ6ah3kvPD16E5ab'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
name: sites
|
name: services
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/sites'
|
uri: 'api/projects/{project_id}/servers/{server_id}/services'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: sites
|
groupName: services
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: list
|
title: list
|
||||||
description: 'Get all sites.'
|
description: 'Get all services.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -33,7 +33,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -41,7 +41,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -50,7 +50,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":null,"server_id":null,"source_control_id":null,"type":"laravel","type_data":null,"domain":"test.com","aliases":null,"web_directory":"\/","path":"\/home","php_version":"8.2","repository":null,"branch":"main","status":"ready","port":null,"progress":100,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"source_control_id":null,"type":"laravel","type_data":null,"domain":"test.com","aliases":null,"web_directory":"\/","path":"\/home","php_version":"8.2","repository":null,"branch":"main","status":"ready","port":null,"progress":100,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null},{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -58,186 +58,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer gaeE86fd1aZP53Vvc6Dhbk4'
|
- 'Bearer gVEce46k8aZfaP3d15vbhD6'
|
||||||
controller: null
|
|
||||||
method: null
|
|
||||||
route: null
|
|
||||||
custom: []
|
|
||||||
-
|
|
||||||
httpMethods:
|
|
||||||
- POST
|
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/sites'
|
|
||||||
metadata:
|
|
||||||
groupName: sites
|
|
||||||
groupDescription: ''
|
|
||||||
subgroup: ''
|
|
||||||
subgroupDescription: ''
|
|
||||||
title: create
|
|
||||||
description: 'Create a new site.'
|
|
||||||
authenticated: true
|
|
||||||
custom: []
|
|
||||||
headers:
|
|
||||||
Authorization: 'Bearer YOUR-API-KEY'
|
|
||||||
Content-Type: application/json
|
|
||||||
Accept: application/json
|
|
||||||
urlParameters:
|
|
||||||
project_id:
|
|
||||||
name: project_id
|
|
||||||
description: 'The ID of the project.'
|
|
||||||
required: true
|
|
||||||
example: 1
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
server_id:
|
|
||||||
name: server_id
|
|
||||||
description: 'The ID of the server.'
|
|
||||||
required: true
|
|
||||||
example: 3
|
|
||||||
type: integer
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanUrlParameters:
|
|
||||||
project_id: 1
|
|
||||||
server_id: 3
|
|
||||||
queryParameters: []
|
|
||||||
cleanQueryParameters: []
|
|
||||||
bodyParameters:
|
|
||||||
type:
|
|
||||||
name: type
|
|
||||||
description: ''
|
|
||||||
required: true
|
|
||||||
example: wordpress
|
|
||||||
type: string
|
|
||||||
enumValues:
|
|
||||||
- php
|
|
||||||
- php-blank
|
|
||||||
- phpmyadmin
|
|
||||||
- laravel
|
|
||||||
- wordpress
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
domain:
|
|
||||||
name: domain
|
|
||||||
description: ''
|
|
||||||
required: true
|
|
||||||
example: quo
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
aliases:
|
|
||||||
name: aliases
|
|
||||||
description: ''
|
|
||||||
required: true
|
|
||||||
example:
|
|
||||||
- dolorum
|
|
||||||
type: 'string[]'
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
php_version:
|
|
||||||
name: php_version
|
|
||||||
description: 'One of the installed PHP Versions'
|
|
||||||
required: true
|
|
||||||
example: '7.4'
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
web_directory:
|
|
||||||
name: web_directory
|
|
||||||
description: 'Required for PHP and Laravel sites'
|
|
||||||
required: true
|
|
||||||
example: public
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
source_control:
|
|
||||||
name: source_control
|
|
||||||
description: 'Source control ID, Required for Sites which support source control'
|
|
||||||
required: true
|
|
||||||
example: explicabo
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
repository:
|
|
||||||
name: repository
|
|
||||||
description: 'Repository, Required for Sites which support source control'
|
|
||||||
required: true
|
|
||||||
example: organization/repository
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
branch:
|
|
||||||
name: branch
|
|
||||||
description: 'Branch, Required for Sites which support source control'
|
|
||||||
required: true
|
|
||||||
example: main
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
composer:
|
|
||||||
name: composer
|
|
||||||
description: 'Run composer if site supports composer'
|
|
||||||
required: true
|
|
||||||
example: true
|
|
||||||
type: boolean
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
version:
|
|
||||||
name: version
|
|
||||||
description: 'Version, if the site type requires a version like PHPMyAdmin'
|
|
||||||
required: true
|
|
||||||
example: 5.2.1
|
|
||||||
type: string
|
|
||||||
enumValues: []
|
|
||||||
exampleWasSpecified: false
|
|
||||||
nullable: false
|
|
||||||
custom: []
|
|
||||||
cleanBodyParameters:
|
|
||||||
type: wordpress
|
|
||||||
domain: quo
|
|
||||||
aliases:
|
|
||||||
- dolorum
|
|
||||||
php_version: '7.4'
|
|
||||||
web_directory: public
|
|
||||||
source_control: explicabo
|
|
||||||
repository: organization/repository
|
|
||||||
branch: main
|
|
||||||
composer: true
|
|
||||||
version: 5.2.1
|
|
||||||
fileParameters: []
|
|
||||||
responses:
|
|
||||||
-
|
|
||||||
status: 200
|
|
||||||
content: '{"id":null,"server_id":null,"source_control_id":null,"type":"laravel","type_data":null,"domain":"test.com","aliases":null,"web_directory":"\/","path":"\/home","php_version":"8.2","repository":null,"branch":"main","status":"ready","port":null,"progress":100,"created_at":null,"updated_at":null}'
|
|
||||||
headers: []
|
|
||||||
description: ''
|
|
||||||
custom: []
|
|
||||||
responseFields: []
|
|
||||||
auth:
|
|
||||||
- headers
|
|
||||||
- Authorization
|
|
||||||
- 'Bearer efDd36cab6vZEaV4hkP851g'
|
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -245,14 +66,14 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/sites/{id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: sites
|
groupName: services
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: show
|
title: show
|
||||||
description: 'Get a site by ID.'
|
description: 'Get a service by ID.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -274,7 +95,7 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -282,9 +103,9 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
id:
|
id:
|
||||||
name: id
|
name: id
|
||||||
description: 'The ID of the site.'
|
description: 'The ID of the service.'
|
||||||
required: true
|
required: true
|
||||||
example: 8
|
example: 169
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -292,8 +113,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
id: 8
|
id: 169
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -302,7 +123,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":null,"server_id":null,"source_control_id":null,"type":"laravel","type_data":null,"domain":"test.com","aliases":null,"web_directory":"\/","path":"\/home","php_version":"8.2","repository":null,"branch":"main","status":"ready","port":null,"progress":100,"created_at":null,"updated_at":null}'
|
content: '{"id":null,"server_id":null,"type":null,"type_data":null,"name":null,"version":null,"unit":null,"status":null,"is_default":null,"created_at":null,"updated_at":null}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -310,22 +131,22 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer bVkf841ava5gE6DPch36Zde'
|
- 'Bearer Ef8D5gbV6cadk3Zh1vP46ea'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
custom: []
|
custom: []
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- DELETE
|
- POST
|
||||||
uri: 'api/projects/{project_id}/servers/{server_id}/sites/{site_id}'
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/start'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: sites
|
groupName: services
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
title: delete
|
title: start
|
||||||
description: 'Delete site.'
|
description: 'Start service.'
|
||||||
authenticated: true
|
authenticated: true
|
||||||
custom: []
|
custom: []
|
||||||
headers:
|
headers:
|
||||||
@ -347,17 +168,17 @@ endpoints:
|
|||||||
name: server_id
|
name: server_id
|
||||||
description: 'The ID of the server.'
|
description: 'The ID of the server.'
|
||||||
required: true
|
required: true
|
||||||
example: 3
|
example: 29
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
site_id:
|
service_id:
|
||||||
name: site_id
|
name: service_id
|
||||||
description: 'The ID of the site.'
|
description: 'The ID of the service.'
|
||||||
required: true
|
required: true
|
||||||
example: 8
|
example: 169
|
||||||
type: integer
|
type: integer
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -365,8 +186,8 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
server_id: 3
|
server_id: 29
|
||||||
site_id: 8
|
service_id: 169
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -375,7 +196,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -383,7 +204,372 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer gfVZbEP5Ddah6k13ae6c8v4'
|
- 'Bearer b3DckZ8g6ha6aPe4f5V1vdE'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/stop'
|
||||||
|
metadata:
|
||||||
|
groupName: services
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: stop
|
||||||
|
description: 'Stop service.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
service_id:
|
||||||
|
name: service_id
|
||||||
|
description: 'The ID of the service.'
|
||||||
|
required: true
|
||||||
|
example: 169
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
service_id: 169
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer 1e8aZbfvE5643DacgkPhdV6'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/restart'
|
||||||
|
metadata:
|
||||||
|
groupName: services
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: restart
|
||||||
|
description: 'Restart service.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
service_id:
|
||||||
|
name: service_id
|
||||||
|
description: 'The ID of the service.'
|
||||||
|
required: true
|
||||||
|
example: 169
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
service_id: 169
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer c46baVZEg5dv1Pfe8Dha6k3'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/enable'
|
||||||
|
metadata:
|
||||||
|
groupName: services
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: enable
|
||||||
|
description: 'Enable service.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
service_id:
|
||||||
|
name: service_id
|
||||||
|
description: 'The ID of the service.'
|
||||||
|
required: true
|
||||||
|
example: 169
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
service_id: 169
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer EvcehkDbdV43f61P86Za5ga'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}/disable'
|
||||||
|
metadata:
|
||||||
|
groupName: services
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: disable
|
||||||
|
description: 'Disable service.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
service_id:
|
||||||
|
name: service_id
|
||||||
|
description: 'The ID of the service.'
|
||||||
|
required: true
|
||||||
|
example: 169
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
service_id: 169
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer k8E5gf6d4h31bevaa6cVPZD'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- DELETE
|
||||||
|
uri: 'api/projects/{project_id}/servers/{server_id}/services/{service_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: services
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: delete
|
||||||
|
description: 'Delete service.'
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
server_id:
|
||||||
|
name: server_id
|
||||||
|
description: 'The ID of the server.'
|
||||||
|
required: true
|
||||||
|
example: 29
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
service_id:
|
||||||
|
name: service_id
|
||||||
|
description: 'The ID of the service.'
|
||||||
|
required: true
|
||||||
|
example: 169
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
server_id: 29
|
||||||
|
service_id: 169
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer Pekav16cd5ag486ZfD3EVbh'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1,12 +1,12 @@
|
|||||||
name: storage-providers
|
name: source-controls
|
||||||
description: ''
|
description: ''
|
||||||
endpoints:
|
endpoints:
|
||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/storage-providers'
|
uri: 'api/projects/{project_id}/source-controls'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: storage-providers
|
groupName: source-controls
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
@ -39,7 +39,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"data":[{"id":3,"project_id":null,"global":true,"name":"et","provider":"local","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"},{"id":4,"project_id":null,"global":true,"name":"sed","provider":"local","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
content: '{"data":[{"id":5,"project_id":null,"global":true,"name":"Zella Robel","provider":"github","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"},{"id":6,"project_id":null,"global":true,"name":"Jairo Williamson","provider":"github","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -47,7 +47,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer 1dbV3vkh6EPD5g48cafeZ6a'
|
- 'Bearer e3f4ag8hkb5vZcDadPEV661'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -55,9 +55,9 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- POST
|
- POST
|
||||||
uri: 'api/projects/{project_id}/storage-providers'
|
uri: 'api/projects/{project_id}/source-controls'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: storage-providers
|
groupName: source-controls
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
@ -87,11 +87,14 @@ endpoints:
|
|||||||
bodyParameters:
|
bodyParameters:
|
||||||
provider:
|
provider:
|
||||||
name: provider
|
name: provider
|
||||||
description: 'The provider (aws, linode, hetzner, digitalocean, vultr, ...)'
|
description: 'The provider'
|
||||||
required: true
|
required: true
|
||||||
example: quod
|
example: gitlab
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues:
|
||||||
|
- gitlab
|
||||||
|
- github
|
||||||
|
- bitbucket
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
@ -99,7 +102,7 @@ endpoints:
|
|||||||
name: name
|
name: name
|
||||||
description: 'The name of the storage provider.'
|
description: 'The name of the storage provider.'
|
||||||
required: true
|
required: true
|
||||||
example: commodi
|
example: molestias
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -109,43 +112,54 @@ endpoints:
|
|||||||
name: token
|
name: token
|
||||||
description: 'The token if provider requires api token'
|
description: 'The token if provider requires api token'
|
||||||
required: true
|
required: true
|
||||||
example: ipsum
|
example: in
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
key:
|
url:
|
||||||
name: key
|
name: url
|
||||||
description: 'The key if provider requires key'
|
description: 'The URL if the provider is Gitlab and it is self-hosted'
|
||||||
required: true
|
required: true
|
||||||
example: ratione
|
example: 'https://www.white.com/aperiam-dolor-nemo-qui-rerum-quod-quas'
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
secret:
|
username:
|
||||||
name: secret
|
name: username
|
||||||
description: 'The secret if provider requires key'
|
description: 'The username if the provider is Bitbucket'
|
||||||
required: true
|
required: true
|
||||||
example: iste
|
example: consectetur
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
password:
|
||||||
|
name: password
|
||||||
|
description: 'The password if the provider is Bitbucket'
|
||||||
|
required: true
|
||||||
|
example: 'y*P4_]ZdjE_:'
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
provider: quod
|
provider: gitlab
|
||||||
name: commodi
|
name: molestias
|
||||||
token: ipsum
|
token: in
|
||||||
key: ratione
|
url: 'https://www.white.com/aperiam-dolor-nemo-qui-rerum-quod-quas'
|
||||||
secret: iste
|
username: consectetur
|
||||||
|
password: 'y*P4_]ZdjE_:'
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":3,"project_id":null,"global":true,"name":"est","provider":"dropbox","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":5,"project_id":null,"global":true,"name":"Miss Claudine Goyette","provider":"github","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -153,7 +167,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer abehv36kP4D658VafgdZE1c'
|
- 'Bearer DfegP56vkEa364Zbhda8V1c'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -161,9 +175,9 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- GET
|
- GET
|
||||||
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
uri: 'api/projects/{project_id}/source-controls/{sourceControl_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: storage-providers
|
groupName: source-controls
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
@ -186,9 +200,9 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
storageProvider_id:
|
sourceControl_id:
|
||||||
name: storageProvider_id
|
name: sourceControl_id
|
||||||
description: 'The ID of the storageProvider.'
|
description: 'The ID of the sourceControl.'
|
||||||
required: true
|
required: true
|
||||||
example: 1
|
example: 1
|
||||||
type: integer
|
type: integer
|
||||||
@ -198,7 +212,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
storageProvider_id: 1
|
sourceControl_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -207,7 +221,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":3,"project_id":null,"global":true,"name":"officia","provider":"ftp","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":5,"project_id":null,"global":true,"name":"Mona Stark","provider":"github","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -215,7 +229,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer bda64P5c1gEDe8V3Z6vhkaf'
|
- 'Bearer ePc6fb65vh1Z4aakE3Dgd8V'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -223,9 +237,9 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- PUT
|
- PUT
|
||||||
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
uri: 'api/projects/{project_id}/source-controls/{sourceControl_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: storage-providers
|
groupName: source-controls
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
@ -248,9 +262,9 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
storageProvider_id:
|
sourceControl_id:
|
||||||
name: storageProvider_id
|
name: sourceControl_id
|
||||||
description: 'The ID of the storageProvider.'
|
description: 'The ID of the sourceControl.'
|
||||||
required: true
|
required: true
|
||||||
example: 1
|
example: 1
|
||||||
type: integer
|
type: integer
|
||||||
@ -260,7 +274,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
storageProvider_id: 1
|
sourceControl_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters:
|
bodyParameters:
|
||||||
@ -268,7 +282,47 @@ endpoints:
|
|||||||
name: name
|
name: name
|
||||||
description: 'The name of the storage provider.'
|
description: 'The name of the storage provider.'
|
||||||
required: true
|
required: true
|
||||||
example: iusto
|
example: non
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
token:
|
||||||
|
name: token
|
||||||
|
description: 'The token if provider requires api token'
|
||||||
|
required: true
|
||||||
|
example: sunt
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
url:
|
||||||
|
name: url
|
||||||
|
description: 'The URL if the provider is Gitlab and it is self-hosted'
|
||||||
|
required: true
|
||||||
|
example: 'https://www.frami.org/ex-at-minus-rerum-quo-minus-ea'
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
username:
|
||||||
|
name: username
|
||||||
|
description: 'The username if the provider is Bitbucket'
|
||||||
|
required: true
|
||||||
|
example: natus
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
password:
|
||||||
|
name: password
|
||||||
|
description: 'The password if the provider is Bitbucket'
|
||||||
|
required: true
|
||||||
|
example: 'A^">*m{p]DI'
|
||||||
type: string
|
type: string
|
||||||
enumValues: []
|
enumValues: []
|
||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
@ -287,13 +341,17 @@ endpoints:
|
|||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
cleanBodyParameters:
|
cleanBodyParameters:
|
||||||
name: iusto
|
name: non
|
||||||
|
token: sunt
|
||||||
|
url: 'https://www.frami.org/ex-at-minus-rerum-quo-minus-ea'
|
||||||
|
username: natus
|
||||||
|
password: 'A^">*m{p]DI'
|
||||||
global: true
|
global: true
|
||||||
fileParameters: []
|
fileParameters: []
|
||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 200
|
status: 200
|
||||||
content: '{"id":3,"project_id":null,"global":true,"name":"rerum","provider":"ftp","created_at":"2024-11-01T15:40:48.000000Z","updated_at":"2024-11-01T15:40:48.000000Z"}'
|
content: '{"id":5,"project_id":null,"global":true,"name":"Neha Little","provider":"github","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -301,7 +359,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer aEP35hVakDdf814eZvg66cb'
|
- 'Bearer v3f6aaPk61Ze8hVdDbE5g4c'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
@ -309,9 +367,9 @@ endpoints:
|
|||||||
-
|
-
|
||||||
httpMethods:
|
httpMethods:
|
||||||
- DELETE
|
- DELETE
|
||||||
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
uri: 'api/projects/{project_id}/source-controls/{sourceControl_id}'
|
||||||
metadata:
|
metadata:
|
||||||
groupName: storage-providers
|
groupName: source-controls
|
||||||
groupDescription: ''
|
groupDescription: ''
|
||||||
subgroup: ''
|
subgroup: ''
|
||||||
subgroupDescription: ''
|
subgroupDescription: ''
|
||||||
@ -334,9 +392,9 @@ endpoints:
|
|||||||
exampleWasSpecified: false
|
exampleWasSpecified: false
|
||||||
nullable: false
|
nullable: false
|
||||||
custom: []
|
custom: []
|
||||||
storageProvider_id:
|
sourceControl_id:
|
||||||
name: storageProvider_id
|
name: sourceControl_id
|
||||||
description: 'The ID of the storageProvider.'
|
description: 'The ID of the sourceControl.'
|
||||||
required: true
|
required: true
|
||||||
example: 1
|
example: 1
|
||||||
type: integer
|
type: integer
|
||||||
@ -346,7 +404,7 @@ endpoints:
|
|||||||
custom: []
|
custom: []
|
||||||
cleanUrlParameters:
|
cleanUrlParameters:
|
||||||
project_id: 1
|
project_id: 1
|
||||||
storageProvider_id: 1
|
sourceControl_id: 1
|
||||||
queryParameters: []
|
queryParameters: []
|
||||||
cleanQueryParameters: []
|
cleanQueryParameters: []
|
||||||
bodyParameters: []
|
bodyParameters: []
|
||||||
@ -355,7 +413,7 @@ endpoints:
|
|||||||
responses:
|
responses:
|
||||||
-
|
-
|
||||||
status: 204
|
status: 204
|
||||||
content: 'null'
|
content: null
|
||||||
headers: []
|
headers: []
|
||||||
description: ''
|
description: ''
|
||||||
custom: []
|
custom: []
|
||||||
@ -363,7 +421,7 @@ endpoints:
|
|||||||
auth:
|
auth:
|
||||||
- headers
|
- headers
|
||||||
- Authorization
|
- Authorization
|
||||||
- 'Bearer Dah3PgE5d64fcbe8a16VkvZ'
|
- 'Bearer fgk61vD68E4cZhP3bV5adea'
|
||||||
controller: null
|
controller: null
|
||||||
method: null
|
method: null
|
||||||
route: null
|
route: null
|
||||||
|
370
.scribe/endpoints/13.yaml
Normal file
370
.scribe/endpoints/13.yaml
Normal file
@ -0,0 +1,370 @@
|
|||||||
|
name: storage-providers
|
||||||
|
description: ''
|
||||||
|
endpoints:
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- GET
|
||||||
|
uri: 'api/projects/{project_id}/storage-providers'
|
||||||
|
metadata:
|
||||||
|
groupName: storage-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: list
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"data":[{"id":5,"project_id":null,"global":true,"name":"veritatis","provider":"ftp","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"},{"id":6,"project_id":null,"global":true,"name":"voluptas","provider":"dropbox","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}],"links":{"first":"\/?page=1","last":"\/?page=1","prev":null,"next":null},"meta":{"current_page":1,"from":1,"last_page":1,"links":[{"url":null,"label":"« Previous","active":false},{"url":"\/?page=1","label":"1","active":true},{"url":null,"label":"Next »","active":false}],"path":"\/","per_page":25,"to":2,"total":2}}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer fgh4eV31dP58kvaDEaZbc66'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- POST
|
||||||
|
uri: 'api/projects/{project_id}/storage-providers'
|
||||||
|
metadata:
|
||||||
|
groupName: storage-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: create
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters:
|
||||||
|
provider:
|
||||||
|
name: provider
|
||||||
|
description: 'The provider (aws, linode, hetzner, digitalocean, vultr, ...)'
|
||||||
|
required: true
|
||||||
|
example: ab
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: 'The name of the storage provider.'
|
||||||
|
required: true
|
||||||
|
example: quo
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
token:
|
||||||
|
name: token
|
||||||
|
description: 'The token if provider requires api token'
|
||||||
|
required: true
|
||||||
|
example: in
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
key:
|
||||||
|
name: key
|
||||||
|
description: 'The key if provider requires key'
|
||||||
|
required: true
|
||||||
|
example: sunt
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
secret:
|
||||||
|
name: secret
|
||||||
|
description: 'The secret if provider requires key'
|
||||||
|
required: true
|
||||||
|
example: molestias
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanBodyParameters:
|
||||||
|
provider: ab
|
||||||
|
name: quo
|
||||||
|
token: in
|
||||||
|
key: sunt
|
||||||
|
secret: molestias
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":5,"project_id":null,"global":true,"name":"asperiores","provider":"dropbox","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer e584613dkZaPDEVvgcahbf6'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- GET
|
||||||
|
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: storage-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: show
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
storageProvider_id:
|
||||||
|
name: storageProvider_id
|
||||||
|
description: 'The ID of the storageProvider.'
|
||||||
|
required: true
|
||||||
|
example: 3
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
storageProvider_id: 3
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":5,"project_id":null,"global":true,"name":"ipsum","provider":"local","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer h6Zk6834dDce5fbPa1VvagE'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- PUT
|
||||||
|
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: storage-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: update
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
storageProvider_id:
|
||||||
|
name: storageProvider_id
|
||||||
|
description: 'The ID of the storageProvider.'
|
||||||
|
required: true
|
||||||
|
example: 3
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
storageProvider_id: 3
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters:
|
||||||
|
name:
|
||||||
|
name: name
|
||||||
|
description: 'The name of the storage provider.'
|
||||||
|
required: true
|
||||||
|
example: voluptas
|
||||||
|
type: string
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
global:
|
||||||
|
name: global
|
||||||
|
description: 'Accessible in all projects'
|
||||||
|
required: true
|
||||||
|
example: true
|
||||||
|
type: string
|
||||||
|
enumValues:
|
||||||
|
- true
|
||||||
|
- false
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanBodyParameters:
|
||||||
|
name: voluptas
|
||||||
|
global: true
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 200
|
||||||
|
content: '{"id":5,"project_id":null,"global":true,"name":"minima","provider":"ftp","created_at":"2025-04-05T17:48:03.000000Z","updated_at":"2025-04-05T17:48:03.000000Z"}'
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer ak6fgd1Eba48chvPV3e5Z6D'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
||||||
|
-
|
||||||
|
httpMethods:
|
||||||
|
- DELETE
|
||||||
|
uri: 'api/projects/{project_id}/storage-providers/{storageProvider_id}'
|
||||||
|
metadata:
|
||||||
|
groupName: storage-providers
|
||||||
|
groupDescription: ''
|
||||||
|
subgroup: ''
|
||||||
|
subgroupDescription: ''
|
||||||
|
title: delete
|
||||||
|
description: ''
|
||||||
|
authenticated: true
|
||||||
|
custom: []
|
||||||
|
headers:
|
||||||
|
Authorization: 'Bearer YOUR-API-KEY'
|
||||||
|
Content-Type: application/json
|
||||||
|
Accept: application/json
|
||||||
|
urlParameters:
|
||||||
|
project_id:
|
||||||
|
name: project_id
|
||||||
|
description: 'The ID of the project.'
|
||||||
|
required: true
|
||||||
|
example: 1
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
storageProvider_id:
|
||||||
|
name: storageProvider_id
|
||||||
|
description: 'The ID of the storageProvider.'
|
||||||
|
required: true
|
||||||
|
example: 3
|
||||||
|
type: integer
|
||||||
|
enumValues: []
|
||||||
|
exampleWasSpecified: false
|
||||||
|
nullable: false
|
||||||
|
custom: []
|
||||||
|
cleanUrlParameters:
|
||||||
|
project_id: 1
|
||||||
|
storageProvider_id: 3
|
||||||
|
queryParameters: []
|
||||||
|
cleanQueryParameters: []
|
||||||
|
bodyParameters: []
|
||||||
|
cleanBodyParameters: []
|
||||||
|
fileParameters: []
|
||||||
|
responses:
|
||||||
|
-
|
||||||
|
status: 204
|
||||||
|
content: null
|
||||||
|
headers: []
|
||||||
|
description: ''
|
||||||
|
custom: []
|
||||||
|
responseFields: []
|
||||||
|
auth:
|
||||||
|
- headers
|
||||||
|
- Authorization
|
||||||
|
- 'Bearer PcaDbh6ZE4aV1e8fdv56k3g'
|
||||||
|
controller: null
|
||||||
|
method: null
|
||||||
|
route: null
|
||||||
|
custom: []
|
@ -6,9 +6,13 @@
|
|||||||
use App\Models\CronJob;
|
use App\Models\CronJob;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
use App\ValidationRules\CronRule;
|
use App\ValidationRules\CronRule;
|
||||||
|
use Illuminate\Validation\Rule;
|
||||||
|
|
||||||
class CreateCronJob
|
class CreateCronJob
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function create(Server $server, array $input): CronJob
|
public function create(Server $server, array $input): CronJob
|
||||||
{
|
{
|
||||||
$cronJob = new CronJob([
|
$cronJob = new CronJob([
|
||||||
@ -27,7 +31,11 @@ public function create(Server $server, array $input): CronJob
|
|||||||
return $cronJob;
|
return $cronJob;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function rules(array $input): array
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, array<mixed>>
|
||||||
|
*/
|
||||||
|
public static function rules(array $input, Server $server): array
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
'command' => [
|
'command' => [
|
||||||
@ -35,7 +43,7 @@ public static function rules(array $input): array
|
|||||||
],
|
],
|
||||||
'user' => [
|
'user' => [
|
||||||
'required',
|
'required',
|
||||||
'in:root,'.config('core.ssh_user'),
|
Rule::in($server->getSshUsers()),
|
||||||
],
|
],
|
||||||
'frequency' => [
|
'frequency' => [
|
||||||
'required',
|
'required',
|
||||||
|
@ -5,20 +5,30 @@
|
|||||||
use App\Enums\DatabaseStatus;
|
use App\Enums\DatabaseStatus;
|
||||||
use App\Models\Database;
|
use App\Models\Database;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
use Illuminate\Validation\Rule;
|
use Illuminate\Validation\Rule;
|
||||||
use Illuminate\Validation\ValidationException;
|
use Illuminate\Validation\ValidationException;
|
||||||
|
|
||||||
class CreateDatabase
|
class CreateDatabase
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function create(Server $server, array $input): Database
|
public function create(Server $server, array $input): Database
|
||||||
{
|
{
|
||||||
$database = new Database([
|
$database = new Database([
|
||||||
'server_id' => $server->id,
|
'server_id' => $server->id,
|
||||||
|
'charset' => $input['charset'],
|
||||||
|
'collation' => $input['collation'],
|
||||||
'name' => $input['name'],
|
'name' => $input['name'],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $server->database();
|
||||||
|
|
||||||
/** @var \App\SSH\Services\Database\Database $databaseHandler */
|
/** @var \App\SSH\Services\Database\Database $databaseHandler */
|
||||||
$databaseHandler = $server->database()->handler();
|
$databaseHandler = $service->handler();
|
||||||
$databaseHandler->create($database->name);
|
$databaseHandler->create($database->name, $database->charset, $database->collation);
|
||||||
$database->status = DatabaseStatus::READY;
|
$database->status = DatabaseStatus::READY;
|
||||||
$database->save();
|
$database->save();
|
||||||
|
|
||||||
@ -32,6 +42,9 @@ public function create(Server $server, array $input): Database
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, mixed>
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
public static function rules(Server $server, array $input): array
|
public static function rules(Server $server, array $input): array
|
||||||
@ -40,7 +53,15 @@ public static function rules(Server $server, array $input): array
|
|||||||
'name' => [
|
'name' => [
|
||||||
'required',
|
'required',
|
||||||
'alpha_dash',
|
'alpha_dash',
|
||||||
Rule::unique('databases', 'name')->where('server_id', $server->id),
|
Rule::unique('databases', 'name')->where('server_id', $server->id)->whereNull('deleted_at'),
|
||||||
|
],
|
||||||
|
'charset' => [
|
||||||
|
'required',
|
||||||
|
'string',
|
||||||
|
],
|
||||||
|
'collation' => [
|
||||||
|
'required',
|
||||||
|
'string',
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
if (isset($input['user']) && $input['user']) {
|
if (isset($input['user']) && $input['user']) {
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
use App\Enums\DatabaseUserStatus;
|
use App\Enums\DatabaseUserStatus;
|
||||||
use App\Models\DatabaseUser;
|
use App\Models\DatabaseUser;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
use App\SSH\Services\Database\Database;
|
use App\SSH\Services\Database\Database;
|
||||||
use Illuminate\Validation\Rule;
|
use Illuminate\Validation\Rule;
|
||||||
use Illuminate\Validation\ValidationException;
|
use Illuminate\Validation\ValidationException;
|
||||||
@ -12,6 +13,9 @@
|
|||||||
class CreateDatabaseUser
|
class CreateDatabaseUser
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @param array<string> $links
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
public function create(Server $server, array $input, array $links = []): DatabaseUser
|
public function create(Server $server, array $input, array $links = []): DatabaseUser
|
||||||
@ -23,8 +27,12 @@ public function create(Server $server, array $input, array $links = []): Databas
|
|||||||
'host' => (isset($input['remote']) && $input['remote']) || isset($input['host']) ? $input['host'] : 'localhost',
|
'host' => (isset($input['remote']) && $input['remote']) || isset($input['host']) ? $input['host'] : 'localhost',
|
||||||
'databases' => $links,
|
'databases' => $links,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $server->database();
|
||||||
|
|
||||||
/** @var Database $databaseHandler */
|
/** @var Database $databaseHandler */
|
||||||
$databaseHandler = $server->database()->handler();
|
$databaseHandler = $service->handler();
|
||||||
$databaseHandler->createUser(
|
$databaseHandler->createUser(
|
||||||
$databaseUser->username,
|
$databaseUser->username,
|
||||||
$databaseUser->password,
|
$databaseUser->password,
|
||||||
@ -41,6 +49,9 @@ public function create(Server $server, array $input, array $links = []): Databas
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, mixed>
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
public static function rules(Server $server, array $input): array
|
public static function rules(Server $server, array $input): array
|
||||||
|
@ -2,14 +2,24 @@
|
|||||||
|
|
||||||
namespace App\Actions\Database;
|
namespace App\Actions\Database;
|
||||||
|
|
||||||
|
use App\Models\Backup;
|
||||||
use App\Models\Database;
|
use App\Models\Database;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
|
|
||||||
class DeleteDatabase
|
class DeleteDatabase
|
||||||
{
|
{
|
||||||
public function delete(Server $server, Database $database): void
|
public function delete(Server $server, Database $database): void
|
||||||
{
|
{
|
||||||
$server->database()->handler()->delete($database->name);
|
/** @var Service $service */
|
||||||
|
$service = $server->database();
|
||||||
|
/** @var \App\SSH\Services\Database\Database $handler */
|
||||||
|
$handler = $service->handler();
|
||||||
|
$handler->delete($database->name);
|
||||||
$database->delete();
|
$database->delete();
|
||||||
|
|
||||||
|
$database->backups()->each(function (Backup $backup): void {
|
||||||
|
app(ManageBackup::class)->stop($backup);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,12 +4,18 @@
|
|||||||
|
|
||||||
use App\Models\DatabaseUser;
|
use App\Models\DatabaseUser;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
|
use App\SSH\Services\Database\Database;
|
||||||
|
|
||||||
class DeleteDatabaseUser
|
class DeleteDatabaseUser
|
||||||
{
|
{
|
||||||
public function delete(Server $server, DatabaseUser $databaseUser): void
|
public function delete(Server $server, DatabaseUser $databaseUser): void
|
||||||
{
|
{
|
||||||
$server->database()->handler()->deleteUser($databaseUser->username, $databaseUser->host);
|
/** @var Service $service */
|
||||||
|
$service = $server->database();
|
||||||
|
/** @var Database $handler */
|
||||||
|
$handler = $service->handler();
|
||||||
|
$handler->deleteUser($databaseUser->username, $databaseUser->host);
|
||||||
$databaseUser->delete();
|
$databaseUser->delete();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,12 +5,16 @@
|
|||||||
use App\Models\Database;
|
use App\Models\Database;
|
||||||
use App\Models\DatabaseUser;
|
use App\Models\DatabaseUser;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
use Illuminate\Validation\Rule;
|
use Illuminate\Validation\Rule;
|
||||||
use Illuminate\Validation\ValidationException;
|
use Illuminate\Validation\ValidationException;
|
||||||
|
|
||||||
class LinkUser
|
class LinkUser
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return DatabaseUser $databaseUser
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
public function link(DatabaseUser $databaseUser, array $input): DatabaseUser
|
public function link(DatabaseUser $databaseUser, array $input): DatabaseUser
|
||||||
@ -29,14 +33,20 @@ public function link(DatabaseUser $databaseUser, array $input): DatabaseUser
|
|||||||
|
|
||||||
$databaseUser->databases = $input['databases'];
|
$databaseUser->databases = $input['databases'];
|
||||||
|
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $databaseUser->server->database();
|
||||||
|
|
||||||
|
/** @var \App\SSH\Services\Database\Database $handler */
|
||||||
|
$handler = $service->handler();
|
||||||
|
|
||||||
// Unlink the user from all databases
|
// Unlink the user from all databases
|
||||||
$databaseUser->server->database()->handler()->unlink(
|
$handler->unlink(
|
||||||
$databaseUser->username,
|
$databaseUser->username,
|
||||||
$databaseUser->host
|
$databaseUser->host
|
||||||
);
|
);
|
||||||
|
|
||||||
// Link the user to the selected databases
|
// Link the user to the selected databases
|
||||||
$databaseUser->server->database()->handler()->link(
|
$handler->link(
|
||||||
$databaseUser->username,
|
$databaseUser->username,
|
||||||
$databaseUser->host,
|
$databaseUser->host,
|
||||||
$databaseUser->databases
|
$databaseUser->databases
|
||||||
@ -49,6 +59,10 @@ public function link(DatabaseUser $databaseUser, array $input): DatabaseUser
|
|||||||
return $databaseUser;
|
return $databaseUser;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, mixed>
|
||||||
|
*/
|
||||||
public static function rules(Server $server, array $input): array
|
public static function rules(Server $server, array $input): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
namespace App\Actions\Database;
|
namespace App\Actions\Database;
|
||||||
|
|
||||||
|
use App\Enums\BackupFileStatus;
|
||||||
use App\Enums\BackupStatus;
|
use App\Enums\BackupStatus;
|
||||||
use App\Enums\DatabaseStatus;
|
use App\Enums\DatabaseStatus;
|
||||||
use App\Models\Backup;
|
use App\Models\Backup;
|
||||||
@ -10,9 +11,11 @@
|
|||||||
use Illuminate\Validation\Rule;
|
use Illuminate\Validation\Rule;
|
||||||
use Illuminate\Validation\ValidationException;
|
use Illuminate\Validation\ValidationException;
|
||||||
|
|
||||||
class CreateBackup
|
class ManageBackup
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
* @throws AuthorizationException
|
* @throws AuthorizationException
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
@ -34,6 +37,38 @@ public function create(Server $server, array $input): Backup
|
|||||||
return $backup;
|
return $backup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
|
public function update(Backup $backup, array $input): void
|
||||||
|
{
|
||||||
|
$backup->interval = $input['interval'] == 'custom' ? $input['custom_interval'] : $input['interval'];
|
||||||
|
$backup->keep_backups = $input['keep'];
|
||||||
|
$backup->save();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function delete(Backup $backup): void
|
||||||
|
{
|
||||||
|
$backup->status = BackupStatus::DELETING;
|
||||||
|
$backup->save();
|
||||||
|
|
||||||
|
dispatch(function () use ($backup): void {
|
||||||
|
$files = $backup->files;
|
||||||
|
foreach ($files as $file) {
|
||||||
|
$file->status = BackupFileStatus::DELETING;
|
||||||
|
$file->save();
|
||||||
|
|
||||||
|
$file->deleteFile();
|
||||||
|
}
|
||||||
|
|
||||||
|
$backup->delete();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, mixed>
|
||||||
|
*/
|
||||||
public static function rules(Server $server, array $input): array
|
public static function rules(Server $server, array $input): array
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
@ -65,4 +100,10 @@ public static function rules(Server $server, array $input): array
|
|||||||
|
|
||||||
return $rules;
|
return $rules;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function stop(Backup $backup): void
|
||||||
|
{
|
||||||
|
$backup->status = BackupStatus::STOPPED;
|
||||||
|
$backup->save();
|
||||||
|
}
|
||||||
}
|
}
|
35
app/Actions/Database/ManageBackupFile.php
Normal file
35
app/Actions/Database/ManageBackupFile.php
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\Database;
|
||||||
|
|
||||||
|
use App\Enums\BackupFileStatus;
|
||||||
|
use App\Models\BackupFile;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||||
|
use Throwable;
|
||||||
|
|
||||||
|
class ManageBackupFile
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @throws Throwable
|
||||||
|
*/
|
||||||
|
public function download(BackupFile $file): StreamedResponse
|
||||||
|
{
|
||||||
|
$file->backup->server->ssh()->download(
|
||||||
|
Storage::disk('tmp')->path(basename($file->path())),
|
||||||
|
$file->path()
|
||||||
|
);
|
||||||
|
|
||||||
|
return Storage::disk('tmp')->download(basename($file->path()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function delete(BackupFile $file): void
|
||||||
|
{
|
||||||
|
$file->status = BackupFileStatus::DELETING;
|
||||||
|
$file->save();
|
||||||
|
|
||||||
|
dispatch(function () use ($file): void {
|
||||||
|
$file->deleteFile();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
@ -5,9 +5,13 @@
|
|||||||
use App\Enums\BackupFileStatus;
|
use App\Enums\BackupFileStatus;
|
||||||
use App\Models\BackupFile;
|
use App\Models\BackupFile;
|
||||||
use App\Models\Database;
|
use App\Models\Database;
|
||||||
|
use App\Models\Service;
|
||||||
|
|
||||||
class RestoreBackup
|
class RestoreBackup
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function restore(BackupFile $backupFile, array $input): void
|
public function restore(BackupFile $backupFile, array $input): void
|
||||||
{
|
{
|
||||||
/** @var Database $database */
|
/** @var Database $database */
|
||||||
@ -16,19 +20,24 @@ public function restore(BackupFile $backupFile, array $input): void
|
|||||||
$backupFile->restored_to = $database->name;
|
$backupFile->restored_to = $database->name;
|
||||||
$backupFile->save();
|
$backupFile->save();
|
||||||
|
|
||||||
dispatch(function () use ($backupFile, $database) {
|
dispatch(function () use ($backupFile, $database): void {
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $database->server->database();
|
||||||
/** @var \App\SSH\Services\Database\Database $databaseHandler */
|
/** @var \App\SSH\Services\Database\Database $databaseHandler */
|
||||||
$databaseHandler = $database->server->database()->handler();
|
$databaseHandler = $service->handler();
|
||||||
$databaseHandler->restoreBackup($backupFile, $database->name);
|
$databaseHandler->restoreBackup($backupFile, $database->name);
|
||||||
$backupFile->status = BackupFileStatus::RESTORED;
|
$backupFile->status = BackupFileStatus::RESTORED;
|
||||||
$backupFile->restored_at = now();
|
$backupFile->restored_at = now();
|
||||||
$backupFile->save();
|
$backupFile->save();
|
||||||
})->catch(function () use ($backupFile) {
|
})->catch(function () use ($backupFile): void {
|
||||||
$backupFile->status = BackupFileStatus::RESTORE_FAILED;
|
$backupFile->status = BackupFileStatus::RESTORE_FAILED;
|
||||||
$backupFile->save();
|
$backupFile->save();
|
||||||
})->onConnection('ssh');
|
})->onConnection('ssh');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(): array
|
public static function rules(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
use App\Enums\BackupStatus;
|
use App\Enums\BackupStatus;
|
||||||
use App\Models\Backup;
|
use App\Models\Backup;
|
||||||
use App\Models\BackupFile;
|
use App\Models\BackupFile;
|
||||||
|
use App\Models\Service;
|
||||||
use App\SSH\Services\Database\Database;
|
use App\SSH\Services\Database\Database;
|
||||||
use Illuminate\Support\Str;
|
use Illuminate\Support\Str;
|
||||||
|
|
||||||
@ -20,9 +21,11 @@ public function run(Backup $backup): BackupFile
|
|||||||
]);
|
]);
|
||||||
$file->save();
|
$file->save();
|
||||||
|
|
||||||
dispatch(function () use ($file, $backup) {
|
dispatch(function () use ($file, $backup): void {
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $backup->server->database();
|
||||||
/** @var Database $databaseHandler */
|
/** @var Database $databaseHandler */
|
||||||
$databaseHandler = $file->backup->server->database()->handler();
|
$databaseHandler = $service->handler();
|
||||||
$databaseHandler->runBackup($file);
|
$databaseHandler->runBackup($file);
|
||||||
$file->status = BackupFileStatus::CREATED;
|
$file->status = BackupFileStatus::CREATED;
|
||||||
$file->save();
|
$file->save();
|
||||||
@ -31,7 +34,7 @@ public function run(Backup $backup): BackupFile
|
|||||||
$backup->status = BackupStatus::RUNNING;
|
$backup->status = BackupStatus::RUNNING;
|
||||||
$backup->save();
|
$backup->save();
|
||||||
}
|
}
|
||||||
})->catch(function () use ($file, $backup) {
|
})->catch(function () use ($file, $backup): void {
|
||||||
$backup->status = BackupStatus::FAILED;
|
$backup->status = BackupStatus::FAILED;
|
||||||
$backup->save();
|
$backup->save();
|
||||||
$file->status = BackupFileStatus::FAILED;
|
$file->status = BackupFileStatus::FAILED;
|
||||||
|
50
app/Actions/Database/SyncDatabaseUsers.php
Normal file
50
app/Actions/Database/SyncDatabaseUsers.php
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\Database;
|
||||||
|
|
||||||
|
use App\Enums\DatabaseUserStatus;
|
||||||
|
use App\Models\DatabaseUser;
|
||||||
|
use App\Models\Server;
|
||||||
|
use App\SSH\Services\Database\Database;
|
||||||
|
|
||||||
|
class SyncDatabaseUsers
|
||||||
|
{
|
||||||
|
public function sync(Server $server): void
|
||||||
|
{
|
||||||
|
$service = $server->database();
|
||||||
|
if (! $service instanceof \App\Models\Service) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
/** @var Database $handler */
|
||||||
|
$handler = $service->handler();
|
||||||
|
|
||||||
|
$this->updateUsers($server, $handler);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function updateUsers(Server $server, Database $handler): void
|
||||||
|
{
|
||||||
|
$users = $handler->getUsers();
|
||||||
|
foreach ($users as $user) {
|
||||||
|
$databases = $user[2] != 'NULL' ? explode(',', $user[2]) : [];
|
||||||
|
|
||||||
|
/** @var ?DatabaseUser $databaseUser */
|
||||||
|
$databaseUser = $server->databaseUsers()
|
||||||
|
->where('username', $user[0])
|
||||||
|
->first();
|
||||||
|
|
||||||
|
if ($databaseUser === null) {
|
||||||
|
$server->databaseUsers()->create([
|
||||||
|
'username' => $user[0],
|
||||||
|
'host' => $user[1],
|
||||||
|
'databases' => $databases,
|
||||||
|
'status' => DatabaseUserStatus::READY,
|
||||||
|
]);
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$databaseUser->databases = $databases;
|
||||||
|
$databaseUser->save();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
63
app/Actions/Database/SyncDatabases.php
Normal file
63
app/Actions/Database/SyncDatabases.php
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\Database;
|
||||||
|
|
||||||
|
use App\Enums\DatabaseStatus;
|
||||||
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
|
use App\SSH\Services\Database\Database;
|
||||||
|
|
||||||
|
class SyncDatabases
|
||||||
|
{
|
||||||
|
public function sync(Server $server): void
|
||||||
|
{
|
||||||
|
$service = $server->database();
|
||||||
|
if (! $service instanceof \App\Models\Service) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
/** @var Database $handler */
|
||||||
|
$handler = $service->handler();
|
||||||
|
|
||||||
|
$this->updateCharsets($service, $handler);
|
||||||
|
$this->updateDatabases($server, $handler);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function updateCharsets(Service $service, Database $handler): void
|
||||||
|
{
|
||||||
|
$data = $service->type_data ?? [];
|
||||||
|
$charsets = $handler->getCharsets();
|
||||||
|
$data['charsets'] = $charsets['charsets'] ?? [];
|
||||||
|
$data['defaultCharset'] = $charsets['defaultCharset'] ?? '';
|
||||||
|
$service->type_data = $data;
|
||||||
|
$service->save();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function updateDatabases(Server $server, Database $handler): void
|
||||||
|
{
|
||||||
|
$databases = $handler->getDatabases();
|
||||||
|
foreach ($databases as $database) {
|
||||||
|
/** @var ?\App\Models\Database $db */
|
||||||
|
$db = $server->databases()
|
||||||
|
->where('name', $database[0])
|
||||||
|
->first();
|
||||||
|
|
||||||
|
if ($db === null) {
|
||||||
|
$server->databases()->create([
|
||||||
|
'name' => $database[0],
|
||||||
|
'collation' => $database[2],
|
||||||
|
'charset' => $database[1],
|
||||||
|
'status' => DatabaseStatus::READY,
|
||||||
|
]);
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($db->collation !== $database[2] || $db->charset !== $database[1]) {
|
||||||
|
$db->update([
|
||||||
|
'collation' => $database[2],
|
||||||
|
'charset' => $database[1],
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
44
app/Actions/FileManager/FetchFiles.php
Normal file
44
app/Actions/FileManager/FetchFiles.php
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\FileManager;
|
||||||
|
|
||||||
|
use App\Exceptions\SSHError;
|
||||||
|
use App\Models\File;
|
||||||
|
use App\Models\Server;
|
||||||
|
use App\Models\User;
|
||||||
|
use Illuminate\Validation\Rule;
|
||||||
|
|
||||||
|
class FetchFiles
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws SSHError
|
||||||
|
*/
|
||||||
|
public function fetch(User $user, Server $server, array $input): void
|
||||||
|
{
|
||||||
|
File::parse(
|
||||||
|
$user,
|
||||||
|
$server,
|
||||||
|
$input['path'],
|
||||||
|
$input['user'],
|
||||||
|
$server->os()->ls($input['path'], $input['user'])
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
|
public static function rules(Server $server): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'path' => [
|
||||||
|
'required',
|
||||||
|
],
|
||||||
|
'user' => [
|
||||||
|
'required',
|
||||||
|
Rule::in($server->getSshUsers()),
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
@ -1,67 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Actions\FirewallRule;
|
|
||||||
|
|
||||||
use App\Enums\FirewallRuleStatus;
|
|
||||||
use App\Models\FirewallRule;
|
|
||||||
use App\Models\Server;
|
|
||||||
use App\SSH\Services\Firewall\Firewall;
|
|
||||||
use Illuminate\Validation\Rule;
|
|
||||||
|
|
||||||
class CreateRule
|
|
||||||
{
|
|
||||||
public function create(Server $server, array $input): FirewallRule
|
|
||||||
{
|
|
||||||
$rule = new FirewallRule([
|
|
||||||
'server_id' => $server->id,
|
|
||||||
'type' => $input['type'],
|
|
||||||
'protocol' => $input['protocol'],
|
|
||||||
'port' => $input['port'],
|
|
||||||
'source' => $input['source'],
|
|
||||||
'mask' => $input['mask'] ?? null,
|
|
||||||
]);
|
|
||||||
|
|
||||||
/** @var Firewall $firewallHandler */
|
|
||||||
$firewallHandler = $server->firewall()->handler();
|
|
||||||
$firewallHandler->addRule(
|
|
||||||
$rule->type,
|
|
||||||
$rule->getRealProtocol(),
|
|
||||||
$rule->port,
|
|
||||||
$rule->source,
|
|
||||||
$rule->mask
|
|
||||||
);
|
|
||||||
|
|
||||||
$rule->status = FirewallRuleStatus::READY;
|
|
||||||
$rule->save();
|
|
||||||
|
|
||||||
return $rule;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function rules(): array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
'type' => [
|
|
||||||
'required',
|
|
||||||
'in:allow,deny',
|
|
||||||
],
|
|
||||||
'protocol' => [
|
|
||||||
'required',
|
|
||||||
Rule::in(array_keys(config('core.firewall_protocols_port'))),
|
|
||||||
],
|
|
||||||
'port' => [
|
|
||||||
'required',
|
|
||||||
'numeric',
|
|
||||||
'min:1',
|
|
||||||
'max:65535',
|
|
||||||
],
|
|
||||||
'source' => [
|
|
||||||
'required',
|
|
||||||
'ip',
|
|
||||||
],
|
|
||||||
'mask' => [
|
|
||||||
'required',
|
|
||||||
'numeric',
|
|
||||||
],
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Actions\FirewallRule;
|
|
||||||
|
|
||||||
use App\Enums\FirewallRuleStatus;
|
|
||||||
use App\Models\FirewallRule;
|
|
||||||
use App\Models\Server;
|
|
||||||
|
|
||||||
class DeleteRule
|
|
||||||
{
|
|
||||||
public function delete(Server $server, FirewallRule $rule): void
|
|
||||||
{
|
|
||||||
$rule->status = FirewallRuleStatus::DELETING;
|
|
||||||
$rule->save();
|
|
||||||
|
|
||||||
$server->firewall()
|
|
||||||
->handler()
|
|
||||||
->removeRule(
|
|
||||||
$rule->type,
|
|
||||||
$rule->getRealProtocol(),
|
|
||||||
$rule->port,
|
|
||||||
$rule->source,
|
|
||||||
$rule->mask
|
|
||||||
);
|
|
||||||
|
|
||||||
$rule->delete();
|
|
||||||
}
|
|
||||||
}
|
|
132
app/Actions/FirewallRule/ManageRule.php
Executable file
132
app/Actions/FirewallRule/ManageRule.php
Executable file
@ -0,0 +1,132 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\FirewallRule;
|
||||||
|
|
||||||
|
use App\Enums\FirewallRuleStatus;
|
||||||
|
use App\Models\FirewallRule;
|
||||||
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
|
use App\SSH\Services\Firewall\Firewall;
|
||||||
|
use Exception;
|
||||||
|
|
||||||
|
class ManageRule
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return FirewallRule $rule
|
||||||
|
*/
|
||||||
|
public function create(Server $server, array $input): FirewallRule
|
||||||
|
{
|
||||||
|
$sourceAny = $input['source_any'] ?? empty($input['source'] ?? null);
|
||||||
|
$rule = new FirewallRule([
|
||||||
|
'name' => $input['name'],
|
||||||
|
'server_id' => $server->id,
|
||||||
|
'type' => $input['type'],
|
||||||
|
'protocol' => $input['protocol'],
|
||||||
|
'port' => $input['port'],
|
||||||
|
'source' => $sourceAny ? null : $input['source'],
|
||||||
|
'mask' => $sourceAny ? null : ($input['mask'] ?? null),
|
||||||
|
'status' => FirewallRuleStatus::CREATING,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$rule->save();
|
||||||
|
|
||||||
|
dispatch(fn () => $this->applyRule($rule));
|
||||||
|
|
||||||
|
return $rule;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return FirewallRule $rule
|
||||||
|
*/
|
||||||
|
public function update(FirewallRule $rule, array $input): FirewallRule
|
||||||
|
{
|
||||||
|
$sourceAny = $input['source_any'] ?? empty($input['source'] ?? null);
|
||||||
|
$rule->update([
|
||||||
|
'name' => $input['name'],
|
||||||
|
'type' => $input['type'],
|
||||||
|
'protocol' => $input['protocol'],
|
||||||
|
'port' => $input['port'],
|
||||||
|
'source' => $sourceAny ? null : $input['source'],
|
||||||
|
'mask' => $sourceAny ? null : ($input['mask'] ?? null),
|
||||||
|
'status' => FirewallRuleStatus::UPDATING,
|
||||||
|
]);
|
||||||
|
|
||||||
|
dispatch(fn () => $this->applyRule($rule));
|
||||||
|
|
||||||
|
return $rule;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function delete(FirewallRule $rule): void
|
||||||
|
{
|
||||||
|
$rule->status = FirewallRuleStatus::DELETING;
|
||||||
|
$rule->save();
|
||||||
|
|
||||||
|
dispatch(fn () => $this->applyRule($rule));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function applyRule(FirewallRule $rule): void
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $rule->server->firewall();
|
||||||
|
/** @var Firewall $handler */
|
||||||
|
$handler = $service->handler();
|
||||||
|
$handler->applyRules();
|
||||||
|
} catch (Exception) {
|
||||||
|
$rule->server->firewallRules()
|
||||||
|
->where('status', '!=', FirewallRuleStatus::READY)
|
||||||
|
->update(['status' => FirewallRuleStatus::FAILED]);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($rule->status === FirewallRuleStatus::DELETING) {
|
||||||
|
$rule->delete();
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$rule->status = FirewallRuleStatus::READY;
|
||||||
|
$rule->save();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
|
public static function rules(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'name' => [
|
||||||
|
'required',
|
||||||
|
'string',
|
||||||
|
'max:18',
|
||||||
|
],
|
||||||
|
'type' => [
|
||||||
|
'required',
|
||||||
|
'in:allow,deny',
|
||||||
|
],
|
||||||
|
'protocol' => [
|
||||||
|
'required',
|
||||||
|
'in:tcp,udp',
|
||||||
|
],
|
||||||
|
'port' => [
|
||||||
|
'required',
|
||||||
|
'numeric',
|
||||||
|
'min:1',
|
||||||
|
'max:65535',
|
||||||
|
],
|
||||||
|
'source' => [
|
||||||
|
'nullable',
|
||||||
|
'ip',
|
||||||
|
],
|
||||||
|
'mask' => [
|
||||||
|
'nullable',
|
||||||
|
'numeric',
|
||||||
|
'min:1',
|
||||||
|
'max:32',
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
@ -11,6 +11,10 @@
|
|||||||
|
|
||||||
class GetMetrics
|
class GetMetrics
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return Collection<int, mixed>
|
||||||
|
*/
|
||||||
public function filter(Server $server, array $input): Collection
|
public function filter(Server $server, array $input): Collection
|
||||||
{
|
{
|
||||||
if (isset($input['from']) && isset($input['to']) && $input['from'] === $input['to']) {
|
if (isset($input['from']) && isset($input['to']) && $input['from'] === $input['to']) {
|
||||||
@ -32,6 +36,9 @@ public function filter(Server $server, array $input): Collection
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Collection<int, mixed>
|
||||||
|
*/
|
||||||
private function metrics(
|
private function metrics(
|
||||||
Server $server,
|
Server $server,
|
||||||
Carbon $fromDate,
|
Carbon $fromDate,
|
||||||
@ -57,13 +64,16 @@ private function metrics(
|
|||||||
->groupByRaw('date_interval')
|
->groupByRaw('date_interval')
|
||||||
->orderBy('date_interval')
|
->orderBy('date_interval')
|
||||||
->get()
|
->get()
|
||||||
->map(function ($item) {
|
->map(function ($item): \stdClass {
|
||||||
$item->date = Carbon::parse($item->date)->format('Y-m-d H:i');
|
$item->date = Carbon::parse($item->date)->format('Y-m-d H:i');
|
||||||
|
|
||||||
return $item;
|
return $item;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
private function getFromDate(array $input): Carbon
|
private function getFromDate(array $input): Carbon
|
||||||
{
|
{
|
||||||
if ($input['period'] === 'custom') {
|
if ($input['period'] === 'custom') {
|
||||||
@ -73,6 +83,9 @@ private function getFromDate(array $input): Carbon
|
|||||||
return Carbon::parse('-'.convert_time_format($input['period']));
|
return Carbon::parse('-'.convert_time_format($input['period']));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
private function getToDate(array $input): Carbon
|
private function getToDate(array $input): Carbon
|
||||||
{
|
{
|
||||||
if ($input['period'] === 'custom') {
|
if ($input['period'] === 'custom') {
|
||||||
@ -82,6 +95,9 @@ private function getToDate(array $input): Carbon
|
|||||||
return Carbon::now();
|
return Carbon::now();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
private function getInterval(array $input): Expression
|
private function getInterval(array $input): Expression
|
||||||
{
|
{
|
||||||
if ($input['period'] === 'custom') {
|
if ($input['period'] === 'custom') {
|
||||||
@ -107,6 +123,10 @@ private function getInterval(array $input): Expression
|
|||||||
return DB::raw("strftime('%Y-%m-%d 00:00:00', created_at) as date_interval");
|
return DB::raw("strftime('%Y-%m-%d 00:00:00', created_at) as date_interval");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(array $input): array
|
public static function rules(array $input): array
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
|
@ -3,19 +3,29 @@
|
|||||||
namespace App\Actions\Monitoring;
|
namespace App\Actions\Monitoring;
|
||||||
|
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
|
use App\SSH\Services\ServiceInterface;
|
||||||
|
|
||||||
class UpdateMetricSettings
|
class UpdateMetricSettings
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function update(Server $server, array $input): void
|
public function update(Server $server, array $input): void
|
||||||
{
|
{
|
||||||
|
/** @var Service $service */
|
||||||
$service = $server->monitoring();
|
$service = $server->monitoring();
|
||||||
|
/** @var ServiceInterface $handler */
|
||||||
$data = $service->handler()->data();
|
$handler = $service->handler();
|
||||||
|
$data = $handler->data();
|
||||||
$data['data_retention'] = $input['data_retention'];
|
$data['data_retention'] = $input['data_retention'];
|
||||||
$service->type_data = $data;
|
$service->type_data = $data;
|
||||||
$service->save();
|
$service->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(): array
|
public static function rules(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
46
app/Actions/NodeJS/ChangeDefaultCli.php
Normal file
46
app/Actions/NodeJS/ChangeDefaultCli.php
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\NodeJS;
|
||||||
|
|
||||||
|
use App\Enums\ServiceStatus;
|
||||||
|
use App\Exceptions\SSHError;
|
||||||
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
|
use App\SSH\Services\NodeJS\NodeJS;
|
||||||
|
use Illuminate\Validation\ValidationException;
|
||||||
|
|
||||||
|
class ChangeDefaultCli
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws ValidationException
|
||||||
|
* @throws SSHError
|
||||||
|
*/
|
||||||
|
public function change(Server $server, array $input): void
|
||||||
|
{
|
||||||
|
$this->validate($server, $input);
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $server->nodejs($input['version']);
|
||||||
|
/** @var NodeJS $handler */
|
||||||
|
$handler = $service->handler();
|
||||||
|
$handler->setDefaultCli();
|
||||||
|
$server->defaultService('nodejs')?->update(['is_default' => 0]);
|
||||||
|
$service->update(['is_default' => 1]);
|
||||||
|
$service->update(['status' => ServiceStatus::READY]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws ValidationException
|
||||||
|
*/
|
||||||
|
public function validate(Server $server, array $input): void
|
||||||
|
{
|
||||||
|
if (! isset($input['version']) || ! in_array($input['version'], $server->installedNodejsVersions())) {
|
||||||
|
throw ValidationException::withMessages(
|
||||||
|
['version' => __('This version is not installed')]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
51
app/Actions/NodeJS/InstallNewNodeJsVersion.php
Executable file
51
app/Actions/NodeJS/InstallNewNodeJsVersion.php
Executable file
@ -0,0 +1,51 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\NodeJS;
|
||||||
|
|
||||||
|
use App\Enums\NodeJS;
|
||||||
|
use App\Enums\ServiceStatus;
|
||||||
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
|
use Illuminate\Validation\Rule;
|
||||||
|
|
||||||
|
class InstallNewNodeJsVersion
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
|
public function install(Server $server, array $input): void
|
||||||
|
{
|
||||||
|
$nodejs = new Service([
|
||||||
|
'server_id' => $server->id,
|
||||||
|
'type' => 'nodejs',
|
||||||
|
'type_data' => [],
|
||||||
|
'name' => 'nodejs',
|
||||||
|
'version' => $input['version'],
|
||||||
|
'status' => ServiceStatus::INSTALLING,
|
||||||
|
'is_default' => false,
|
||||||
|
]);
|
||||||
|
$nodejs->save();
|
||||||
|
|
||||||
|
dispatch(function () use ($nodejs): void {
|
||||||
|
$nodejs->handler()->install();
|
||||||
|
$nodejs->status = ServiceStatus::READY;
|
||||||
|
$nodejs->save();
|
||||||
|
})->catch(function () use ($nodejs): void {
|
||||||
|
$nodejs->delete();
|
||||||
|
})->onConnection('ssh');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
|
public static function rules(Server $server): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'version' => [
|
||||||
|
'required',
|
||||||
|
Rule::in(config('core.nodejs_versions')),
|
||||||
|
Rule::notIn(array_merge($server->installedNodejsVersions(), [NodeJS::NONE])),
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
60
app/Actions/NodeJS/UninstallNodeJS.php
Executable file
60
app/Actions/NodeJS/UninstallNodeJS.php
Executable file
@ -0,0 +1,60 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\NodeJS;
|
||||||
|
|
||||||
|
use App\Enums\ServiceStatus;
|
||||||
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
|
use Illuminate\Support\Facades\Validator;
|
||||||
|
use Illuminate\Validation\ValidationException;
|
||||||
|
|
||||||
|
class UninstallNodeJS
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws ValidationException
|
||||||
|
*/
|
||||||
|
public function uninstall(Server $server, array $input): void
|
||||||
|
{
|
||||||
|
$this->validate($server, $input);
|
||||||
|
|
||||||
|
/** @var Service $nodejs */
|
||||||
|
$nodejs = $server->nodejs($input['version']);
|
||||||
|
$nodejs->status = ServiceStatus::UNINSTALLING;
|
||||||
|
$nodejs->save();
|
||||||
|
|
||||||
|
dispatch(function () use ($nodejs): void {
|
||||||
|
$nodejs->handler()->uninstall();
|
||||||
|
$nodejs->delete();
|
||||||
|
})->catch(function () use ($nodejs): void {
|
||||||
|
$nodejs->status = ServiceStatus::FAILED;
|
||||||
|
$nodejs->save();
|
||||||
|
})->onConnection('ssh');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws ValidationException
|
||||||
|
*/
|
||||||
|
private function validate(Server $server, array $input): void
|
||||||
|
{
|
||||||
|
Validator::make($input, [
|
||||||
|
'version' => 'required|string',
|
||||||
|
])->validate();
|
||||||
|
|
||||||
|
if (! in_array($input['version'], $server->installedNodejsVersions())) {
|
||||||
|
throw ValidationException::withMessages(
|
||||||
|
['version' => __('This version is not installed')]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$hasSite = $server->sites()->where('nodejs_version', $input['version'])->first();
|
||||||
|
if ($hasSite) {
|
||||||
|
throw ValidationException::withMessages(
|
||||||
|
['version' => __('Cannot uninstall this version because some sites are using it!')]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -11,8 +11,9 @@
|
|||||||
class AddChannel
|
class AddChannel
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
* @throws Exception
|
|
||||||
*/
|
*/
|
||||||
public function add(User $user, array $input): void
|
public function add(User $user, array $input): void
|
||||||
{
|
{
|
||||||
@ -42,13 +43,19 @@ public function add(User $user, array $input): void
|
|||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
$channel->delete();
|
$channel->delete();
|
||||||
|
|
||||||
throw $e;
|
throw ValidationException::withMessages([
|
||||||
|
'provider' => $e->getMessage(),
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
$channel->connected = true;
|
$channel->connected = true;
|
||||||
$channel->save();
|
$channel->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, mixed>
|
||||||
|
*/
|
||||||
public static function rules(array $input): array
|
public static function rules(array $input): array
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
@ -59,9 +66,13 @@ public static function rules(array $input): array
|
|||||||
'label' => 'required',
|
'label' => 'required',
|
||||||
];
|
];
|
||||||
|
|
||||||
return array_merge($rules, static::providerRules($input));
|
return array_merge($rules, self::providerRules($input));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
private static function providerRules(array $input): array
|
private static function providerRules(array $input): array
|
||||||
{
|
{
|
||||||
if (! isset($input['provider'])) {
|
if (! isset($input['provider'])) {
|
||||||
|
@ -7,6 +7,9 @@
|
|||||||
|
|
||||||
class EditChannel
|
class EditChannel
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function edit(NotificationChannel $notificationChannel, User $user, array $input): void
|
public function edit(NotificationChannel $notificationChannel, User $user, array $input): void
|
||||||
{
|
{
|
||||||
$notificationChannel->fill([
|
$notificationChannel->fill([
|
||||||
@ -16,6 +19,10 @@ public function edit(NotificationChannel $notificationChannel, User $user, array
|
|||||||
$notificationChannel->save();
|
$notificationChannel->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, string>
|
||||||
|
*/
|
||||||
public static function rules(array $input): array
|
public static function rules(array $input): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -3,24 +3,37 @@
|
|||||||
namespace App\Actions\PHP;
|
namespace App\Actions\PHP;
|
||||||
|
|
||||||
use App\Enums\ServiceStatus;
|
use App\Enums\ServiceStatus;
|
||||||
|
use App\Exceptions\SSHError;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
use App\SSH\Services\PHP\PHP;
|
use App\SSH\Services\PHP\PHP;
|
||||||
use Illuminate\Validation\ValidationException;
|
use Illuminate\Validation\ValidationException;
|
||||||
|
|
||||||
class ChangeDefaultCli
|
class ChangeDefaultCli
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws SSHError
|
||||||
|
*/
|
||||||
public function change(Server $server, array $input): void
|
public function change(Server $server, array $input): void
|
||||||
{
|
{
|
||||||
$this->validate($server, $input);
|
$this->validate($server, $input);
|
||||||
|
/** @var Service $service */
|
||||||
$service = $server->php($input['version']);
|
$service = $server->php($input['version']);
|
||||||
/** @var PHP $handler */
|
/** @var PHP $handler */
|
||||||
$handler = $service->handler();
|
$handler = $service->handler();
|
||||||
$handler->setDefaultCli();
|
$handler->setDefaultCli();
|
||||||
$server->defaultService('php')->update(['is_default' => 0]);
|
$server->defaultService('php')?->update(['is_default' => 0]);
|
||||||
$service->update(['is_default' => 1]);
|
$service->update(['is_default' => 1]);
|
||||||
$service->update(['status' => ServiceStatus::READY]);
|
$service->update(['status' => ServiceStatus::READY]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws ValidationException
|
||||||
|
*/
|
||||||
public function validate(Server $server, array $input): void
|
public function validate(Server $server, array $input): void
|
||||||
{
|
{
|
||||||
if (! isset($input['version']) || ! in_array($input['version'], $server->installedPHPVersions())) {
|
if (! isset($input['version']) || ! in_array($input['version'], $server->installedPHPVersions())) {
|
||||||
|
@ -4,17 +4,25 @@
|
|||||||
|
|
||||||
use App\Enums\PHPIniType;
|
use App\Enums\PHPIniType;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
use App\SSH\Services\PHP\PHP;
|
use App\SSH\Services\PHP\PHP;
|
||||||
use Illuminate\Support\Facades\Validator;
|
use Illuminate\Support\Facades\Validator;
|
||||||
use Illuminate\Validation\Rule;
|
use Illuminate\Validation\Rule;
|
||||||
use Illuminate\Validation\ValidationException;
|
use Illuminate\Validation\ValidationException;
|
||||||
|
use Throwable;
|
||||||
|
|
||||||
class GetPHPIni
|
class GetPHPIni
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws ValidationException
|
||||||
|
*/
|
||||||
public function getIni(Server $server, array $input): string
|
public function getIni(Server $server, array $input): string
|
||||||
{
|
{
|
||||||
$this->validate($server, $input);
|
$this->validate($server, $input);
|
||||||
|
|
||||||
|
/** @var Service $php */
|
||||||
$php = $server->php($input['version']);
|
$php = $server->php($input['version']);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@ -22,13 +30,18 @@ public function getIni(Server $server, array $input): string
|
|||||||
$handler = $php->handler();
|
$handler = $php->handler();
|
||||||
|
|
||||||
return $handler->getPHPIni($input['type']);
|
return $handler->getPHPIni($input['type']);
|
||||||
} catch (\Throwable $e) {
|
} catch (Throwable $e) {
|
||||||
throw ValidationException::withMessages(
|
throw ValidationException::withMessages(
|
||||||
['ini' => $e->getMessage()]
|
['ini' => $e->getMessage()]
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws ValidationException
|
||||||
|
*/
|
||||||
public function validate(Server $server, array $input): void
|
public function validate(Server $server, array $input): void
|
||||||
{
|
{
|
||||||
Validator::make($input, [
|
Validator::make($input, [
|
||||||
|
@ -10,6 +10,9 @@
|
|||||||
|
|
||||||
class InstallNewPHP
|
class InstallNewPHP
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function install(Server $server, array $input): void
|
public function install(Server $server, array $input): void
|
||||||
{
|
{
|
||||||
$php = new Service([
|
$php = new Service([
|
||||||
@ -26,15 +29,18 @@ public function install(Server $server, array $input): void
|
|||||||
]);
|
]);
|
||||||
$php->save();
|
$php->save();
|
||||||
|
|
||||||
dispatch(function () use ($php) {
|
dispatch(function () use ($php): void {
|
||||||
$php->handler()->install();
|
$php->handler()->install();
|
||||||
$php->status = ServiceStatus::READY;
|
$php->status = ServiceStatus::READY;
|
||||||
$php->save();
|
$php->save();
|
||||||
})->catch(function () use ($php) {
|
})->catch(function () use ($php): void {
|
||||||
$php->delete();
|
$php->delete();
|
||||||
})->onConnection('ssh');
|
})->onConnection('ssh');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(Server $server): array
|
public static function rules(Server $server): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -2,7 +2,6 @@
|
|||||||
|
|
||||||
namespace App\Actions\PHP;
|
namespace App\Actions\PHP;
|
||||||
|
|
||||||
use App\Exceptions\SSHCommandError;
|
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
use App\Models\Service;
|
use App\Models\Service;
|
||||||
use App\SSH\Services\PHP\PHP;
|
use App\SSH\Services\PHP\PHP;
|
||||||
@ -11,6 +10,11 @@
|
|||||||
|
|
||||||
class InstallPHPExtension
|
class InstallPHPExtension
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws ValidationException
|
||||||
|
*/
|
||||||
public function install(Server $server, array $input): Service
|
public function install(Server $server, array $input): Service
|
||||||
{
|
{
|
||||||
/** @var Service $service */
|
/** @var Service $service */
|
||||||
@ -23,20 +27,17 @@ public function install(Server $server, array $input): Service
|
|||||||
}
|
}
|
||||||
|
|
||||||
$typeData = $service->type_data;
|
$typeData = $service->type_data;
|
||||||
$typeData['extensions'] = $typeData['extensions'] ?? [];
|
$typeData['extensions'] ??= [];
|
||||||
$typeData['extensions'][] = $input['extension'];
|
$typeData['extensions'][] = $input['extension'];
|
||||||
$service->type_data = $typeData;
|
$service->type_data = $typeData;
|
||||||
$service->save();
|
$service->save();
|
||||||
|
|
||||||
dispatch(
|
dispatch(
|
||||||
/**
|
function () use ($service, $input): void {
|
||||||
* @throws SSHCommandError
|
|
||||||
*/
|
|
||||||
function () use ($service, $input) {
|
|
||||||
/** @var PHP $handler */
|
/** @var PHP $handler */
|
||||||
$handler = $service->handler();
|
$handler = $service->handler();
|
||||||
$handler->installExtension($input['extension']);
|
$handler->installExtension($input['extension']);
|
||||||
})->catch(function () use ($service, $input) {
|
})->catch(function () use ($service, $input): void {
|
||||||
$service->refresh();
|
$service->refresh();
|
||||||
$typeData = $service->type_data;
|
$typeData = $service->type_data;
|
||||||
$typeData['extensions'] = array_values(array_diff($typeData['extensions'], [$input['extension']]));
|
$typeData['extensions'] = array_values(array_diff($typeData['extensions'], [$input['extension']]));
|
||||||
@ -47,6 +48,9 @@ function () use ($service, $input) {
|
|||||||
return $service;
|
return $service;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(Server $server): array
|
public static function rules(Server $server): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -10,6 +10,11 @@
|
|||||||
|
|
||||||
class UninstallPHP
|
class UninstallPHP
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws ValidationException
|
||||||
|
*/
|
||||||
public function uninstall(Server $server, array $input): void
|
public function uninstall(Server $server, array $input): void
|
||||||
{
|
{
|
||||||
$this->validate($server, $input);
|
$this->validate($server, $input);
|
||||||
@ -19,16 +24,18 @@ public function uninstall(Server $server, array $input): void
|
|||||||
$php->status = ServiceStatus::UNINSTALLING;
|
$php->status = ServiceStatus::UNINSTALLING;
|
||||||
$php->save();
|
$php->save();
|
||||||
|
|
||||||
dispatch(function () use ($php) {
|
dispatch(function () use ($php): void {
|
||||||
$php->handler()->uninstall();
|
$php->handler()->uninstall();
|
||||||
$php->delete();
|
$php->delete();
|
||||||
})->catch(function () use ($php) {
|
})->catch(function () use ($php): void {
|
||||||
$php->status = ServiceStatus::FAILED;
|
$php->status = ServiceStatus::FAILED;
|
||||||
$php->save();
|
$php->save();
|
||||||
})->onConnection('ssh');
|
})->onConnection('ssh');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
private function validate(Server $server, array $input): void
|
private function validate(Server $server, array $input): void
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
use App\Enums\PHPIniType;
|
use App\Enums\PHPIniType;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
|
use App\Models\Service;
|
||||||
use Illuminate\Filesystem\FilesystemAdapter;
|
use Illuminate\Filesystem\FilesystemAdapter;
|
||||||
use Illuminate\Support\Facades\Storage;
|
use Illuminate\Support\Facades\Storage;
|
||||||
use Illuminate\Support\Str;
|
use Illuminate\Support\Str;
|
||||||
@ -14,10 +15,13 @@
|
|||||||
class UpdatePHPIni
|
class UpdatePHPIni
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
public function update(Server $server, array $input): void
|
public function update(Server $server, array $input): void
|
||||||
{
|
{
|
||||||
|
/** @var Service $service */
|
||||||
$service = $server->php($input['version']);
|
$service = $server->php($input['version']);
|
||||||
|
|
||||||
$tmpName = Str::random(10).strtotime('now');
|
$tmpName = Str::random(10).strtotime('now');
|
||||||
@ -48,6 +52,9 @@ private function deleteTempFile(string $name): void
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(Server $server): array
|
public static function rules(Server $server): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -9,6 +9,9 @@
|
|||||||
|
|
||||||
class AddUser
|
class AddUser
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function add(Project $project, array $input): void
|
public function add(Project $project, array $input): void
|
||||||
{
|
{
|
||||||
/** @var User $user */
|
/** @var User $user */
|
||||||
@ -18,13 +21,16 @@ public function add(Project $project, array $input): void
|
|||||||
$project->users()->attach($user);
|
$project->users()->attach($user);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(Project $project): array
|
public static function rules(Project $project): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
'user' => [
|
'user' => [
|
||||||
'required',
|
'required',
|
||||||
Rule::exists('users', 'id'),
|
Rule::exists('users', 'id'),
|
||||||
Rule::unique('user_project', 'user_id')->where(function (Builder $query) use ($project) {
|
Rule::unique('user_project', 'user_id')->where(function (Builder $query) use ($project): void {
|
||||||
$query->where('project_id', $project->id);
|
$query->where('project_id', $project->id);
|
||||||
}),
|
}),
|
||||||
],
|
],
|
||||||
|
@ -8,10 +8,13 @@
|
|||||||
|
|
||||||
class CreateProject
|
class CreateProject
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function create(User $user, array $input): Project
|
public function create(User $user, array $input): Project
|
||||||
{
|
{
|
||||||
if (isset($input['name'])) {
|
if (isset($input['name'])) {
|
||||||
$input['name'] = strtolower($input['name']);
|
$input['name'] = strtolower((string) $input['name']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->validate($input);
|
$this->validate($input);
|
||||||
@ -27,6 +30,9 @@ public function create(User $user, array $input): Project
|
|||||||
return $project;
|
return $project;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(): array
|
public static function rules(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
@ -40,6 +46,9 @@ public static function rules(): array
|
|||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
private function validate(array $input): void
|
private function validate(array $input): void
|
||||||
{
|
{
|
||||||
Validator::make($input, self::rules())->validate();
|
Validator::make($input, self::rules())->validate();
|
||||||
|
@ -8,10 +8,13 @@
|
|||||||
|
|
||||||
class UpdateProject
|
class UpdateProject
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function update(Project $project, array $input): Project
|
public function update(Project $project, array $input): Project
|
||||||
{
|
{
|
||||||
if (isset($input['name'])) {
|
if (isset($input['name'])) {
|
||||||
$input['name'] = strtolower($input['name']);
|
$input['name'] = strtolower((string) $input['name']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->validate($project, $input);
|
$this->validate($project, $input);
|
||||||
@ -23,6 +26,9 @@ public function update(Project $project, array $input): Project
|
|||||||
return $project;
|
return $project;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(Project $project): array
|
public static function rules(Project $project): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
@ -36,6 +42,9 @@ public static function rules(Project $project): array
|
|||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
private function validate(Project $project, array $input): void
|
private function validate(Project $project, array $input): void
|
||||||
{
|
{
|
||||||
Validator::make($input, self::rules($project))->validate();
|
Validator::make($input, self::rules($project))->validate();
|
||||||
|
@ -1,69 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Actions\Queue;
|
|
||||||
|
|
||||||
use App\Enums\QueueStatus;
|
|
||||||
use App\Models\Queue;
|
|
||||||
use App\Models\Server;
|
|
||||||
use App\Models\Site;
|
|
||||||
use Illuminate\Validation\Rule;
|
|
||||||
use Illuminate\Validation\ValidationException;
|
|
||||||
|
|
||||||
class CreateQueue
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* @throws ValidationException
|
|
||||||
*/
|
|
||||||
public function create(mixed $queueable, array $input): void
|
|
||||||
{
|
|
||||||
$queue = new Queue([
|
|
||||||
'server_id' => $queueable instanceof Server ? $queueable->id : $queueable->server_id,
|
|
||||||
'site_id' => $queueable instanceof Site ? $queueable->id : null,
|
|
||||||
'command' => $input['command'],
|
|
||||||
'user' => $input['user'],
|
|
||||||
'auto_start' => $input['auto_start'] ? 1 : 0,
|
|
||||||
'auto_restart' => $input['auto_restart'] ? 1 : 0,
|
|
||||||
'numprocs' => $input['numprocs'],
|
|
||||||
'status' => QueueStatus::CREATING,
|
|
||||||
]);
|
|
||||||
$queue->save();
|
|
||||||
|
|
||||||
dispatch(function () use ($queue) {
|
|
||||||
$queue->server->processManager()->handler()->create(
|
|
||||||
$queue->id,
|
|
||||||
$queue->command,
|
|
||||||
$queue->user,
|
|
||||||
$queue->auto_start,
|
|
||||||
$queue->auto_restart,
|
|
||||||
$queue->numprocs,
|
|
||||||
$queue->getLogFile(),
|
|
||||||
$queue->site_id
|
|
||||||
);
|
|
||||||
$queue->status = QueueStatus::RUNNING;
|
|
||||||
$queue->save();
|
|
||||||
})->catch(function () use ($queue) {
|
|
||||||
$queue->delete();
|
|
||||||
})->onConnection('ssh');
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function rules(Server $server): array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
'command' => [
|
|
||||||
'required',
|
|
||||||
],
|
|
||||||
'user' => [
|
|
||||||
'required',
|
|
||||||
Rule::in([
|
|
||||||
'root',
|
|
||||||
$server->ssh_user,
|
|
||||||
]),
|
|
||||||
],
|
|
||||||
'numprocs' => [
|
|
||||||
'required',
|
|
||||||
'numeric',
|
|
||||||
'min:1',
|
|
||||||
],
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,17 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Actions\Queue;
|
|
||||||
|
|
||||||
use App\Models\Queue;
|
|
||||||
use App\SSH\Services\ProcessManager\ProcessManager;
|
|
||||||
|
|
||||||
class DeleteQueue
|
|
||||||
{
|
|
||||||
public function delete(Queue $queue): void
|
|
||||||
{
|
|
||||||
/** @var ProcessManager $processManager */
|
|
||||||
$processManager = $queue->server->processManager()->handler();
|
|
||||||
$processManager->delete($queue->id, $queue->site_id);
|
|
||||||
$queue->delete();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,72 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Actions\Queue;
|
|
||||||
|
|
||||||
use App\Enums\QueueStatus;
|
|
||||||
use App\Models\Queue;
|
|
||||||
use App\Models\Server;
|
|
||||||
use App\SSH\Services\ProcessManager\ProcessManager;
|
|
||||||
use Illuminate\Validation\Rule;
|
|
||||||
use Illuminate\Validation\ValidationException;
|
|
||||||
|
|
||||||
class EditQueue
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* @throws ValidationException
|
|
||||||
*/
|
|
||||||
public function edit(Queue $queue, array $input): void
|
|
||||||
{
|
|
||||||
$queue->fill([
|
|
||||||
'command' => $input['command'],
|
|
||||||
'user' => $input['user'],
|
|
||||||
'auto_start' => $input['auto_start'] ? 1 : 0,
|
|
||||||
'auto_restart' => $input['auto_restart'] ? 1 : 0,
|
|
||||||
'numprocs' => $input['numprocs'],
|
|
||||||
'status' => QueueStatus::RESTARTING,
|
|
||||||
]);
|
|
||||||
$queue->save();
|
|
||||||
|
|
||||||
dispatch(function () use ($queue) {
|
|
||||||
/** @var ProcessManager $processManager */
|
|
||||||
$processManager = $queue->server->processManager()->handler();
|
|
||||||
$processManager->delete($queue->id, $queue->site_id);
|
|
||||||
|
|
||||||
$processManager->create(
|
|
||||||
$queue->id,
|
|
||||||
$queue->command,
|
|
||||||
$queue->user,
|
|
||||||
$queue->auto_start,
|
|
||||||
$queue->auto_restart,
|
|
||||||
$queue->numprocs,
|
|
||||||
$queue->getLogFile(),
|
|
||||||
$queue->site_id
|
|
||||||
);
|
|
||||||
$queue->status = QueueStatus::RUNNING;
|
|
||||||
$queue->save();
|
|
||||||
})->catch(function () use ($queue) {
|
|
||||||
$queue->status = QueueStatus::FAILED;
|
|
||||||
$queue->save();
|
|
||||||
})->onConnection('ssh');
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function rules(Server $server): array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
'command' => [
|
|
||||||
'required',
|
|
||||||
],
|
|
||||||
'user' => [
|
|
||||||
'required',
|
|
||||||
Rule::in([
|
|
||||||
'root',
|
|
||||||
$server->ssh_user,
|
|
||||||
]),
|
|
||||||
],
|
|
||||||
'numprocs' => [
|
|
||||||
'required',
|
|
||||||
'numeric',
|
|
||||||
'min:1',
|
|
||||||
],
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,13 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Actions\Queue;
|
|
||||||
|
|
||||||
use App\Models\Queue;
|
|
||||||
|
|
||||||
class GetQueueLogs
|
|
||||||
{
|
|
||||||
public function getLogs(Queue $queue): string
|
|
||||||
{
|
|
||||||
return $queue->server->processManager()->handler()->getLogs($queue->getLogFile());
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,42 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Actions\Queue;
|
|
||||||
|
|
||||||
use App\Enums\QueueStatus;
|
|
||||||
use App\Models\Queue;
|
|
||||||
|
|
||||||
class ManageQueue
|
|
||||||
{
|
|
||||||
public function start(Queue $queue): void
|
|
||||||
{
|
|
||||||
$queue->status = QueueStatus::STARTING;
|
|
||||||
$queue->save();
|
|
||||||
dispatch(function () use ($queue) {
|
|
||||||
$queue->server->processManager()->handler()->start($queue->id, $queue->site_id);
|
|
||||||
$queue->status = QueueStatus::RUNNING;
|
|
||||||
$queue->save();
|
|
||||||
})->onConnection('ssh');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function stop(Queue $queue): void
|
|
||||||
{
|
|
||||||
$queue->status = QueueStatus::STOPPING;
|
|
||||||
$queue->save();
|
|
||||||
dispatch(function () use ($queue) {
|
|
||||||
$queue->server->processManager()->handler()->stop($queue->id, $queue->site_id);
|
|
||||||
$queue->status = QueueStatus::STOPPED;
|
|
||||||
$queue->save();
|
|
||||||
})->onConnection('ssh');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function restart(Queue $queue): void
|
|
||||||
{
|
|
||||||
$queue->status = QueueStatus::RESTARTING;
|
|
||||||
$queue->save();
|
|
||||||
dispatch(function () use ($queue) {
|
|
||||||
$queue->server->processManager()->handler()->restart($queue->id, $queue->site_id);
|
|
||||||
$queue->status = QueueStatus::RUNNING;
|
|
||||||
$queue->save();
|
|
||||||
})->onConnection('ssh');
|
|
||||||
}
|
|
||||||
}
|
|
75
app/Actions/Redirect/CreateRedirect.php
Normal file
75
app/Actions/Redirect/CreateRedirect.php
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\Redirect;
|
||||||
|
|
||||||
|
use App\Enums\RedirectStatus;
|
||||||
|
use App\Models\Redirect;
|
||||||
|
use App\Models\Service;
|
||||||
|
use App\Models\Site;
|
||||||
|
use App\SSH\Services\Webserver\Webserver;
|
||||||
|
use Illuminate\Validation\Rule;
|
||||||
|
|
||||||
|
class CreateRedirect
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
|
public function create(Site $site, array $input): Redirect
|
||||||
|
{
|
||||||
|
$redirect = new Redirect;
|
||||||
|
|
||||||
|
$redirect->site_id = $site->id;
|
||||||
|
$redirect->from = $input['from'];
|
||||||
|
$redirect->to = $input['to'];
|
||||||
|
$redirect->mode = $input['mode'];
|
||||||
|
$redirect->status = RedirectStatus::CREATING;
|
||||||
|
$redirect->save();
|
||||||
|
|
||||||
|
dispatch(function () use ($site, $redirect): void {
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $site->server->webserver();
|
||||||
|
/** @var Webserver $webserver */
|
||||||
|
$webserver = $service->handler();
|
||||||
|
$webserver->updateVHost($site);
|
||||||
|
$redirect->status = RedirectStatus::READY;
|
||||||
|
$redirect->save();
|
||||||
|
})
|
||||||
|
->catch(function () use ($redirect): void {
|
||||||
|
$redirect->status = RedirectStatus::FAILED;
|
||||||
|
$redirect->save();
|
||||||
|
})
|
||||||
|
->onConnection('ssh');
|
||||||
|
|
||||||
|
return $redirect->refresh();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
|
public static function rules(Site $site): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'from' => [
|
||||||
|
'required',
|
||||||
|
'string',
|
||||||
|
'max:255',
|
||||||
|
'not_regex:/^http(s)?:\/\//',
|
||||||
|
Rule::unique('redirects', 'from')->where('site_id', $site->id),
|
||||||
|
],
|
||||||
|
'to' => [
|
||||||
|
'required',
|
||||||
|
'url:http,https',
|
||||||
|
],
|
||||||
|
'mode' => [
|
||||||
|
'required',
|
||||||
|
'integer',
|
||||||
|
Rule::in([
|
||||||
|
301,
|
||||||
|
302,
|
||||||
|
307,
|
||||||
|
308,
|
||||||
|
]),
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
30
app/Actions/Redirect/DeleteRedirect.php
Normal file
30
app/Actions/Redirect/DeleteRedirect.php
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\Redirect;
|
||||||
|
|
||||||
|
use App\Enums\RedirectStatus;
|
||||||
|
use App\Models\Redirect;
|
||||||
|
use App\Models\Service;
|
||||||
|
use App\Models\Site;
|
||||||
|
use App\SSH\Services\Webserver\Webserver;
|
||||||
|
|
||||||
|
class DeleteRedirect
|
||||||
|
{
|
||||||
|
public function delete(Site $site, Redirect $redirect): void
|
||||||
|
{
|
||||||
|
$redirect->status = RedirectStatus::DELETING;
|
||||||
|
$redirect->save();
|
||||||
|
|
||||||
|
dispatch(function () use ($site, $redirect): void {
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $site->server->webserver();
|
||||||
|
/** @var Webserver $webserver */
|
||||||
|
$webserver = $service->handler();
|
||||||
|
$webserver->updateVHost($site);
|
||||||
|
$redirect->delete();
|
||||||
|
})->catch(function () use ($redirect): void {
|
||||||
|
$redirect->status = RedirectStatus::FAILED;
|
||||||
|
$redirect->save();
|
||||||
|
})->onConnection('ssh');
|
||||||
|
}
|
||||||
|
}
|
16
app/Actions/SSL/ActivateSSL.php
Normal file
16
app/Actions/SSL/ActivateSSL.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\SSL;
|
||||||
|
|
||||||
|
use App\Models\Ssl;
|
||||||
|
|
||||||
|
class ActivateSSL
|
||||||
|
{
|
||||||
|
public function activate(Ssl $ssl): void
|
||||||
|
{
|
||||||
|
$ssl->site->ssls()->update(['is_active' => false]);
|
||||||
|
$ssl->is_active = true;
|
||||||
|
$ssl->save();
|
||||||
|
$ssl->site->webserver()->updateVHost($ssl->site);
|
||||||
|
}
|
||||||
|
}
|
@ -5,6 +5,7 @@
|
|||||||
use App\Enums\SslStatus;
|
use App\Enums\SslStatus;
|
||||||
use App\Enums\SslType;
|
use App\Enums\SslType;
|
||||||
use App\Models\ServerLog;
|
use App\Models\ServerLog;
|
||||||
|
use App\Models\Service;
|
||||||
use App\Models\Site;
|
use App\Models\Site;
|
||||||
use App\Models\Ssl;
|
use App\Models\Ssl;
|
||||||
use App\SSH\Services\Webserver\Webserver;
|
use App\SSH\Services\Webserver\Webserver;
|
||||||
@ -14,6 +15,8 @@
|
|||||||
class CreateSSL
|
class CreateSSL
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
public function create(Site $site, array $input): void
|
public function create(Site $site, array $input): void
|
||||||
@ -30,6 +33,8 @@ public function create(Site $site, array $input): void
|
|||||||
'pk' => $input['private'] ?? null,
|
'pk' => $input['private'] ?? null,
|
||||||
'expires_at' => $input['type'] === SslType::LETSENCRYPT ? now()->addMonths(3) : $input['expires_at'],
|
'expires_at' => $input['type'] === SslType::LETSENCRYPT ? now()->addMonths(3) : $input['expires_at'],
|
||||||
'status' => SslStatus::CREATING,
|
'status' => SslStatus::CREATING,
|
||||||
|
'email' => $input['email'] ?? null,
|
||||||
|
'is_active' => ! $site->activeSsl,
|
||||||
]);
|
]);
|
||||||
$ssl->domains = [$site->domain];
|
$ssl->domains = [$site->domain];
|
||||||
if (isset($input['aliases']) && $input['aliases']) {
|
if (isset($input['aliases']) && $input['aliases']) {
|
||||||
@ -38,19 +43,25 @@ public function create(Site $site, array $input): void
|
|||||||
$ssl->log_id = ServerLog::log($site->server, 'create-ssl', '', $site)->id;
|
$ssl->log_id = ServerLog::log($site->server, 'create-ssl', '', $site)->id;
|
||||||
$ssl->save();
|
$ssl->save();
|
||||||
|
|
||||||
dispatch(function () use ($site, $ssl) {
|
dispatch(function () use ($site, $ssl): void {
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $site->server->webserver();
|
||||||
/** @var Webserver $webserver */
|
/** @var Webserver $webserver */
|
||||||
$webserver = $site->server->webserver()->handler();
|
$webserver = $service->handler();
|
||||||
$webserver->setupSSL($ssl);
|
$webserver->setupSSL($ssl);
|
||||||
$ssl->status = SslStatus::CREATED;
|
$ssl->status = SslStatus::CREATED;
|
||||||
$ssl->save();
|
$ssl->save();
|
||||||
$site->type()->edit();
|
$webserver->updateVHost($site);
|
||||||
})->catch(function () use ($ssl) {
|
})->catch(function () use ($ssl): void {
|
||||||
$ssl->status = SslStatus::FAILED;
|
$ssl->status = SslStatus::FAILED;
|
||||||
$ssl->save();
|
$ssl->save();
|
||||||
})->onConnection('ssh');
|
})->onConnection('ssh');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, mixed>
|
||||||
|
*/
|
||||||
public static function rules(array $input): array
|
public static function rules(array $input): array
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
@ -68,6 +79,12 @@ public static function rules(array $input): array
|
|||||||
'after_or_equal:'.now(),
|
'after_or_equal:'.now(),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
if (isset($input['type']) && $input['type'] == SslType::LETSENCRYPT) {
|
||||||
|
$rules['email'] = [
|
||||||
|
'required',
|
||||||
|
'email',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
return $rules;
|
return $rules;
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,8 @@
|
|||||||
|
|
||||||
namespace App\Actions\SSL;
|
namespace App\Actions\SSL;
|
||||||
|
|
||||||
|
use App\Enums\SslStatus;
|
||||||
|
use App\Models\Service;
|
||||||
use App\Models\Ssl;
|
use App\Models\Ssl;
|
||||||
use App\SSH\Services\Webserver\Webserver;
|
use App\SSH\Services\Webserver\Webserver;
|
||||||
|
|
||||||
@ -9,8 +11,12 @@ class DeleteSSL
|
|||||||
{
|
{
|
||||||
public function delete(Ssl $ssl): void
|
public function delete(Ssl $ssl): void
|
||||||
{
|
{
|
||||||
|
$ssl->status = SslStatus::DELETING;
|
||||||
|
$ssl->save();
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $ssl->site->server->webserver();
|
||||||
/** @var Webserver $webserver */
|
/** @var Webserver $webserver */
|
||||||
$webserver = $ssl->site->server->webserver()->handler();
|
$webserver = $service->handler();
|
||||||
$webserver->removeSSL($ssl);
|
$webserver->removeSSL($ssl);
|
||||||
$ssl->delete();
|
$ssl->delete();
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,9 @@
|
|||||||
|
|
||||||
class CreateScript
|
class CreateScript
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function create(User $user, array $input): Script
|
public function create(User $user, array $input): Script
|
||||||
{
|
{
|
||||||
$script = new Script([
|
$script = new Script([
|
||||||
@ -20,6 +23,9 @@ public function create(User $user, array $input): Script
|
|||||||
return $script;
|
return $script;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(): array
|
public static function rules(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -7,6 +7,9 @@
|
|||||||
|
|
||||||
class EditScript
|
class EditScript
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function edit(Script $script, User $user, array $input): Script
|
public function edit(Script $script, User $user, array $input): Script
|
||||||
{
|
{
|
||||||
$script->name = $input['name'];
|
$script->name = $input['name'];
|
||||||
@ -18,6 +21,9 @@ public function edit(Script $script, User $user, array $input): Script
|
|||||||
return $script;
|
return $script;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(): array
|
public static function rules(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -11,6 +11,9 @@
|
|||||||
|
|
||||||
class ExecuteScript
|
class ExecuteScript
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function execute(Script $script, array $input): ScriptExecution
|
public function execute(Script $script, array $input): ScriptExecution
|
||||||
{
|
{
|
||||||
$execution = new ScriptExecution([
|
$execution = new ScriptExecution([
|
||||||
@ -22,16 +25,19 @@ public function execute(Script $script, array $input): ScriptExecution
|
|||||||
]);
|
]);
|
||||||
$execution->save();
|
$execution->save();
|
||||||
|
|
||||||
dispatch(function () use ($execution, $script) {
|
dispatch(function () use ($execution, $script): void {
|
||||||
|
/** @var Server $server */
|
||||||
|
$server = $execution->server;
|
||||||
|
|
||||||
$content = $execution->getContent();
|
$content = $execution->getContent();
|
||||||
$log = ServerLog::make($execution->server, 'script-'.$script->id.'-'.strtotime('now'));
|
$log = ServerLog::newLog($server, 'script-'.$script->id.'-'.strtotime('now'));
|
||||||
$log->save();
|
$log->save();
|
||||||
$execution->server_log_id = $log->id;
|
$execution->server_log_id = $log->id;
|
||||||
$execution->save();
|
$execution->save();
|
||||||
$execution->server->os()->runScript('~/', $content, $log, $execution->user);
|
$server->os()->runScript('~/', $content, $log, $execution->user);
|
||||||
$execution->status = ScriptExecutionStatus::COMPLETED;
|
$execution->status = ScriptExecutionStatus::COMPLETED;
|
||||||
$execution->save();
|
$execution->save();
|
||||||
})->catch(function () use ($execution) {
|
})->catch(function () use ($execution): void {
|
||||||
$execution->status = ScriptExecutionStatus::FAILED;
|
$execution->status = ScriptExecutionStatus::FAILED;
|
||||||
$execution->save();
|
$execution->save();
|
||||||
})->onConnection('ssh');
|
})->onConnection('ssh');
|
||||||
@ -39,11 +45,17 @@ public function execute(Script $script, array $input): ScriptExecution
|
|||||||
return $execution;
|
return $execution;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, mixed>
|
||||||
|
*/
|
||||||
public static function rules(array $input): array
|
public static function rules(array $input): array
|
||||||
{
|
{
|
||||||
|
$users = ['root'];
|
||||||
if (isset($input['server'])) {
|
if (isset($input['server'])) {
|
||||||
/** @var ?Server $server */
|
/** @var Server $server */
|
||||||
$server = Server::query()->find($input['server']);
|
$server = Server::query()->findOrFail($input['server']);
|
||||||
|
$users = $server->getSshUsers();
|
||||||
}
|
}
|
||||||
|
|
||||||
return [
|
return [
|
||||||
@ -53,10 +65,7 @@ public static function rules(array $input): array
|
|||||||
],
|
],
|
||||||
'user' => [
|
'user' => [
|
||||||
'required',
|
'required',
|
||||||
Rule::in([
|
Rule::in($users),
|
||||||
'root',
|
|
||||||
isset($server) ? $server?->ssh_user : null,
|
|
||||||
]),
|
|
||||||
],
|
],
|
||||||
'variables' => 'array',
|
'variables' => 'array',
|
||||||
'variables.*' => [
|
'variables.*' => [
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
use App\Enums\ServerProvider;
|
use App\Enums\ServerProvider;
|
||||||
use App\Enums\ServerStatus;
|
use App\Enums\ServerStatus;
|
||||||
use App\Enums\ServerType;
|
use App\Enums\ServerType;
|
||||||
|
use App\Exceptions\SSHConnectionError;
|
||||||
use App\Facades\Notifier;
|
use App\Facades\Notifier;
|
||||||
use App\Models\Project;
|
use App\Models\Project;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
@ -15,7 +16,6 @@
|
|||||||
use App\ValidationRules\RestrictedIPAddressesRule;
|
use App\ValidationRules\RestrictedIPAddressesRule;
|
||||||
use Exception;
|
use Exception;
|
||||||
use Illuminate\Database\Query\Builder;
|
use Illuminate\Database\Query\Builder;
|
||||||
use Illuminate\Support\Facades\Bus;
|
|
||||||
use Illuminate\Support\Facades\Log;
|
use Illuminate\Support\Facades\Log;
|
||||||
use Illuminate\Support\Str;
|
use Illuminate\Support\Str;
|
||||||
use Illuminate\Validation\Rule;
|
use Illuminate\Validation\Rule;
|
||||||
@ -24,6 +24,9 @@
|
|||||||
|
|
||||||
class CreateServer
|
class CreateServer
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function create(User $creator, Project $project, array $input): Server
|
public function create(User $creator, Project $project, array $input): Server
|
||||||
{
|
{
|
||||||
$server = new Server([
|
$server = new Server([
|
||||||
@ -81,36 +84,43 @@ public function create(User $creator, Project $project, array $input): Server
|
|||||||
|
|
||||||
private function install(Server $server): void
|
private function install(Server $server): void
|
||||||
{
|
{
|
||||||
$bus = Bus::chain([
|
dispatch(function () use ($server): void {
|
||||||
function () use ($server) {
|
$maxWait = 180;
|
||||||
|
while ($maxWait > 0) {
|
||||||
|
sleep(10);
|
||||||
|
$maxWait -= 10;
|
||||||
if (! $server->provider()->isRunning()) {
|
if (! $server->provider()->isRunning()) {
|
||||||
sleep(2);
|
continue;
|
||||||
}
|
}
|
||||||
$server->type()->install();
|
try {
|
||||||
$server->update([
|
$server->ssh()->connect();
|
||||||
'status' => ServerStatus::READY,
|
break;
|
||||||
]);
|
} catch (SSHConnectionError) {
|
||||||
Notifier::send($server, new ServerInstallationSucceed($server));
|
// ignore
|
||||||
},
|
}
|
||||||
])->catch(function (Throwable $e) use ($server) {
|
}
|
||||||
|
$server->type()->install();
|
||||||
$server->update([
|
$server->update([
|
||||||
'status' => ServerStatus::INSTALLATION_FAILED,
|
'status' => ServerStatus::READY,
|
||||||
]);
|
]);
|
||||||
Notifier::send($server, new ServerInstallationFailed($server));
|
Notifier::send($server, new ServerInstallationSucceed($server));
|
||||||
Log::error('server-installation-error', [
|
})
|
||||||
'error' => (string) $e,
|
->catch(function (Throwable $e) use ($server): void {
|
||||||
]);
|
$server->update([
|
||||||
});
|
'status' => ServerStatus::INSTALLATION_FAILED,
|
||||||
|
]);
|
||||||
if ($server->provider != ServerProvider::CUSTOM) {
|
Notifier::send($server, new ServerInstallationFailed($server));
|
||||||
$server->progress_step = 'waiting-for-provider';
|
Log::error('server-installation-error', [
|
||||||
$server->save();
|
'error' => (string) $e,
|
||||||
$bus->delay(now()->addMinutes(3));
|
]);
|
||||||
}
|
})
|
||||||
|
->onConnection('ssh');
|
||||||
$bus->onConnection('ssh')->dispatch();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, mixed>
|
||||||
|
*/
|
||||||
public static function rules(Project $project, array $input): array
|
public static function rules(Project $project, array $input): array
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
@ -126,28 +136,22 @@ public static function rules(Project $project, array $input): array
|
|||||||
Rule::in(config('core.operating_systems')),
|
Rule::in(config('core.operating_systems')),
|
||||||
],
|
],
|
||||||
'server_provider' => [
|
'server_provider' => [
|
||||||
Rule::when(function () use ($input) {
|
Rule::when(fn (): bool => isset($input['provider']) && $input['provider'] != ServerProvider::CUSTOM, [
|
||||||
return isset($input['provider']) && $input['provider'] != ServerProvider::CUSTOM;
|
|
||||||
}, [
|
|
||||||
'required',
|
'required',
|
||||||
Rule::exists('server_providers', 'id')->where(function (Builder $query) use ($project) {
|
Rule::exists('server_providers', 'id')->where(function (Builder $query) use ($project): void {
|
||||||
$query->where('project_id', $project->id)
|
$query->where('project_id', $project->id)
|
||||||
->orWhereNull('project_id');
|
->orWhereNull('project_id');
|
||||||
}),
|
}),
|
||||||
]),
|
]),
|
||||||
],
|
],
|
||||||
'ip' => [
|
'ip' => [
|
||||||
Rule::when(function () use ($input) {
|
Rule::when(fn (): bool => isset($input['provider']) && $input['provider'] == ServerProvider::CUSTOM, [
|
||||||
return isset($input['provider']) && $input['provider'] == ServerProvider::CUSTOM;
|
|
||||||
}, [
|
|
||||||
'required',
|
'required',
|
||||||
new RestrictedIPAddressesRule,
|
new RestrictedIPAddressesRule,
|
||||||
]),
|
]),
|
||||||
],
|
],
|
||||||
'port' => [
|
'port' => [
|
||||||
Rule::when(function () use ($input) {
|
Rule::when(fn (): bool => isset($input['provider']) && $input['provider'] == ServerProvider::CUSTOM, [
|
||||||
return isset($input['provider']) && $input['provider'] == ServerProvider::CUSTOM;
|
|
||||||
}, [
|
|
||||||
'required',
|
'required',
|
||||||
'numeric',
|
'numeric',
|
||||||
'min:1',
|
'min:1',
|
||||||
@ -159,6 +163,10 @@ public static function rules(Project $project, array $input): array
|
|||||||
return array_merge($rules, self::typeRules($input), self::providerRules($input));
|
return array_merge($rules, self::typeRules($input), self::providerRules($input));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
private static function typeRules(array $input): array
|
private static function typeRules(array $input): array
|
||||||
{
|
{
|
||||||
if (! isset($input['type']) || ! in_array($input['type'], config('core.server_types'))) {
|
if (! isset($input['type']) || ! in_array($input['type'], config('core.server_types'))) {
|
||||||
@ -170,6 +178,10 @@ private static function typeRules(array $input): array
|
|||||||
return $server->type()->createRules($input);
|
return $server->type()->createRules($input);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
private static function providerRules(array $input): array
|
private static function providerRules(array $input): array
|
||||||
{
|
{
|
||||||
if (
|
if (
|
||||||
@ -194,26 +206,29 @@ public function createFirewallRules(Server $server): void
|
|||||||
$server->firewallRules()->createMany([
|
$server->firewallRules()->createMany([
|
||||||
[
|
[
|
||||||
'type' => 'allow',
|
'type' => 'allow',
|
||||||
'protocol' => 'ssh',
|
'name' => 'SSH',
|
||||||
|
'protocol' => 'tcp',
|
||||||
'port' => 22,
|
'port' => 22,
|
||||||
'source' => '0.0.0.0',
|
'source' => null,
|
||||||
'mask' => 0,
|
'mask' => null,
|
||||||
'status' => FirewallRuleStatus::READY,
|
'status' => FirewallRuleStatus::READY,
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'type' => 'allow',
|
'type' => 'allow',
|
||||||
'protocol' => 'http',
|
'name' => 'HTTP',
|
||||||
|
'protocol' => 'tcp',
|
||||||
'port' => 80,
|
'port' => 80,
|
||||||
'source' => '0.0.0.0',
|
'source' => null,
|
||||||
'mask' => 0,
|
'mask' => null,
|
||||||
'status' => FirewallRuleStatus::READY,
|
'status' => FirewallRuleStatus::READY,
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'type' => 'allow',
|
'type' => 'allow',
|
||||||
'protocol' => 'https',
|
'name' => 'HTTPS',
|
||||||
|
'protocol' => 'tcp',
|
||||||
'port' => 443,
|
'port' => 443,
|
||||||
'source' => '0.0.0.0',
|
'source' => null,
|
||||||
'mask' => 0,
|
'mask' => null,
|
||||||
'status' => FirewallRuleStatus::READY,
|
'status' => FirewallRuleStatus::READY,
|
||||||
],
|
],
|
||||||
]);
|
]);
|
||||||
|
@ -8,6 +8,8 @@
|
|||||||
class CreateServerLog
|
class CreateServerLog
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
public function create(Server $server, array $input): void
|
public function create(Server $server, array $input): void
|
||||||
@ -20,6 +22,9 @@ public function create(Server $server, array $input): void
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, string>
|
||||||
|
*/
|
||||||
public static function rules(): array
|
public static function rules(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -10,6 +10,9 @@
|
|||||||
class EditServer
|
class EditServer
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return Server $server
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
public function edit(Server $server, array $input): Server
|
public function edit(Server $server, array $input): Server
|
||||||
@ -24,6 +27,9 @@ public function edit(Server $server, array $input): Server
|
|||||||
}
|
}
|
||||||
$server->ip = $input['ip'];
|
$server->ip = $input['ip'];
|
||||||
}
|
}
|
||||||
|
if (isset($input['local_ip'])) {
|
||||||
|
$server->local_ip = $input['local_ip'];
|
||||||
|
}
|
||||||
if (isset($input['port'])) {
|
if (isset($input['port'])) {
|
||||||
if ($server->port !== $input['port']) {
|
if ($server->port !== $input['port']) {
|
||||||
$checkConnection = true;
|
$checkConnection = true;
|
||||||
@ -39,6 +45,9 @@ public function edit(Server $server, array $input): Server
|
|||||||
return $server;
|
return $server;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<int, mixed>>
|
||||||
|
*/
|
||||||
public static function rules(Server $server): array
|
public static function rules(Server $server): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
@ -52,6 +61,10 @@ public static function rules(Server $server): array
|
|||||||
new RestrictedIPAddressesRule,
|
new RestrictedIPAddressesRule,
|
||||||
Rule::unique('servers')->where('project_id', $server->project_id)->ignore($server->id),
|
Rule::unique('servers')->where('project_id', $server->project_id)->ignore($server->id),
|
||||||
],
|
],
|
||||||
|
'local_ip' => [
|
||||||
|
'string',
|
||||||
|
Rule::unique('servers')->where('project_id', $server->project_id)->ignore($server->id),
|
||||||
|
],
|
||||||
'port' => [
|
'port' => [
|
||||||
'integer',
|
'integer',
|
||||||
'min:1',
|
'min:1',
|
||||||
|
@ -13,11 +13,11 @@ public function update(Server $server): void
|
|||||||
{
|
{
|
||||||
$server->status = ServerStatus::UPDATING;
|
$server->status = ServerStatus::UPDATING;
|
||||||
$server->save();
|
$server->save();
|
||||||
dispatch(function () use ($server) {
|
dispatch(function () use ($server): void {
|
||||||
$server->os()->upgrade();
|
$server->os()->upgrade();
|
||||||
$server->checkConnection();
|
$server->checkConnection();
|
||||||
$server->checkForUpdates();
|
$server->checkForUpdates();
|
||||||
})->catch(function () use ($server) {
|
})->catch(function () use ($server): void {
|
||||||
Notifier::send($server, new ServerUpdateFailed($server));
|
Notifier::send($server, new ServerUpdateFailed($server));
|
||||||
$server->checkConnection();
|
$server->checkConnection();
|
||||||
})->onConnection('ssh');
|
})->onConnection('ssh');
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
namespace App\Actions\ServerProvider;
|
namespace App\Actions\ServerProvider;
|
||||||
|
|
||||||
use App\Models\Project;
|
use App\Models\Project;
|
||||||
|
use App\Models\Server;
|
||||||
use App\Models\ServerProvider;
|
use App\Models\ServerProvider;
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
use App\ServerProviders\ServerProvider as ServerProviderContract;
|
use App\ServerProviders\ServerProvider as ServerProviderContract;
|
||||||
@ -13,11 +14,13 @@
|
|||||||
class CreateServerProvider
|
class CreateServerProvider
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
* @throws ValidationException
|
* @throws ValidationException
|
||||||
*/
|
*/
|
||||||
public function create(User $user, Project $project, array $input): ServerProvider
|
public function create(User $user, Project $project, array $input): ServerProvider
|
||||||
{
|
{
|
||||||
$provider = static::getProvider($input['provider']);
|
$provider = self::getProvider($input['provider']);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$provider->connect($input);
|
$provider->connect($input);
|
||||||
@ -40,13 +43,19 @@ public function create(User $user, Project $project, array $input): ServerProvid
|
|||||||
return $serverProvider;
|
return $serverProvider;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function getProvider($name): ServerProviderContract
|
private static function getProvider(string $name): ServerProviderContract
|
||||||
{
|
{
|
||||||
$providerClass = config('core.server_providers_class.'.$name);
|
$providerClass = config('core.server_providers_class.'.$name);
|
||||||
|
/** @var ServerProviderContract $provider */
|
||||||
|
$provider = new $providerClass(new ServerProvider, new Server);
|
||||||
|
|
||||||
return new $providerClass;
|
return $provider;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, mixed>
|
||||||
|
*/
|
||||||
public static function rules(array $input): array
|
public static function rules(array $input): array
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
@ -60,15 +69,19 @@ public static function rules(array $input): array
|
|||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
return array_merge($rules, static::providerRules($input));
|
return array_merge($rules, self::providerRules($input));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
private static function providerRules(array $input): array
|
private static function providerRules(array $input): array
|
||||||
{
|
{
|
||||||
if (! isset($input['provider'])) {
|
if (! isset($input['provider'])) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
return static::getProvider($input['provider'])->credentialValidationRules($input);
|
return self::getProvider($input['provider'])->credentialValidationRules($input);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,9 @@
|
|||||||
|
|
||||||
class EditServerProvider
|
class EditServerProvider
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function edit(ServerProvider $serverProvider, Project $project, array $input): ServerProvider
|
public function edit(ServerProvider $serverProvider, Project $project, array $input): ServerProvider
|
||||||
{
|
{
|
||||||
$serverProvider->profile = $input['name'];
|
$serverProvider->profile = $input['name'];
|
||||||
@ -17,6 +20,9 @@ public function edit(ServerProvider $serverProvider, Project $project, array $in
|
|||||||
return $serverProvider;
|
return $serverProvider;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(): array
|
public static function rules(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -10,6 +10,9 @@
|
|||||||
|
|
||||||
class Install
|
class Install
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function install(Server $server, array $input): Service
|
public function install(Server $server, array $input): Service
|
||||||
{
|
{
|
||||||
$input['type'] = config('core.service_types')[$input['name']];
|
$input['type'] = config('core.service_types')[$input['name']];
|
||||||
@ -28,11 +31,11 @@ public function install(Server $server, array $input): Service
|
|||||||
|
|
||||||
$service->save();
|
$service->save();
|
||||||
|
|
||||||
dispatch(function () use ($service) {
|
dispatch(function () use ($service): void {
|
||||||
$service->handler()->install();
|
$service->handler()->install();
|
||||||
$service->status = ServiceStatus::READY;
|
$service->status = ServiceStatus::READY;
|
||||||
$service->save();
|
$service->save();
|
||||||
})->catch(function () use ($service) {
|
})->catch(function () use ($service): void {
|
||||||
$service->status = ServiceStatus::INSTALLATION_FAILED;
|
$service->status = ServiceStatus::INSTALLATION_FAILED;
|
||||||
$service->save();
|
$service->save();
|
||||||
})->onConnection('ssh');
|
})->onConnection('ssh');
|
||||||
@ -40,6 +43,10 @@ public function install(Server $server, array $input): Service
|
|||||||
return $service;
|
return $service;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, array<int, mixed>>
|
||||||
|
*/
|
||||||
public static function rules(array $input): array
|
public static function rules(array $input): array
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
|
@ -11,7 +11,7 @@ public function start(Service $service): void
|
|||||||
{
|
{
|
||||||
$service->status = ServiceStatus::STARTING;
|
$service->status = ServiceStatus::STARTING;
|
||||||
$service->save();
|
$service->save();
|
||||||
dispatch(function () use ($service) {
|
dispatch(function () use ($service): void {
|
||||||
$status = $service->server->systemd()->start($service->unit);
|
$status = $service->server->systemd()->start($service->unit);
|
||||||
if (str($status)->contains('Active: active')) {
|
if (str($status)->contains('Active: active')) {
|
||||||
$service->status = ServiceStatus::READY;
|
$service->status = ServiceStatus::READY;
|
||||||
@ -26,7 +26,7 @@ public function stop(Service $service): void
|
|||||||
{
|
{
|
||||||
$service->status = ServiceStatus::STOPPING;
|
$service->status = ServiceStatus::STOPPING;
|
||||||
$service->save();
|
$service->save();
|
||||||
dispatch(function () use ($service) {
|
dispatch(function () use ($service): void {
|
||||||
$status = $service->server->systemd()->stop($service->unit);
|
$status = $service->server->systemd()->stop($service->unit);
|
||||||
if (str($status)->contains('Active: inactive')) {
|
if (str($status)->contains('Active: inactive')) {
|
||||||
$service->status = ServiceStatus::STOPPED;
|
$service->status = ServiceStatus::STOPPED;
|
||||||
@ -41,7 +41,7 @@ public function restart(Service $service): void
|
|||||||
{
|
{
|
||||||
$service->status = ServiceStatus::RESTARTING;
|
$service->status = ServiceStatus::RESTARTING;
|
||||||
$service->save();
|
$service->save();
|
||||||
dispatch(function () use ($service) {
|
dispatch(function () use ($service): void {
|
||||||
$status = $service->server->systemd()->restart($service->unit);
|
$status = $service->server->systemd()->restart($service->unit);
|
||||||
if (str($status)->contains('Active: active')) {
|
if (str($status)->contains('Active: active')) {
|
||||||
$service->status = ServiceStatus::READY;
|
$service->status = ServiceStatus::READY;
|
||||||
@ -56,7 +56,7 @@ public function enable(Service $service): void
|
|||||||
{
|
{
|
||||||
$service->status = ServiceStatus::ENABLING;
|
$service->status = ServiceStatus::ENABLING;
|
||||||
$service->save();
|
$service->save();
|
||||||
dispatch(function () use ($service) {
|
dispatch(function () use ($service): void {
|
||||||
$status = $service->server->systemd()->enable($service->unit);
|
$status = $service->server->systemd()->enable($service->unit);
|
||||||
if (str($status)->contains('Active: active')) {
|
if (str($status)->contains('Active: active')) {
|
||||||
$service->status = ServiceStatus::READY;
|
$service->status = ServiceStatus::READY;
|
||||||
@ -71,7 +71,7 @@ public function disable(Service $service): void
|
|||||||
{
|
{
|
||||||
$service->status = ServiceStatus::DISABLING;
|
$service->status = ServiceStatus::DISABLING;
|
||||||
$service->save();
|
$service->save();
|
||||||
dispatch(function () use ($service) {
|
dispatch(function () use ($service): void {
|
||||||
$status = $service->server->systemd()->disable($service->unit);
|
$status = $service->server->systemd()->disable($service->unit);
|
||||||
if (str($status)->contains('Active: inactive')) {
|
if (str($status)->contains('Active: inactive')) {
|
||||||
$service->status = ServiceStatus::DISABLED;
|
$service->status = ServiceStatus::DISABLED;
|
||||||
|
@ -20,10 +20,10 @@ public function uninstall(Service $service): void
|
|||||||
$service->status = ServiceStatus::UNINSTALLING;
|
$service->status = ServiceStatus::UNINSTALLING;
|
||||||
$service->save();
|
$service->save();
|
||||||
|
|
||||||
dispatch(function () use ($service) {
|
dispatch(function () use ($service): void {
|
||||||
$service->handler()->uninstall();
|
$service->handler()->uninstall();
|
||||||
$service->delete();
|
$service->delete();
|
||||||
})->catch(function () use ($service) {
|
})->catch(function () use ($service): void {
|
||||||
$service->status = ServiceStatus::FAILED;
|
$service->status = ServiceStatus::FAILED;
|
||||||
$service->save();
|
$service->save();
|
||||||
})->onConnection('ssh');
|
})->onConnection('ssh');
|
||||||
|
35
app/Actions/Site/CreateCommand.php
Normal file
35
app/Actions/Site/CreateCommand.php
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\Site;
|
||||||
|
|
||||||
|
use App\Models\Command;
|
||||||
|
use App\Models\Site;
|
||||||
|
|
||||||
|
class CreateCommand
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
|
public function create(Site $site, array $input): Command
|
||||||
|
{
|
||||||
|
$script = new Command([
|
||||||
|
'site_id' => $site->id,
|
||||||
|
'name' => $input['name'],
|
||||||
|
'command' => $input['command'],
|
||||||
|
]);
|
||||||
|
$script->save();
|
||||||
|
|
||||||
|
return $script;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
|
public static function rules(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'name' => ['required', 'string', 'max:255'],
|
||||||
|
'command' => ['required', 'string'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
@ -19,16 +19,23 @@
|
|||||||
|
|
||||||
class CreateSite
|
class CreateSite
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws ValidationException
|
||||||
|
*/
|
||||||
public function create(Server $server, array $input): Site
|
public function create(Server $server, array $input): Site
|
||||||
{
|
{
|
||||||
DB::beginTransaction();
|
DB::beginTransaction();
|
||||||
try {
|
try {
|
||||||
|
$user = $input['user'] ?? $server->getSshUser();
|
||||||
$site = new Site([
|
$site = new Site([
|
||||||
'server_id' => $server->id,
|
'server_id' => $server->id,
|
||||||
'type' => $input['type'],
|
'type' => $input['type'],
|
||||||
'domain' => $input['domain'],
|
'domain' => $input['domain'],
|
||||||
'aliases' => $input['aliases'] ?? [],
|
'aliases' => $input['aliases'] ?? [],
|
||||||
'path' => '/home/'.$server->getSshUser().'/'.$input['domain'],
|
'user' => $user,
|
||||||
|
'path' => '/home/'.$user.'/'.$input['domain'],
|
||||||
'status' => SiteStatus::INSTALLING,
|
'status' => SiteStatus::INSTALLING,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
@ -38,7 +45,7 @@ public function create(Server $server, array $input): Site
|
|||||||
// check has access to repository
|
// check has access to repository
|
||||||
try {
|
try {
|
||||||
if ($site->sourceControl) {
|
if ($site->sourceControl) {
|
||||||
$site->sourceControl?->getRepo($site->repository);
|
$site->sourceControl->getRepo($site->repository);
|
||||||
}
|
}
|
||||||
} catch (SourceControlIsNotConnected) {
|
} catch (SourceControlIsNotConnected) {
|
||||||
throw ValidationException::withMessages([
|
throw ValidationException::withMessages([
|
||||||
@ -66,15 +73,18 @@ public function create(Server $server, array $input): Site
|
|||||||
'content' => '',
|
'content' => '',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
// create base commands if any
|
||||||
|
$site->commands()->createMany($site->type()->baseCommands());
|
||||||
|
|
||||||
// install site
|
// install site
|
||||||
dispatch(function () use ($site) {
|
dispatch(function () use ($site): void {
|
||||||
$site->type()->install();
|
$site->type()->install();
|
||||||
$site->update([
|
$site->update([
|
||||||
'status' => SiteStatus::READY,
|
'status' => SiteStatus::READY,
|
||||||
'progress' => 100,
|
'progress' => 100,
|
||||||
]);
|
]);
|
||||||
Notifier::send($site, new SiteInstallationSucceed($site));
|
Notifier::send($site, new SiteInstallationSucceed($site));
|
||||||
})->catch(function () use ($site) {
|
})->catch(function () use ($site): void {
|
||||||
$site->status = SiteStatus::INSTALLATION_FAILED;
|
$site->status = SiteStatus::INSTALLATION_FAILED;
|
||||||
$site->save();
|
$site->save();
|
||||||
Notifier::send($site, new SiteInstallationFailed($site));
|
Notifier::send($site, new SiteInstallationFailed($site));
|
||||||
@ -91,6 +101,10 @@ public function create(Server $server, array $input): Site
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, mixed>
|
||||||
|
*/
|
||||||
public static function rules(Server $server, array $input): array
|
public static function rules(Server $server, array $input): array
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
@ -101,18 +115,27 @@ public static function rules(Server $server, array $input): array
|
|||||||
'domain' => [
|
'domain' => [
|
||||||
'required',
|
'required',
|
||||||
new DomainRule,
|
new DomainRule,
|
||||||
Rule::unique('sites', 'domain')->where(function ($query) use ($server) {
|
Rule::unique('sites', 'domain')->where(fn ($query) => $query->where('server_id', $server->id)),
|
||||||
return $query->where('server_id', $server->id);
|
|
||||||
}),
|
|
||||||
],
|
],
|
||||||
'aliases.*' => [
|
'aliases.*' => [
|
||||||
new DomainRule,
|
new DomainRule,
|
||||||
],
|
],
|
||||||
|
'user' => [
|
||||||
|
'regex:/^[a-z_][a-z0-9_-]*[a-z0-9]$/',
|
||||||
|
'min:3',
|
||||||
|
'max:32',
|
||||||
|
Rule::unique('sites', 'user')->where('server_id', $server->id),
|
||||||
|
Rule::notIn($server->getSshUsers()),
|
||||||
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
return array_merge($rules, self::typeRules($server, $input));
|
return array_merge($rules, self::typeRules($server, $input));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
private static function typeRules(Server $server, array $input): array
|
private static function typeRules(Server $server, array $input): array
|
||||||
{
|
{
|
||||||
if (! isset($input['type']) || ! in_array($input['type'], config('core.site_types'))) {
|
if (! isset($input['type']) || ! in_array($input['type'], config('core.site_types'))) {
|
||||||
|
@ -2,16 +2,37 @@
|
|||||||
|
|
||||||
namespace App\Actions\Site;
|
namespace App\Actions\Site;
|
||||||
|
|
||||||
|
use App\Exceptions\SSHError;
|
||||||
|
use App\Models\Service;
|
||||||
use App\Models\Site;
|
use App\Models\Site;
|
||||||
|
use App\SSH\Services\PHP\PHP;
|
||||||
use App\SSH\Services\Webserver\Webserver;
|
use App\SSH\Services\Webserver\Webserver;
|
||||||
|
|
||||||
class DeleteSite
|
class DeleteSite
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @throws SSHError
|
||||||
|
*/
|
||||||
public function delete(Site $site): void
|
public function delete(Site $site): void
|
||||||
{
|
{
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $site->server->webserver();
|
||||||
|
|
||||||
/** @var Webserver $webserverHandler */
|
/** @var Webserver $webserverHandler */
|
||||||
$webserverHandler = $site->server->webserver()->handler();
|
$webserverHandler = $service->handler();
|
||||||
$webserverHandler->deleteSite($site);
|
$webserverHandler->deleteSite($site);
|
||||||
|
|
||||||
|
if ($site->isIsolated()) {
|
||||||
|
/** @var Service $phpService */
|
||||||
|
$phpService = $site->server->php();
|
||||||
|
/** @var PHP $php */
|
||||||
|
$php = $phpService->handler();
|
||||||
|
$php->removeFpmPool($site->user, $site->php_version, $site->id);
|
||||||
|
|
||||||
|
$os = $site->server->os();
|
||||||
|
$os->deleteIsolatedUser($site->user);
|
||||||
|
}
|
||||||
|
|
||||||
$site->delete();
|
$site->delete();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,16 +4,18 @@
|
|||||||
|
|
||||||
use App\Enums\DeploymentStatus;
|
use App\Enums\DeploymentStatus;
|
||||||
use App\Exceptions\DeploymentScriptIsEmptyException;
|
use App\Exceptions\DeploymentScriptIsEmptyException;
|
||||||
use App\Exceptions\SourceControlIsNotConnected;
|
use App\Exceptions\SSHError;
|
||||||
|
use App\Facades\Notifier;
|
||||||
use App\Models\Deployment;
|
use App\Models\Deployment;
|
||||||
use App\Models\ServerLog;
|
use App\Models\ServerLog;
|
||||||
use App\Models\Site;
|
use App\Models\Site;
|
||||||
|
use App\Notifications\DeploymentCompleted;
|
||||||
|
|
||||||
class Deploy
|
class Deploy
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @throws SourceControlIsNotConnected
|
|
||||||
* @throws DeploymentScriptIsEmptyException
|
* @throws DeploymentScriptIsEmptyException
|
||||||
|
* @throws SSHError
|
||||||
*/
|
*/
|
||||||
public function run(Site $site): Deployment
|
public function run(Site $site): Deployment
|
||||||
{
|
{
|
||||||
@ -37,9 +39,8 @@ public function run(Site $site): Deployment
|
|||||||
}
|
}
|
||||||
$deployment->save();
|
$deployment->save();
|
||||||
|
|
||||||
dispatch(function () use ($site, $deployment) {
|
dispatch(function () use ($site, $deployment): void {
|
||||||
/** @var ServerLog $log */
|
$log = ServerLog::newLog($site->server, 'deploy-'.strtotime('now'))
|
||||||
$log = ServerLog::make($site->server, 'deploy-'.strtotime('now'))
|
|
||||||
->forSite($site);
|
->forSite($site);
|
||||||
$log->save();
|
$log->save();
|
||||||
$deployment->log_id = $log->id;
|
$deployment->log_id = $log->id;
|
||||||
@ -48,13 +49,16 @@ public function run(Site $site): Deployment
|
|||||||
path: $site->path,
|
path: $site->path,
|
||||||
script: $site->deploymentScript->content,
|
script: $site->deploymentScript->content,
|
||||||
serverLog: $log,
|
serverLog: $log,
|
||||||
variables: $site->environmentVariables($deployment)
|
user: $site->user,
|
||||||
|
variables: $site->environmentVariables($deployment),
|
||||||
);
|
);
|
||||||
$deployment->status = DeploymentStatus::FINISHED;
|
$deployment->status = DeploymentStatus::FINISHED;
|
||||||
$deployment->save();
|
$deployment->save();
|
||||||
})->catch(function () use ($deployment) {
|
Notifier::send($site, new DeploymentCompleted($deployment, $site));
|
||||||
|
})->catch(function () use ($deployment, $site): void {
|
||||||
$deployment->status = DeploymentStatus::FAILED;
|
$deployment->status = DeploymentStatus::FAILED;
|
||||||
$deployment->save();
|
$deployment->save();
|
||||||
|
Notifier::send($site, new DeploymentCompleted($deployment, $site));
|
||||||
})->onConnection('ssh');
|
})->onConnection('ssh');
|
||||||
|
|
||||||
return $deployment;
|
return $deployment;
|
||||||
|
31
app/Actions/Site/EditCommand.php
Normal file
31
app/Actions/Site/EditCommand.php
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\Site;
|
||||||
|
|
||||||
|
use App\Models\Command;
|
||||||
|
|
||||||
|
class EditCommand
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
|
public function edit(Command $command, array $input): Command
|
||||||
|
{
|
||||||
|
$command->name = $input['name'];
|
||||||
|
$command->command = $input['command'];
|
||||||
|
$command->save();
|
||||||
|
|
||||||
|
return $command;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
|
public static function rules(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'name' => ['required', 'string', 'max:255'],
|
||||||
|
'command' => ['required', 'string'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
65
app/Actions/Site/ExecuteCommand.php
Normal file
65
app/Actions/Site/ExecuteCommand.php
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\Site;
|
||||||
|
|
||||||
|
use App\Enums\CommandExecutionStatus;
|
||||||
|
use App\Models\Command;
|
||||||
|
use App\Models\CommandExecution;
|
||||||
|
use App\Models\ServerLog;
|
||||||
|
use App\Models\User;
|
||||||
|
|
||||||
|
class ExecuteCommand
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
|
public function execute(Command $command, User $user, array $input): CommandExecution
|
||||||
|
{
|
||||||
|
$execution = new CommandExecution([
|
||||||
|
'command_id' => $command->id,
|
||||||
|
'server_id' => $command->site->server_id,
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'variables' => $input['variables'] ?? [],
|
||||||
|
'status' => CommandExecutionStatus::EXECUTING,
|
||||||
|
]);
|
||||||
|
$execution->save();
|
||||||
|
|
||||||
|
dispatch(function () use ($execution, $command): void {
|
||||||
|
$content = $execution->getContent();
|
||||||
|
$log = ServerLog::newLog($execution->server, 'command-'.$command->id.'-'.strtotime('now'));
|
||||||
|
$log->save();
|
||||||
|
$execution->server_log_id = $log->id;
|
||||||
|
$execution->save();
|
||||||
|
$execution->server->os()->runScript(
|
||||||
|
path: $command->site->path,
|
||||||
|
script: $content,
|
||||||
|
serverLog: $log,
|
||||||
|
user: $command->site->user,
|
||||||
|
variables: $execution->variables
|
||||||
|
);
|
||||||
|
$execution->status = CommandExecutionStatus::COMPLETED;
|
||||||
|
$execution->save();
|
||||||
|
})->catch(function () use ($execution): void {
|
||||||
|
$execution->status = CommandExecutionStatus::FAILED;
|
||||||
|
$execution->save();
|
||||||
|
})->onConnection('ssh');
|
||||||
|
|
||||||
|
return $execution;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
* @return array<string, string|array<int, mixed>>
|
||||||
|
*/
|
||||||
|
public static function rules(array $input): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'variables' => 'array',
|
||||||
|
'variables.*' => [
|
||||||
|
'required',
|
||||||
|
'string',
|
||||||
|
'max:255',
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
@ -2,23 +2,33 @@
|
|||||||
|
|
||||||
namespace App\Actions\Site;
|
namespace App\Actions\Site;
|
||||||
|
|
||||||
|
use App\Models\Service;
|
||||||
use App\Models\Site;
|
use App\Models\Site;
|
||||||
use App\SSH\Services\Webserver\Webserver;
|
use App\SSH\Services\Webserver\Webserver;
|
||||||
use App\ValidationRules\DomainRule;
|
use App\ValidationRules\DomainRule;
|
||||||
|
|
||||||
class UpdateAliases
|
class UpdateAliases
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
public function update(Site $site, array $input): void
|
public function update(Site $site, array $input): void
|
||||||
{
|
{
|
||||||
$site->aliases = $input['aliases'] ?? [];
|
$site->aliases = $input['aliases'] ?? [];
|
||||||
|
|
||||||
|
/** @var Service $service */
|
||||||
|
$service = $site->server->webserver();
|
||||||
|
|
||||||
/** @var Webserver $webserver */
|
/** @var Webserver $webserver */
|
||||||
$webserver = $site->server->webserver()->handler();
|
$webserver = $service->handler();
|
||||||
$webserver->updateVHost($site, ! $site->hasSSL());
|
$webserver->updateVHost($site);
|
||||||
|
|
||||||
$site->save();
|
$site->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<int, mixed>>
|
||||||
|
*/
|
||||||
public static function rules(): array
|
public static function rules(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
@ -2,24 +2,27 @@
|
|||||||
|
|
||||||
namespace App\Actions\Site;
|
namespace App\Actions\Site;
|
||||||
|
|
||||||
|
use App\Exceptions\SSHError;
|
||||||
use App\Models\Site;
|
use App\Models\Site;
|
||||||
use App\SSH\Git\Git;
|
use App\SSH\Git\Git;
|
||||||
use Illuminate\Validation\ValidationException;
|
|
||||||
|
|
||||||
class UpdateBranch
|
class UpdateBranch
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @throws ValidationException
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws SSHError
|
||||||
*/
|
*/
|
||||||
public function update(Site $site, array $input): void
|
public function update(Site $site, array $input): void
|
||||||
{
|
{
|
||||||
$site->branch = $input['branch'];
|
$site->branch = $input['branch'];
|
||||||
|
app(Git::class)->fetchOrigin($site);
|
||||||
app(Git::class)->checkout($site);
|
app(Git::class)->checkout($site);
|
||||||
$site->save();
|
$site->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws ValidationException
|
* @return array<string, string>
|
||||||
*/
|
*/
|
||||||
public static function rules(): array
|
public static function rules(): array
|
||||||
{
|
{
|
||||||
|
@ -2,23 +2,24 @@
|
|||||||
|
|
||||||
namespace App\Actions\Site;
|
namespace App\Actions\Site;
|
||||||
|
|
||||||
|
use App\Models\DeploymentScript;
|
||||||
use App\Models\Site;
|
use App\Models\Site;
|
||||||
use Illuminate\Validation\ValidationException;
|
|
||||||
|
|
||||||
class UpdateDeploymentScript
|
class UpdateDeploymentScript
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @throws ValidationException
|
* @param array<string, mixed> $input
|
||||||
*/
|
*/
|
||||||
public function update(Site $site, array $input): void
|
public function update(Site $site, array $input): void
|
||||||
{
|
{
|
||||||
$site->deploymentScript()->update([
|
/** @var DeploymentScript $script */
|
||||||
'content' => $input['script'],
|
$script = $site->deploymentScript;
|
||||||
]);
|
$script->content = $input['script'];
|
||||||
|
$script->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws ValidationException
|
* @return array<string, array<string>>
|
||||||
*/
|
*/
|
||||||
public static function rules(): array
|
public static function rules(): array
|
||||||
{
|
{
|
||||||
|
@ -2,19 +2,22 @@
|
|||||||
|
|
||||||
namespace App\Actions\Site;
|
namespace App\Actions\Site;
|
||||||
|
|
||||||
use App\Exceptions\SSHUploadFailed;
|
use App\Exceptions\SSHError;
|
||||||
use App\Models\Site;
|
use App\Models\Site;
|
||||||
|
|
||||||
class UpdateEnv
|
class UpdateEnv
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @throws SSHUploadFailed
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws SSHError
|
||||||
*/
|
*/
|
||||||
public function update(Site $site, array $input): void
|
public function update(Site $site, array $input): void
|
||||||
{
|
{
|
||||||
$site->server->os()->editFile(
|
$site->server->os()->editFileAs(
|
||||||
$site->path.'/.env',
|
$site->path.'/.env',
|
||||||
$input['env']
|
$site->user,
|
||||||
|
trim((string) $input['env']),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
69
app/Actions/Site/UpdateLoadBalancer.php
Normal file
69
app/Actions/Site/UpdateLoadBalancer.php
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Actions\Site;
|
||||||
|
|
||||||
|
use App\Enums\LoadBalancerMethod;
|
||||||
|
use App\Models\LoadBalancerServer;
|
||||||
|
use App\Models\Site;
|
||||||
|
use Illuminate\Validation\Rule;
|
||||||
|
|
||||||
|
class UpdateLoadBalancer
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*/
|
||||||
|
public function update(Site $site, array $input): void
|
||||||
|
{
|
||||||
|
$site->loadBalancerServers()->delete();
|
||||||
|
|
||||||
|
foreach ($input['servers'] as $server) {
|
||||||
|
$loadBalancerServer = new LoadBalancerServer([
|
||||||
|
'load_balancer_id' => $site->id,
|
||||||
|
'ip' => $server['server'],
|
||||||
|
'port' => $server['port'],
|
||||||
|
'weight' => $server['weight'],
|
||||||
|
'backup' => (bool) $server['backup'],
|
||||||
|
]);
|
||||||
|
$loadBalancerServer->save();
|
||||||
|
}
|
||||||
|
|
||||||
|
$site->webserver()->updateVHost($site);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array<string, array<int, mixed>>
|
||||||
|
*/
|
||||||
|
public static function rules(Site $site): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'servers' => [
|
||||||
|
'required',
|
||||||
|
'array',
|
||||||
|
],
|
||||||
|
'servers.*.server' => [
|
||||||
|
'required',
|
||||||
|
Rule::exists('servers', 'local_ip')
|
||||||
|
->where('project_id', $site->project->id),
|
||||||
|
],
|
||||||
|
'servers.*.port' => [
|
||||||
|
'required',
|
||||||
|
'numeric',
|
||||||
|
'min:1',
|
||||||
|
'max:65535',
|
||||||
|
],
|
||||||
|
'servers.*.weight' => [
|
||||||
|
'nullable',
|
||||||
|
'numeric',
|
||||||
|
'min:0',
|
||||||
|
],
|
||||||
|
'servers.*.backup' => [
|
||||||
|
'required',
|
||||||
|
'boolean',
|
||||||
|
],
|
||||||
|
'method' => [
|
||||||
|
'required',
|
||||||
|
Rule::in(LoadBalancerMethod::all()),
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
@ -2,11 +2,15 @@
|
|||||||
|
|
||||||
namespace App\Actions\Site;
|
namespace App\Actions\Site;
|
||||||
|
|
||||||
|
use App\Exceptions\SSHError;
|
||||||
use App\Models\Site;
|
use App\Models\Site;
|
||||||
use Illuminate\Validation\Rule;
|
use Illuminate\Validation\Rule;
|
||||||
|
|
||||||
class UpdatePHPVersion
|
class UpdatePHPVersion
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @return array<string, array<string>>
|
||||||
|
*/
|
||||||
public static function rules(Site $site): array
|
public static function rules(Site $site): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
@ -19,6 +23,11 @@ public static function rules(Site $site): array
|
|||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, mixed> $input
|
||||||
|
*
|
||||||
|
* @throws SSHError
|
||||||
|
*/
|
||||||
public function update(Site $site, array $input): void
|
public function update(Site $site, array $input): void
|
||||||
{
|
{
|
||||||
$site->changePHPVersion($input['version']);
|
$site->changePHPVersion($input['version']);
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user