prettier formatting
This commit is contained in:
parent
c082c953f3
commit
94b3416300
5 changed files with 311 additions and 101 deletions
|
|
@ -3,24 +3,28 @@
|
||||||
So the goal of the extension is to allow the owner of a domain to sell their subdomain to the anyone who is willing to pay some money for it.
|
So the goal of the extension is to allow the owner of a domain to sell their subdomain to the anyone who is willing to pay some money for it.
|
||||||
|
|
||||||
## Requirements
|
## Requirements
|
||||||
|
|
||||||
- Free cloudflare account
|
- Free cloudflare account
|
||||||
- Cloudflare as a dns server provider
|
- Cloudflare as a dns server provider
|
||||||
- Cloudflare TOKEN and Cloudflare zone-id where the domain is parked
|
- Cloudflare TOKEN and Cloudflare zone-id where the domain is parked
|
||||||
|
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
1. Register at cloudflare and setup your domain with them. (Just follow instructions they provide...)
|
1. Register at cloudflare and setup your domain with them. (Just follow instructions they provide...)
|
||||||
2. Change DNS server at your domain registrar to point to cloudflare's
|
2. Change DNS server at your domain registrar to point to cloudflare's
|
||||||
3. Get Cloudflare zoneID for your domain
|
3. Get Cloudflare zoneID for your domain
|
||||||
<img src="https://i.imgur.com/xOgapHr.png">
|
<img src="https://i.imgur.com/xOgapHr.png">
|
||||||
4. get Cloudflare API TOKEN
|
4. get Cloudflare API TOKEN
|
||||||
<img src="https://i.imgur.com/BZbktTy.png">
|
<img src="https://i.imgur.com/BZbktTy.png">
|
||||||
<img src="https://i.imgur.com/YDZpW7D.png">
|
<img src="https://i.imgur.com/YDZpW7D.png">
|
||||||
5. Open the lnbits subdomains extension and register your domain with lnbits
|
5. Open the lnbits subdomains extension and register your domain with lnbits
|
||||||
6. Click on the button in the table to open the public form that was generated for your domain
|
6. Click on the button in the table to open the public form that was generated for your domain
|
||||||
- Extension also supports webhooks so you can get notified when someone buys a new domain
|
|
||||||
|
- Extension also supports webhooks so you can get notified when someone buys a new domain
|
||||||
<img src="https://i.imgur.com/hiauxeR.png">
|
<img src="https://i.imgur.com/hiauxeR.png">
|
||||||
|
|
||||||
## API Endpoints
|
## API Endpoints
|
||||||
|
|
||||||
- **Domains**
|
- **Domains**
|
||||||
- GET /api/v1/domains
|
- GET /api/v1/domains
|
||||||
- POST /api/v1/domains
|
- POST /api/v1/domains
|
||||||
|
|
@ -35,6 +39,7 @@ So the goal of the extension is to allow the owner of a domain to sell their sub
|
||||||
## Useful
|
## Useful
|
||||||
|
|
||||||
### Cloudflare
|
### Cloudflare
|
||||||
|
|
||||||
- Cloudflare offers programmatic subdomain registration... (create new A record)
|
- Cloudflare offers programmatic subdomain registration... (create new A record)
|
||||||
- you can keep your existing domain's registrar, you just have to transfer dns records to the cloudflare (free service)
|
- you can keep your existing domain's registrar, you just have to transfer dns records to the cloudflare (free service)
|
||||||
- more information:
|
- more information:
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "Subdomains",
|
"name": "Subdomains",
|
||||||
"short_description": "Sell subdomains of your domain",
|
"short_description": "Sell subdomains of your domain",
|
||||||
"icon": "domain",
|
"icon": "domain",
|
||||||
"contributors": ["grmkris"]
|
"contributors": ["grmkris"]
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,9 @@
|
||||||
<q-expansion-item group="extras" icon="swap_vertical_circle" label="Info" :content-inset-level="0.5">
|
<q-expansion-item
|
||||||
|
group="extras"
|
||||||
|
icon="swap_vertical_circle"
|
||||||
|
label="Info"
|
||||||
|
:content-inset-level="0.5"
|
||||||
|
>
|
||||||
<q-card>
|
<q-card>
|
||||||
<q-card-section>
|
<q-card-section>
|
||||||
<h5 class="text-subtitle1 q-my-none">
|
<h5 class="text-subtitle1 q-my-none">
|
||||||
|
|
@ -6,10 +11,12 @@
|
||||||
</h5>
|
</h5>
|
||||||
<p>
|
<p>
|
||||||
Charge people for using your subdomain name...<br />
|
Charge people for using your subdomain name...<br />
|
||||||
Are you the owner of <b>cool-domain.com</b> and want to sell <i>cool-subdomain</i>.<b>cool-domain.com</b>
|
Are you the owner of <b>cool-domain.com</b> and want to sell
|
||||||
|
<i>cool-subdomain</i>.<b>cool-domain.com</b>
|
||||||
<br />
|
<br />
|
||||||
<small>
|
<small>
|
||||||
Created by, <a href="https://github.com/grmkris">Kris</a></small>
|
Created by, <a href="https://github.com/grmkris">Kris</a></small
|
||||||
|
>
|
||||||
</p>
|
</p>
|
||||||
</q-card-section>
|
</q-card-section>
|
||||||
</q-card>
|
</q-card>
|
||||||
|
|
|
||||||
|
|
@ -8,26 +8,59 @@
|
||||||
<h5 class="q-my-none">{{ domain_desc }}</h5>
|
<h5 class="q-my-none">{{ domain_desc }}</h5>
|
||||||
<br />
|
<br />
|
||||||
<q-form @submit="Invoice()" class="q-gutter-md">
|
<q-form @submit="Invoice()" class="q-gutter-md">
|
||||||
<q-input filled dense v-model.trim="formDialog.data.email" type="email"
|
<q-input
|
||||||
label="Your email (optional, if you want a reply)"></q-input>
|
filled
|
||||||
<q-select dense filled v-model="formDialog.data.record_type" :options='{{domain_allowed_record_types}}'
|
dense
|
||||||
label="Record type"></q-select>
|
v-model.trim="formDialog.data.email"
|
||||||
<q-input filled dense v-model.trim="formDialog.data.subdomain" type="text" label="Subdomain you want">
|
type="email"
|
||||||
|
label="Your email (optional, if you want a reply)"
|
||||||
|
></q-input>
|
||||||
|
<q-select
|
||||||
|
dense
|
||||||
|
filled
|
||||||
|
v-model="formDialog.data.record_type"
|
||||||
|
:options="{{domain_allowed_record_types}}"
|
||||||
|
label="Record type"
|
||||||
|
></q-select>
|
||||||
|
<q-input
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
v-model.trim="formDialog.data.subdomain"
|
||||||
|
type="text"
|
||||||
|
label="Subdomain you want"
|
||||||
|
>
|
||||||
</q-input>
|
</q-input>
|
||||||
<q-input filled dense v-model.trim="formDialog.data.ip" type="text" label="Ip of your server">
|
<q-input
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
v-model.trim="formDialog.data.ip"
|
||||||
|
type="text"
|
||||||
|
label="Ip of your server"
|
||||||
|
>
|
||||||
</q-input>
|
</q-input>
|
||||||
<q-input filled dense v-model.trim="formDialog.data.duration" type="number" label="Number of days">
|
<q-input
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
v-model.trim="formDialog.data.duration"
|
||||||
|
type="number"
|
||||||
|
label="Number of days"
|
||||||
|
>
|
||||||
</q-input>
|
</q-input>
|
||||||
<p>
|
<p>
|
||||||
Cost per day: {{ domain_cost }} sats<br />
|
Cost per day: {{ domain_cost }} sats<br />
|
||||||
{% raw %}
|
{% raw %} Total cost: {{amountSats}} sats {% endraw %}
|
||||||
Total cost: {{amountSats}} sats
|
</p>
|
||||||
{% endraw %}</p>
|
|
||||||
<div class="row q-mt-lg">
|
<div class="row q-mt-lg">
|
||||||
<q-btn unelevated color="deep-purple"
|
<q-btn
|
||||||
|
unelevated
|
||||||
|
color="deep-purple"
|
||||||
:disable="formDialog.data.subdomain == '' || formDialog.data.ip == '' || formDialog.data.duration == ''"
|
:disable="formDialog.data.subdomain == '' || formDialog.data.ip == '' || formDialog.data.duration == ''"
|
||||||
type="submit">Submit</q-btn>
|
type="submit"
|
||||||
<q-btn @click="resetForm" flat color="grey" class="q-ml-auto">Cancel</q-btn>
|
>Submit</q-btn
|
||||||
|
>
|
||||||
|
<q-btn @click="resetForm" flat color="grey" class="q-ml-auto"
|
||||||
|
>Cancel</q-btn
|
||||||
|
>
|
||||||
</div>
|
</div>
|
||||||
</q-form>
|
</q-form>
|
||||||
</q-card-section>
|
</q-card-section>
|
||||||
|
|
@ -35,18 +68,27 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<q-dialog v-model="receive.show" position="top" @hide="closeReceiveDialog">
|
<q-dialog v-model="receive.show" position="top" @hide="closeReceiveDialog">
|
||||||
<q-card v-if="!receive.paymentReq" class="q-pa-lg q-pt-xl lnbits__dialog-card">
|
<q-card
|
||||||
|
v-if="!receive.paymentReq"
|
||||||
|
class="q-pa-lg q-pt-xl lnbits__dialog-card"
|
||||||
|
>
|
||||||
</q-card>
|
</q-card>
|
||||||
<q-card v-else class="q-pa-lg q-pt-xl lnbits__dialog-card">
|
<q-card v-else class="q-pa-lg q-pt-xl lnbits__dialog-card">
|
||||||
<div class="text-center q-mb-lg">
|
<div class="text-center q-mb-lg">
|
||||||
<a :href="'lightning:' + receive.paymentReq">
|
<a :href="'lightning:' + receive.paymentReq">
|
||||||
<q-responsive :ratio="1" class="q-mx-xl">
|
<q-responsive :ratio="1" class="q-mx-xl">
|
||||||
<qrcode :value="paymentReq" :options="{width: 340}" class="rounded-borders"></qrcode>
|
<qrcode
|
||||||
|
:value="paymentReq"
|
||||||
|
:options="{width: 340}"
|
||||||
|
class="rounded-borders"
|
||||||
|
></qrcode>
|
||||||
</q-responsive>
|
</q-responsive>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
<div class="row q-mt-lg">
|
<div class="row q-mt-lg">
|
||||||
<q-btn outline color="grey" @click="copyText(receive.paymentReq)">Copy invoice</q-btn>
|
<q-btn outline color="grey" @click="copyText(receive.paymentReq)"
|
||||||
|
>Copy invoice</q-btn
|
||||||
|
>
|
||||||
<q-btn v-close-popup flat color="grey" class="q-ml-auto">Close</q-btn>
|
<q-btn v-close-popup flat color="grey" class="q-ml-auto">Close</q-btn>
|
||||||
</div>
|
</div>
|
||||||
</q-card>
|
</q-card>
|
||||||
|
|
@ -105,7 +147,7 @@
|
||||||
dismissMsg()
|
dismissMsg()
|
||||||
|
|
||||||
clearInterval(paymentChecker)
|
clearInterval(paymentChecker)
|
||||||
setTimeout(function () { }, 10000)
|
setTimeout(function () {}, 10000)
|
||||||
},
|
},
|
||||||
Invoice: function () {
|
Invoice: function () {
|
||||||
var self = this
|
var self = this
|
||||||
|
|
@ -157,10 +199,9 @@
|
||||||
self.$q.notify({
|
self.$q.notify({
|
||||||
type: 'positive',
|
type: 'positive',
|
||||||
message: 'Sent, thank you!',
|
message: 'Sent, thank you!',
|
||||||
icon: 'thumb_up',
|
icon: 'thumb_up'
|
||||||
})
|
})
|
||||||
console.log("END")
|
console.log('END')
|
||||||
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.catch(function (error) {
|
.catch(function (error) {
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,9 @@
|
||||||
<div class="col-12 col-md-8 col-lg-7 q-gutter-y-md">
|
<div class="col-12 col-md-8 col-lg-7 q-gutter-y-md">
|
||||||
<q-card>
|
<q-card>
|
||||||
<q-card-section>
|
<q-card-section>
|
||||||
<q-btn unelevated color="deep-purple" @click="domainDialog.show = true">New Domain</q-btn>
|
<q-btn unelevated color="deep-purple" @click="domainDialog.show = true"
|
||||||
|
>New Domain</q-btn
|
||||||
|
>
|
||||||
</q-card-section>
|
</q-card-section>
|
||||||
</q-card>
|
</q-card>
|
||||||
|
|
||||||
|
|
@ -16,11 +18,19 @@
|
||||||
<h5 class="text-subtitle1 q-my-none">Domains</h5>
|
<h5 class="text-subtitle1 q-my-none">Domains</h5>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-auto">
|
<div class="col-auto">
|
||||||
<q-btn flat color="grey" @click="exportDomainsCSV">Export to CSV</q-btn>
|
<q-btn flat color="grey" @click="exportDomainsCSV"
|
||||||
|
>Export to CSV</q-btn
|
||||||
|
>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<q-table dense flat :data="domains" row-key="id" :columns="domainsTable.columns"
|
<q-table
|
||||||
:pagination.sync="domainsTable.pagination">
|
dense
|
||||||
|
flat
|
||||||
|
:data="domains"
|
||||||
|
row-key="id"
|
||||||
|
:columns="domainsTable.columns"
|
||||||
|
:pagination.sync="domainsTable.pagination"
|
||||||
|
>
|
||||||
{% raw %}
|
{% raw %}
|
||||||
<template v-slot:header="props">
|
<template v-slot:header="props">
|
||||||
<q-tr :props="props">
|
<q-tr :props="props">
|
||||||
|
|
@ -34,18 +44,40 @@
|
||||||
<template v-slot:body="props">
|
<template v-slot:body="props">
|
||||||
<q-tr :props="props">
|
<q-tr :props="props">
|
||||||
<q-td auto-width>
|
<q-td auto-width>
|
||||||
<q-btn unelevated dense size="xs" icon="link" :color="($q.dark.isActive) ? 'grey-7' : 'grey-5'" type="a"
|
<q-btn
|
||||||
:href="props.row.displayUrl" target="_blank"></q-btn>
|
unelevated
|
||||||
|
dense
|
||||||
|
size="xs"
|
||||||
|
icon="link"
|
||||||
|
:color="($q.dark.isActive) ? 'grey-7' : 'grey-5'"
|
||||||
|
type="a"
|
||||||
|
:href="props.row.displayUrl"
|
||||||
|
target="_blank"
|
||||||
|
></q-btn>
|
||||||
</q-td>
|
</q-td>
|
||||||
<q-td v-for="col in props.cols" :key="col.name" :props="props">
|
<q-td v-for="col in props.cols" :key="col.name" :props="props">
|
||||||
{{ col.value }}
|
{{ col.value }}
|
||||||
</q-td>
|
</q-td>
|
||||||
<q-td auto-width>
|
<q-td auto-width>
|
||||||
<q-btn flat dense size="xs" @click="updateDomainDialog(props.row.id)" icon="edit" color="light-blue">
|
<q-btn
|
||||||
|
flat
|
||||||
|
dense
|
||||||
|
size="xs"
|
||||||
|
@click="updateDomainDialog(props.row.id)"
|
||||||
|
icon="edit"
|
||||||
|
color="light-blue"
|
||||||
|
>
|
||||||
</q-btn>
|
</q-btn>
|
||||||
</q-td>
|
</q-td>
|
||||||
<q-td auto-width>
|
<q-td auto-width>
|
||||||
<q-btn flat dense size="xs" @click="deleteDomain(props.row.id)" icon="cancel" color="pink"></q-btn>
|
<q-btn
|
||||||
|
flat
|
||||||
|
dense
|
||||||
|
size="xs"
|
||||||
|
@click="deleteDomain(props.row.id)"
|
||||||
|
icon="cancel"
|
||||||
|
color="pink"
|
||||||
|
></q-btn>
|
||||||
</q-td>
|
</q-td>
|
||||||
</q-tr>
|
</q-tr>
|
||||||
</template>
|
</template>
|
||||||
|
|
@ -61,11 +93,19 @@
|
||||||
<h5 class="text-subtitle1 q-my-none">Subdomains</h5>
|
<h5 class="text-subtitle1 q-my-none">Subdomains</h5>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-auto">
|
<div class="col-auto">
|
||||||
<q-btn flat color="grey" @click="exportSubdomainsCSV">Export to CSV</q-btn>
|
<q-btn flat color="grey" @click="exportSubdomainsCSV"
|
||||||
|
>Export to CSV</q-btn
|
||||||
|
>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<q-table dense flat :data="subdomains" row-key="id" :columns="subdomainsTable.columns"
|
<q-table
|
||||||
:pagination.sync="subdomainsTable.pagination">
|
dense
|
||||||
|
flat
|
||||||
|
:data="subdomains"
|
||||||
|
row-key="id"
|
||||||
|
:columns="subdomainsTable.columns"
|
||||||
|
:pagination.sync="subdomainsTable.pagination"
|
||||||
|
>
|
||||||
{% raw %}
|
{% raw %}
|
||||||
<template v-slot:header="props">
|
<template v-slot:header="props">
|
||||||
<q-tr :props="props">
|
<q-tr :props="props">
|
||||||
|
|
@ -78,8 +118,15 @@
|
||||||
<template v-slot:body="props">
|
<template v-slot:body="props">
|
||||||
<q-tr :props="props" v-if="props.row.paid">
|
<q-tr :props="props" v-if="props.row.paid">
|
||||||
<q-td auto-width>
|
<q-td auto-width>
|
||||||
<q-btn unelevated dense size="xs" icon="email" :color="($q.dark.isActive) ? 'grey-7' : 'grey-5'"
|
<q-btn
|
||||||
type="a" :href="'mailto:' + props.row.email"></q-btn>
|
unelevated
|
||||||
|
dense
|
||||||
|
size="xs"
|
||||||
|
icon="email"
|
||||||
|
:color="($q.dark.isActive) ? 'grey-7' : 'grey-5'"
|
||||||
|
type="a"
|
||||||
|
:href="'mailto:' + props.row.email"
|
||||||
|
></q-btn>
|
||||||
</q-td>
|
</q-td>
|
||||||
|
|
||||||
<q-td v-for="col in props.cols" :key="col.name" :props="props">
|
<q-td v-for="col in props.cols" :key="col.name" :props="props">
|
||||||
|
|
@ -87,7 +134,14 @@
|
||||||
</q-td>
|
</q-td>
|
||||||
|
|
||||||
<q-td auto-width>
|
<q-td auto-width>
|
||||||
<q-btn flat dense size="xs" @click="deleteSubdomain(props.row.id)" icon="cancel" color="pink"></q-btn>
|
<q-btn
|
||||||
|
flat
|
||||||
|
dense
|
||||||
|
size="xs"
|
||||||
|
@click="deleteSubdomain(props.row.id)"
|
||||||
|
icon="cancel"
|
||||||
|
color="pink"
|
||||||
|
></q-btn>
|
||||||
</q-td>
|
</q-td>
|
||||||
</q-tr>
|
</q-tr>
|
||||||
</template>
|
</template>
|
||||||
|
|
@ -98,9 +152,7 @@
|
||||||
<div class="col-12 col-md-4 col-lg-5 q-gutter-y-md">
|
<div class="col-12 col-md-4 col-lg-5 q-gutter-y-md">
|
||||||
<q-card>
|
<q-card>
|
||||||
<q-card-section>
|
<q-card-section>
|
||||||
<h6 class="text-subtitle1 q-my-none">
|
<h6 class="text-subtitle1 q-my-none">LNbits Subdomain extension</h6>
|
||||||
LNbits Subdomain extension
|
|
||||||
</h6>
|
|
||||||
</q-card-section>
|
</q-card-section>
|
||||||
<q-card-section class="q-pa-none">
|
<q-card-section class="q-pa-none">
|
||||||
<q-separator></q-separator>
|
<q-separator></q-separator>
|
||||||
|
|
@ -110,36 +162,96 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<q-dialog v-model="domainDialog.show" position="top">
|
<q-dialog v-model="domainDialog.show" position="top">
|
||||||
<q-card class="q-pa-lg q-pt-xl lnbits__dialog-card">
|
<q-card class="q-pa-lg q-pt-xl lnbits__dialog-card">
|
||||||
<q-form @submit="sendFormData" class="q-gutter-md">
|
<q-form @submit="sendFormData" class="q-gutter-md">
|
||||||
<q-select filled dense emit-value v-model="domainDialog.data.wallet" :options="g.user.walletOptions"
|
<q-select
|
||||||
label="Wallet *">
|
filled
|
||||||
|
dense
|
||||||
|
emit-value
|
||||||
|
v-model="domainDialog.data.wallet"
|
||||||
|
:options="g.user.walletOptions"
|
||||||
|
label="Wallet *"
|
||||||
|
>
|
||||||
</q-select>
|
</q-select>
|
||||||
<q-select dense filled v-model="domainDialog.data.allowed_record_types" multiple :options="dnsRecordTypes"
|
<q-select
|
||||||
label="Allowed record types" ></q-select>
|
dense
|
||||||
<q-input filled dense emit-value v-model.trim="domainDialog.data.domain" type="text" label="Domain name "></q-input>
|
filled
|
||||||
<q-input filled dense v-model.trim="domainDialog.data.cf_token" type="text" label="Cloudflare API token">
|
v-model="domainDialog.data.allowed_record_types"
|
||||||
|
multiple
|
||||||
|
:options="dnsRecordTypes"
|
||||||
|
label="Allowed record types"
|
||||||
|
></q-select>
|
||||||
|
<q-input
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
emit-value
|
||||||
|
v-model.trim="domainDialog.data.domain"
|
||||||
|
type="text"
|
||||||
|
label="Domain name "
|
||||||
|
></q-input>
|
||||||
|
<q-input
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
v-model.trim="domainDialog.data.cf_token"
|
||||||
|
type="text"
|
||||||
|
label="Cloudflare API token"
|
||||||
|
>
|
||||||
</q-input>
|
</q-input>
|
||||||
<q-input filled dense v-model.trim="domainDialog.data.cf_zone_id" type="text" label="Cloudflare Zone Id">
|
<q-input
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
v-model.trim="domainDialog.data.cf_zone_id"
|
||||||
|
type="text"
|
||||||
|
label="Cloudflare Zone Id"
|
||||||
|
>
|
||||||
</q-input>
|
</q-input>
|
||||||
<q-input filled dense v-model.trim="domainDialog.data.webhook" type="text" label="Webhook (optional)"
|
<q-input
|
||||||
hint="A URL to be called whenever this link receives a payment."></q-input>
|
filled
|
||||||
<q-input filled dense v-model.trim="domainDialog.data.description" type="textarea" label="Description ">
|
dense
|
||||||
|
v-model.trim="domainDialog.data.webhook"
|
||||||
|
type="text"
|
||||||
|
label="Webhook (optional)"
|
||||||
|
hint="A URL to be called whenever this link receives a payment."
|
||||||
|
></q-input>
|
||||||
|
<q-input
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
v-model.trim="domainDialog.data.description"
|
||||||
|
type="textarea"
|
||||||
|
label="Description "
|
||||||
|
>
|
||||||
</q-input>
|
</q-input>
|
||||||
<q-input filled dense v-model.number="domainDialog.data.cost" type="number" label="Amount per day"></q-input>
|
<q-input
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
v-model.number="domainDialog.data.cost"
|
||||||
|
type="number"
|
||||||
|
label="Amount per day"
|
||||||
|
></q-input>
|
||||||
<div class="row q-mt-lg">
|
<div class="row q-mt-lg">
|
||||||
<q-btn v-if="domainDialog.data.id" unelevated color="deep-purple" type="submit">Update Form</q-btn>
|
<q-btn
|
||||||
<q-btn v-else unelevated color="deep-purple"
|
v-if="domainDialog.data.id"
|
||||||
|
unelevated
|
||||||
|
color="deep-purple"
|
||||||
|
type="submit"
|
||||||
|
>Update Form</q-btn
|
||||||
|
>
|
||||||
|
<q-btn
|
||||||
|
v-else
|
||||||
|
unelevated
|
||||||
|
color="deep-purple"
|
||||||
:disable="domainDialog.data.cost == null || domainDialog.data.cost < 0 || domainDialog.data.domain == null"
|
:disable="domainDialog.data.cost == null || domainDialog.data.cost < 0 || domainDialog.data.domain == null"
|
||||||
type="submit">Create Domain</q-btn>
|
type="submit"
|
||||||
<q-btn v-close-popup flat color="grey" class="q-ml-auto">Cancel</q-btn>
|
>Create Domain</q-btn
|
||||||
|
>
|
||||||
|
<q-btn v-close-popup flat color="grey" class="q-ml-auto"
|
||||||
|
>Cancel</q-btn
|
||||||
|
>
|
||||||
</div>
|
</div>
|
||||||
</q-form>
|
</q-form>
|
||||||
</q-card>
|
</q-card>
|
||||||
</q-dialog>
|
</q-dialog>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% endblock %} {% block scripts %} {{ window_vars(user) }}
|
{% endblock %} {% block scripts %} {{ window_vars(user) }}
|
||||||
|
|
@ -161,14 +273,49 @@
|
||||||
return {
|
return {
|
||||||
domains: [],
|
domains: [],
|
||||||
subdomains: [],
|
subdomains: [],
|
||||||
dnsRecordTypes: ['A', 'AAAA', 'CNAME', 'HTTPS', 'TXT', 'SRV', 'LOC', 'MX', 'NS', 'SPF', 'CERT', 'DNSKEY', 'DS', 'NAPTR', 'SMIMEA', 'SSHFP', 'SVCB', 'TLSA', 'URI'],
|
dnsRecordTypes: [
|
||||||
|
'A',
|
||||||
|
'AAAA',
|
||||||
|
'CNAME',
|
||||||
|
'HTTPS',
|
||||||
|
'TXT',
|
||||||
|
'SRV',
|
||||||
|
'LOC',
|
||||||
|
'MX',
|
||||||
|
'NS',
|
||||||
|
'SPF',
|
||||||
|
'CERT',
|
||||||
|
'DNSKEY',
|
||||||
|
'DS',
|
||||||
|
'NAPTR',
|
||||||
|
'SMIMEA',
|
||||||
|
'SSHFP',
|
||||||
|
'SVCB',
|
||||||
|
'TLSA',
|
||||||
|
'URI'
|
||||||
|
],
|
||||||
domainsTable: {
|
domainsTable: {
|
||||||
columns: [
|
columns: [
|
||||||
{ name: 'id', align: 'left', label: 'ID', field: 'id' },
|
{name: 'id', align: 'left', label: 'ID', field: 'id'},
|
||||||
{ name: 'domain', align: 'left', label: 'Domain name', field: 'domain' },
|
{
|
||||||
{ name: 'allowed_record_types', align: 'left', label: 'Allowed record types', field: 'allowed_record_types' },
|
name: 'domain',
|
||||||
{ name: 'wallet', align: 'left', label: 'Wallet', field: 'wallet' },
|
align: 'left',
|
||||||
{ name: 'webhook', align: 'left', label: 'Webhook', field: 'webhook' },
|
label: 'Domain name',
|
||||||
|
field: 'domain'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'allowed_record_types',
|
||||||
|
align: 'left',
|
||||||
|
label: 'Allowed record types',
|
||||||
|
field: 'allowed_record_types'
|
||||||
|
},
|
||||||
|
{name: 'wallet', align: 'left', label: 'Wallet', field: 'wallet'},
|
||||||
|
{
|
||||||
|
name: 'webhook',
|
||||||
|
align: 'left',
|
||||||
|
label: 'Webhook',
|
||||||
|
field: 'webhook'
|
||||||
|
},
|
||||||
{
|
{
|
||||||
name: 'description',
|
name: 'description',
|
||||||
align: 'left',
|
align: 'left',
|
||||||
|
|
@ -184,13 +331,28 @@
|
||||||
],
|
],
|
||||||
pagination: {
|
pagination: {
|
||||||
rowsPerPage: 10
|
rowsPerPage: 10
|
||||||
},
|
}
|
||||||
},
|
},
|
||||||
subdomainsTable: {
|
subdomainsTable: {
|
||||||
columns: [
|
columns: [
|
||||||
{ name: 'subdomain', align: 'left', label: 'Subdomain name', field: 'subdomain' },
|
{
|
||||||
{ name: 'domain', align: 'left', label: 'Domain name', field: 'domain_name' },
|
name: 'subdomain',
|
||||||
{ name: 'record_type', align: 'left', label: 'Record type', field: 'record_type' },
|
align: 'left',
|
||||||
|
label: 'Subdomain name',
|
||||||
|
field: 'subdomain'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'domain',
|
||||||
|
align: 'left',
|
||||||
|
label: 'Domain name',
|
||||||
|
field: 'domain_name'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'record_type',
|
||||||
|
align: 'left',
|
||||||
|
label: 'Record type',
|
||||||
|
field: 'record_type'
|
||||||
|
},
|
||||||
{
|
{
|
||||||
name: 'email',
|
name: 'email',
|
||||||
align: 'left',
|
align: 'left',
|
||||||
|
|
@ -215,11 +377,11 @@
|
||||||
label: 'Duration in days',
|
label: 'Duration in days',
|
||||||
field: 'duration'
|
field: 'duration'
|
||||||
},
|
},
|
||||||
{ name: 'id', align: 'left', label: 'ID', field: 'id' }
|
{name: 'id', align: 'left', label: 'ID', field: 'id'}
|
||||||
],
|
],
|
||||||
pagination: {
|
pagination: {
|
||||||
rowsPerPage: 10
|
rowsPerPage: 10
|
||||||
},
|
}
|
||||||
},
|
},
|
||||||
domainDialog: {
|
domainDialog: {
|
||||||
show: false,
|
show: false,
|
||||||
|
|
@ -242,11 +404,10 @@
|
||||||
return mapLNDomain(obj)
|
return mapLNDomain(obj)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
},
|
},
|
||||||
deleteSubdomain: function (subdomainId) {
|
deleteSubdomain: function (subdomainId) {
|
||||||
var self = this
|
var self = this
|
||||||
var subdomains = _.findWhere(this.subdomains, { id: subdomainId })
|
var subdomains = _.findWhere(this.subdomains, {id: subdomainId})
|
||||||
|
|
||||||
LNbits.utils
|
LNbits.utils
|
||||||
.confirmDialog('Are you sure you want to delete this subdomain')
|
.confirmDialog('Are you sure you want to delete this subdomain')
|
||||||
|
|
@ -255,7 +416,7 @@
|
||||||
.request(
|
.request(
|
||||||
'DELETE',
|
'DELETE',
|
||||||
'/subdomain/api/v1/subdomains/' + subdomainId,
|
'/subdomain/api/v1/subdomains/' + subdomainId,
|
||||||
_.findWhere(self.g.user.wallets, { id: subdomains.wallet }).inkey
|
_.findWhere(self.g.user.wallets, {id: subdomains.wallet}).inkey
|
||||||
)
|
)
|
||||||
.then(function (response) {
|
.then(function (response) {
|
||||||
self.subdomains = _.reject(self.subdomains, function (obj) {
|
self.subdomains = _.reject(self.subdomains, function (obj) {
|
||||||
|
|
@ -266,7 +427,6 @@
|
||||||
LNbits.utils.notifyApiError(error)
|
LNbits.utils.notifyApiError(error)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
},
|
},
|
||||||
exportSubdomainsCSV: function () {
|
exportSubdomainsCSV: function () {
|
||||||
LNbits.utils.exportCSV(this.subdomainsTable.columns, this.subdomains)
|
LNbits.utils.exportCSV(this.subdomainsTable.columns, this.subdomains)
|
||||||
|
|
@ -286,14 +446,13 @@
|
||||||
return mapLNDomain(obj)
|
return mapLNDomain(obj)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
},
|
},
|
||||||
sendFormData: function () {
|
sendFormData: function () {
|
||||||
var wallet = _.findWhere(this.g.user.wallets, {
|
var wallet = _.findWhere(this.g.user.wallets, {
|
||||||
id: this.domainDialog.data.wallet
|
id: this.domainDialog.data.wallet
|
||||||
})
|
})
|
||||||
var data = this.domainDialog.data
|
var data = this.domainDialog.data
|
||||||
data.allowed_record_types = data.allowed_record_types.join(", ")
|
data.allowed_record_types = data.allowed_record_types.join(', ')
|
||||||
console.log(this.domainDialog)
|
console.log(this.domainDialog)
|
||||||
if (data.id) {
|
if (data.id) {
|
||||||
this.updateDomain(wallet, data)
|
this.updateDomain(wallet, data)
|
||||||
|
|
@ -315,10 +474,9 @@
|
||||||
.catch(function (error) {
|
.catch(function (error) {
|
||||||
LNbits.utils.notifyApiError(error)
|
LNbits.utils.notifyApiError(error)
|
||||||
})
|
})
|
||||||
|
|
||||||
},
|
},
|
||||||
updateDomainDialog: function (formId) {
|
updateDomainDialog: function (formId) {
|
||||||
var link = _.findWhere(this.domains, { id: formId })
|
var link = _.findWhere(this.domains, {id: formId})
|
||||||
console.log(link.id)
|
console.log(link.id)
|
||||||
this.domainDialog.data.id = link.id
|
this.domainDialog.data.id = link.id
|
||||||
this.domainDialog.data.wallet = link.wallet
|
this.domainDialog.data.wallet = link.wallet
|
||||||
|
|
@ -328,14 +486,15 @@
|
||||||
this.domainDialog.data.cf_zone_id = link.cf_zone_id
|
this.domainDialog.data.cf_zone_id = link.cf_zone_id
|
||||||
this.domainDialog.data.webhook = link.webhook
|
this.domainDialog.data.webhook = link.webhook
|
||||||
this.domainDialog.data.cost = link.cost
|
this.domainDialog.data.cost = link.cost
|
||||||
this.domainDialog.data.allowed_record_types = link.allowed_record_types.split(", ")
|
this.domainDialog.data.allowed_record_types = link.allowed_record_types.split(
|
||||||
|
', '
|
||||||
|
)
|
||||||
this.domainDialog.show = true
|
this.domainDialog.show = true
|
||||||
},
|
},
|
||||||
updateDomain: function (wallet, data) {
|
updateDomain: function (wallet, data) {
|
||||||
var self = this
|
var self = this
|
||||||
console.log(data)
|
console.log(data)
|
||||||
|
|
||||||
|
|
||||||
LNbits.api
|
LNbits.api
|
||||||
.request(
|
.request(
|
||||||
'PUT',
|
'PUT',
|
||||||
|
|
@ -354,11 +513,10 @@
|
||||||
.catch(function (error) {
|
.catch(function (error) {
|
||||||
LNbits.utils.notifyApiError(error)
|
LNbits.utils.notifyApiError(error)
|
||||||
})
|
})
|
||||||
|
|
||||||
},
|
},
|
||||||
deleteDomain: function (domainId) {
|
deleteDomain: function (domainId) {
|
||||||
var self = this
|
var self = this
|
||||||
var domains = _.findWhere(this.domains, { id: domainId })
|
var domains = _.findWhere(this.domains, {id: domainId})
|
||||||
|
|
||||||
LNbits.utils
|
LNbits.utils
|
||||||
.confirmDialog('Are you sure you want to delete this domain link?')
|
.confirmDialog('Are you sure you want to delete this domain link?')
|
||||||
|
|
@ -367,7 +525,7 @@
|
||||||
.request(
|
.request(
|
||||||
'DELETE',
|
'DELETE',
|
||||||
'/subdomains/api/v1/domains/' + domainId,
|
'/subdomains/api/v1/domains/' + domainId,
|
||||||
_.findWhere(self.g.user.wallets, { id: domains.wallet }).inkey
|
_.findWhere(self.g.user.wallets, {id: domains.wallet}).inkey
|
||||||
)
|
)
|
||||||
.then(function (response) {
|
.then(function (response) {
|
||||||
self.domains = _.reject(self.domains, function (obj) {
|
self.domains = _.reject(self.domains, function (obj) {
|
||||||
|
|
@ -378,7 +536,6 @@
|
||||||
LNbits.utils.notifyApiError(error)
|
LNbits.utils.notifyApiError(error)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
},
|
},
|
||||||
exportDomainsCSV: function () {
|
exportDomainsCSV: function () {
|
||||||
LNbits.utils.exportCSV(this.domainsTable.columns, this.domains)
|
LNbits.utils.exportCSV(this.domainsTable.columns, this.domains)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue