config creation and management APIs

This commit is contained in:
Martin McKeaveney 2021-04-20 18:14:36 +01:00
parent b5e19e4216
commit 301f681c88
7 changed files with 135 additions and 6 deletions

View File

@ -10,6 +10,7 @@ const DocumentTypes = {
USER: "us", USER: "us",
APP: "app", APP: "app",
GROUP: "group", GROUP: "group",
CONFIG: "config",
} }
exports.DocumentTypes = DocumentTypes exports.DocumentTypes = DocumentTypes
@ -52,7 +53,7 @@ exports.getGroupParams = (id = "", otherProps = {}) => {
} }
/** /**
* Gets parameters for retrieving users. * Gets parameters for retrieving users, this is a utility function for the getDocParams function.
*/ */
exports.getUserParams = (email = "", otherProps = {}) => { exports.getUserParams = (email = "", otherProps = {}) => {
if (!email) { if (!email) {
@ -64,3 +65,26 @@ exports.getUserParams = (email = "", otherProps = {}) => {
endkey: `${DocumentTypes.USER}${SEPARATOR}${email}${UNICODE_MAX}`, endkey: `${DocumentTypes.USER}${SEPARATOR}${email}${UNICODE_MAX}`,
} }
} }
/**
* Generates a new configuration ID.
* @returns {string} The new configuration ID which the config doc can be stored under.
*/
exports.generateConfigID = (type = "", group = "") => {
group += SEPARATOR
return `${
DocumentTypes.CONFIG
}${SEPARATOR}${type}${SEPARATOR}${group}${newid()}`
}
/**
* Gets parameters for retrieving configurations.
*/
exports.getConfigParams = (type = "", group = "", otherProps = {}) => {
return {
...otherProps,
startkey: `${DocumentTypes.CONFIG}${SEPARATOR}${type}${SEPARATOR}${group}`,
endkey: `${DocumentTypes.CONFIG}${SEPARATOR}${type}${SEPARATOR}${group}${UNICODE_MAX}`,
}
}

View File

@ -20,6 +20,8 @@ const {
generateGroupID, generateGroupID,
getGroupParams, getGroupParams,
getEmailFromUserID, getEmailFromUserID,
generateConfigID,
getConfigParams,
} = require("./db/utils") } = require("./db/utils")
// Strategies // Strategies
@ -54,6 +56,8 @@ module.exports = {
generateGroupID, generateGroupID,
getGroupParams, getGroupParams,
getEmailFromUserID, getEmailFromUserID,
generateConfigID,
getConfigParams,
hash, hash,
compare, compare,
getAppId, getAppId,

View File

@ -6,7 +6,13 @@ exports.options = {
callbackURL: env.GOOGLE_AUTH_CALLBACK_URL, callbackURL: env.GOOGLE_AUTH_CALLBACK_URL,
} }
// exports.authenticate = async function(token, tokenSecret, profile, done) { exports.authenticate = async function(token, tokenSecret, profile, done) {
// // retrieve user ... console.log({
// fetchUser().then(user => done(null, user)) token,
// } tokenSecret,
profile,
done,
})
// retrieve user ...
// fetchUser().then(user => done(null, user))
}

View File

@ -0,0 +1,60 @@
const CouchDB = require("../../../db")
const { StaticDatabases } = require("@budibase/auth")
const { generateConfigID } = require("@budibase/auth")
const { getConfigParams } = require("@budibase/auth/src/db/utils")
const GLOBAL_DB = StaticDatabases.GLOBAL.name
exports.save = async function(ctx) {
const db = new CouchDB(GLOBAL_DB)
const configDoc = ctx.request.body
// Config does not exist yet
if (!configDoc._id) {
configDoc._id = generateConfigID(configDoc.type, configDoc.group)
}
try {
const response = await db.post(configDoc)
ctx.body = {
type: configDoc.type,
_id: response.id,
_rev: response.rev,
}
} catch (err) {
ctx.throw(err.status, err)
}
}
exports.fetch = async function(ctx) {
const db = new CouchDB(GLOBAL_DB)
const response = await db.allDocs(
getConfigParams(undefined, {
include_docs: true,
})
)
const groups = response.rows.map(row => row.doc)
ctx.body = groups
}
exports.find = async function(ctx) {
const db = new CouchDB(GLOBAL_DB)
try {
const record = await db.get(ctx.params.id)
ctx.body = record
} catch (err) {
ctx.throw(err.status, err)
}
}
exports.destroy = async function(ctx) {
const db = new CouchDB(GLOBAL_DB)
const { id, rev } = ctx.params
try {
await db.remove(id, rev)
ctx.body = { message: "Config deleted successfully" }
} catch (err) {
ctx.throw(err.status, err)
}
}

View File

@ -0,0 +1,28 @@
const Router = require("@koa/router")
const controller = require("../../controllers/admin/configs")
const joiValidator = require("../../../middleware/joi-validator")
const { authenticated } = require("@budibase/auth")
const Joi = require("joi")
const { Configs } = require("../../../constants")
const router = Router()
function buildConfigSaveValidation() {
// prettier-ignore
return joiValidator.body(Joi.object({
type: Joi.string().valid(...Object.values(Configs)).required()
}).required().unknown(true))
}
router
.post(
"/api/admin/configs",
buildConfigSaveValidation(),
authenticated,
controller.save
)
.delete("/api/admin/configs/:id", authenticated, controller.destroy)
.get("/api/admin/configs", authenticated, controller.fetch)
.get("/api/admin/configs/:id", authenticated, controller.find)
module.exports = router

View File

@ -1,6 +1,7 @@
const userRoutes = require("./admin/users") const userRoutes = require("./admin/users")
const configRoutes = require("./admin/configs")
const groupRoutes = require("./admin/groups") const groupRoutes = require("./admin/groups")
const authRoutes = require("./auth") const authRoutes = require("./auth")
const appRoutes = require("./app") const appRoutes = require("./app")
exports.routes = [userRoutes, groupRoutes, authRoutes, appRoutes] exports.routes = [configRoutes, userRoutes, groupRoutes, authRoutes, appRoutes]

View File

@ -6,3 +6,9 @@ exports.UserStatus = {
exports.Groups = { exports.Groups = {
ALL_USERS: "all_users", ALL_USERS: "all_users",
} }
exports.Configs = {
SETTINGS: "settings",
ACCOUNT: "account",
SMTP: "smtp",
}