Making sure deployment object is used everywhere to hide all underlying deployment properties.

This commit is contained in:
mike12345567 2020-12-01 16:51:17 +00:00
parent 103161c7a8
commit 3dde3e0581
2 changed files with 30 additions and 20 deletions

View File

@ -1,13 +1,14 @@
const { getAppQuota } = require("./quota") const { getAppQuota } = require("./quota")
const env = require("../../../environment") const env = require("../../../environment")
const newid = require("../../../db/newid")
/** /**
* This is used to pass around information about the deployment that is occurring * This is used to pass around information about the deployment that is occurring
*/ */
class Deployment { class Deployment {
constructor(id, appId) { constructor(appId, id = null) {
this._id = id
this.appId = appId this.appId = appId
this._id = id || newid()
} }
// purely so that we can do quota stuff outside the main deployment context // purely so that we can do quota stuff outside the main deployment context
@ -30,6 +31,9 @@ class Deployment {
} }
setVerification(verification) { setVerification(verification) {
if (this.verification.quota) {
this.quota = this.verification.quota
}
this.verification = verification this.verification = verification
} }
@ -44,6 +48,18 @@ class Deployment {
} }
} }
fromJSON(json) {
if (json.verification) {
this.setVerification(json.verification)
}
if (json.quota) {
this.setQuota(json.quota)
}
if (json.status) {
this.setStatus(json.status, json.err)
}
}
getJSON() { getJSON() {
const obj = { const obj = {
_id: this._id, _id: this._id,
@ -56,8 +72,8 @@ class Deployment {
if (this.verification && this.verification.cfDistribution) { if (this.verification && this.verification.cfDistribution) {
obj.cfDistribution = this.verification.cfDistribution obj.cfDistribution = this.verification.cfDistribution
} }
if (this.verification && this.verification.quota) { if (this.quota) {
obj.quota = this.verification.quota obj.quota = this.quota
} }
return obj return obj
} }

View File

@ -1,6 +1,6 @@
const CouchDB = require("pouchdb") const CouchDB = require("pouchdb")
const PouchDB = require("../../../db") const PouchDB = require("../../../db")
const newid = require("../../../db/newid")
const env = require("../../../environment") const env = require("../../../environment")
const deployment = env.SELF_HOSTED const deployment = env.SELF_HOSTED
? require("./selfDeploy") ? require("./selfDeploy")
@ -69,7 +69,7 @@ async function storeLocalDeploymentHistory(deployment) {
deploymentDoc = { _id: "_local/deployments", history: {} } deploymentDoc = { _id: "_local/deployments", history: {} }
} }
const deploymentId = deploymentJSON._id || newid() const deploymentId = deploymentJSON._id
// first time deployment // first time deployment
if (!deploymentDoc.history[deploymentId]) if (!deploymentDoc.history[deploymentId])
@ -82,14 +82,12 @@ async function storeLocalDeploymentHistory(deployment) {
} }
await db.put(deploymentDoc) await db.put(deploymentDoc)
return { deployment.fromJSON(deploymentDoc.history[deploymentId])
_id: deploymentId, return deployment
...deploymentDoc.history[deploymentId],
}
} }
async function deployApp({ appId, deploymentId }) { async function deployApp(deployment) {
const deployment = new Deployment(deploymentId, appId) const appId = deployment.getAppId()
try { try {
await deployment.init() await deployment.init()
deployment.setVerification(await preDeployment(deployment)) deployment.setVerification(await preDeployment(deployment))
@ -144,15 +142,11 @@ exports.deploymentProgress = async function(ctx) {
} }
exports.deployApp = async function(ctx) { exports.deployApp = async function(ctx) {
const deployment = await storeLocalDeploymentHistory({ let deployment = new Deployment(ctx.user.appId)
appId: ctx.user.appId, deployment.setStatus(DeploymentStatus.PENDING)
status: DeploymentStatus.PENDING, deployment = await storeLocalDeploymentHistory(deployment)
})
await deployApp({ await deployApp(deployment)
...ctx.user,
deploymentId: deployment._id,
})
ctx.body = deployment ctx.body = deployment
} }