mirror of
https://github.com/spacedeck/spacedeck-open.git
synced 2025-12-16 18:07:31 +01:00
WIP chargebee integration sketch
This commit is contained in:
13
package-lock.json
generated
13
package-lock.json
generated
@@ -1035,6 +1035,14 @@
|
|||||||
"supports-color": "^5.3.0"
|
"supports-color": "^5.3.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"chargebee": {
|
||||||
|
"version": "2.6.5",
|
||||||
|
"resolved": "https://registry.npmjs.org/chargebee/-/chargebee-2.6.5.tgz",
|
||||||
|
"integrity": "sha512-h11cxGXN+6I47F0Ncj7pemnYO05kLm/vOKPK9mcvdU6K/HByNI/ArlvOLLhpFqjrePfTyCmBTqDYWgYjMP3uJg==",
|
||||||
|
"requires": {
|
||||||
|
"q": ">=1.0.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
"cheerio": {
|
"cheerio": {
|
||||||
"version": "0.22.0",
|
"version": "0.22.0",
|
||||||
"resolved": "https://registry.npmjs.org/cheerio/-/cheerio-0.22.0.tgz",
|
"resolved": "https://registry.npmjs.org/cheerio/-/cheerio-0.22.0.tgz",
|
||||||
@@ -5267,6 +5275,11 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"q": {
|
||||||
|
"version": "1.5.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz",
|
||||||
|
"integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc="
|
||||||
|
},
|
||||||
"qs": {
|
"qs": {
|
||||||
"version": "6.7.0",
|
"version": "6.7.0",
|
||||||
"resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz",
|
"resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz",
|
||||||
|
|||||||
@@ -15,6 +15,7 @@
|
|||||||
"async": "2.3.0",
|
"async": "2.3.0",
|
||||||
"bcryptjs": "2.4.3",
|
"bcryptjs": "2.4.3",
|
||||||
"body-parser": "^1.19.0",
|
"body-parser": "^1.19.0",
|
||||||
|
"chargebee": "2.6.5",
|
||||||
"cheerio": "0.22.0",
|
"cheerio": "0.22.0",
|
||||||
"config": "1.25.1",
|
"config": "1.25.1",
|
||||||
"cookie-parser": "~1.4.3",
|
"cookie-parser": "~1.4.3",
|
||||||
|
|||||||
@@ -130,9 +130,27 @@ SpacedeckUsers = {
|
|||||||
$event.stopPropagation();
|
$event.stopPropagation();
|
||||||
}
|
}
|
||||||
|
|
||||||
create_user(name, email, password, password_confirmation, invite_code, function(session) {
|
create_user(name, email, password, password_confirmation, invite_code, function(res) {
|
||||||
this.creating_user = false;
|
this.creating_user = false;
|
||||||
this.login_submit(email, password, null, on_success);
|
|
||||||
|
if (res.chargebee_checkout) {
|
||||||
|
var chargebeeInstance = Chargebee.init({
|
||||||
|
site: "spacedeck-test",
|
||||||
|
enableRedirectMode: true,
|
||||||
|
enableFriendbuyTracking: false
|
||||||
|
});
|
||||||
|
|
||||||
|
chargebeeInstance.openCheckout({
|
||||||
|
hostedPage: function() {
|
||||||
|
return new Promise(function(resolve, reject) {
|
||||||
|
resolve(res.chargebee_checkout);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
// user created, login
|
||||||
|
this.login_submit(email, password, null, on_success);
|
||||||
|
}
|
||||||
}.bind(this), function(req) {
|
}.bind(this), function(req) {
|
||||||
this.creating_user = false;
|
this.creating_user = false;
|
||||||
try {
|
try {
|
||||||
|
|||||||
@@ -23,6 +23,8 @@ var express = require('express');
|
|||||||
var router = express.Router();
|
var router = express.Router();
|
||||||
var glob = require('glob');
|
var glob = require('glob');
|
||||||
|
|
||||||
|
var chargebee = require('chargebee');
|
||||||
|
|
||||||
router.get('/current', function(req, res, next) {
|
router.get('/current', function(req, res, next) {
|
||||||
if (req.user) {
|
if (req.user) {
|
||||||
var u = _.clone(req.user.dataValues);
|
var u = _.clone(req.user.dataValues);
|
||||||
@@ -39,6 +41,88 @@ router.get('/current', function(req, res, next) {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function createChargebeeCheckout(req, res, plan_id, email, name, company) {
|
||||||
|
var nameParts = name.split(" ");
|
||||||
|
var firstName = nameParts.shift();
|
||||||
|
var lastName = nameParts.join(" ");
|
||||||
|
|
||||||
|
chargebee.hosted_page.checkout_new({
|
||||||
|
subscription: {
|
||||||
|
plan_id: plan_id
|
||||||
|
},
|
||||||
|
customer: {
|
||||||
|
first_name: firstName,
|
||||||
|
last_name: lastName,
|
||||||
|
email: email,
|
||||||
|
company: company,
|
||||||
|
}
|
||||||
|
}).request(function(error,result) {
|
||||||
|
if (error) {
|
||||||
|
console.log(error);
|
||||||
|
res.status(400).json({"error":error+""});
|
||||||
|
} else {
|
||||||
|
res.status(200).json({"chargebee_checkout":result.hosted_page});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function createUser(req, res, email, nickname, password) {
|
||||||
|
bcrypt.genSalt(10, function(err, salt) {
|
||||||
|
bcrypt.hash(password, salt, function(err, hash) {
|
||||||
|
crypto.randomBytes(16, function(ex, buf) {
|
||||||
|
var token = buf.toString('hex');
|
||||||
|
|
||||||
|
var u = {
|
||||||
|
_id: uuidv4(),
|
||||||
|
email: email,
|
||||||
|
account_type: "email",
|
||||||
|
nickname: nickname,
|
||||||
|
password_hash: hash,
|
||||||
|
prefs_language: req.i18n.locale,
|
||||||
|
confirmation_token: token
|
||||||
|
};
|
||||||
|
|
||||||
|
db.User.create(u)
|
||||||
|
.error(err => {
|
||||||
|
res.sendStatus(400);
|
||||||
|
})
|
||||||
|
.then(u => {
|
||||||
|
var homeFolder = {
|
||||||
|
_id: uuidv4(),
|
||||||
|
name: req.i18n.__("home"),
|
||||||
|
space_type: "folder",
|
||||||
|
creator_id: u._id
|
||||||
|
};
|
||||||
|
db.Space.create(homeFolder)
|
||||||
|
.error(err => {
|
||||||
|
res.sendStatus(400);
|
||||||
|
})
|
||||||
|
.then(homeFolder => {
|
||||||
|
u.home_folder_id = homeFolder._id;
|
||||||
|
u.save()
|
||||||
|
.then(() => {
|
||||||
|
// home folder created,
|
||||||
|
// auto accept pending invites
|
||||||
|
db.Membership.update({
|
||||||
|
"state": "active"
|
||||||
|
}, {
|
||||||
|
where: {
|
||||||
|
"email_invited": u.email,
|
||||||
|
"state": "pending"
|
||||||
|
}
|
||||||
|
});
|
||||||
|
res.status(201).json({});
|
||||||
|
})
|
||||||
|
.error(err => {
|
||||||
|
res.status(400).json(err);
|
||||||
|
});
|
||||||
|
})
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
// create user
|
// create user
|
||||||
router.post('/', function(req, res) {
|
router.post('/', function(req, res) {
|
||||||
if (!req.body["email"] || !req.body["password"]) {
|
if (!req.body["email"] || !req.body["password"]) {
|
||||||
@@ -51,6 +135,7 @@ router.post('/', function(req, res) {
|
|||||||
var password = req.body["password"];
|
var password = req.body["password"];
|
||||||
var password_confirmation = req.body["password_confirmation"];
|
var password_confirmation = req.body["password_confirmation"];
|
||||||
var invite_code = req.body["invite_code"];
|
var invite_code = req.body["invite_code"];
|
||||||
|
var company = req.body["company"] || "";
|
||||||
|
|
||||||
if (password_confirmation != password) {
|
if (password_confirmation != password) {
|
||||||
res.status(400).json({"error":"password_confirmation"});
|
res.status(400).json({"error":"password_confirmation"});
|
||||||
@@ -67,67 +152,17 @@ router.post('/', function(req, res) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var createUser = function() {
|
|
||||||
bcrypt.genSalt(10, function(err, salt) {
|
|
||||||
bcrypt.hash(password, salt, function(err, hash) {
|
|
||||||
crypto.randomBytes(16, function(ex, buf) {
|
|
||||||
var token = buf.toString('hex');
|
|
||||||
|
|
||||||
var u = {
|
|
||||||
_id: uuidv4(),
|
|
||||||
email: email,
|
|
||||||
account_type: "email",
|
|
||||||
nickname: nickname,
|
|
||||||
password_hash: hash,
|
|
||||||
prefs_language: req.i18n.locale,
|
|
||||||
confirmation_token: token
|
|
||||||
};
|
|
||||||
|
|
||||||
db.User.create(u)
|
|
||||||
.error(err => {
|
|
||||||
res.sendStatus(400);
|
|
||||||
})
|
|
||||||
.then(u => {
|
|
||||||
var homeFolder = {
|
|
||||||
_id: uuidv4(),
|
|
||||||
name: req.i18n.__("home"),
|
|
||||||
space_type: "folder",
|
|
||||||
creator_id: u._id
|
|
||||||
};
|
|
||||||
db.Space.create(homeFolder)
|
|
||||||
.error(err => {
|
|
||||||
res.sendStatus(400);
|
|
||||||
})
|
|
||||||
.then(homeFolder => {
|
|
||||||
u.home_folder_id = homeFolder._id;
|
|
||||||
u.save()
|
|
||||||
.then(() => {
|
|
||||||
// home folder created,
|
|
||||||
// auto accept pending invites
|
|
||||||
db.Membership.update({
|
|
||||||
"state": "active"
|
|
||||||
}, {
|
|
||||||
where: {
|
|
||||||
"email_invited": u.email,
|
|
||||||
"state": "pending"
|
|
||||||
}
|
|
||||||
});
|
|
||||||
res.status(201).json({});
|
|
||||||
})
|
|
||||||
.error(err => {
|
|
||||||
res.status(400).json(err);
|
|
||||||
});
|
|
||||||
})
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
db.User.findAll({where: {email: email}})
|
db.User.findAll({where: {email: email}})
|
||||||
.then(users => {
|
.then(users => {
|
||||||
if (users.length == 0) {
|
if (users.length == 0) {
|
||||||
createUser();
|
if (config.get('chargebee_integration')) {
|
||||||
|
// sign up via paid plan trial
|
||||||
|
createChargebeeCheckout(req, res, config.get('chargebee_default_plan_id'), email, nickname, company);
|
||||||
|
// TODO: createUser after chargebee checkout
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
createUser(req, res, email, nickname, password);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
res.status(400).json({"error":"user_email_already_used"});
|
res.status(400).json({"error":"user_email_already_used"});
|
||||||
}
|
}
|
||||||
|
|||||||
10
spacedeck.js
10
spacedeck.js
@@ -23,6 +23,8 @@ const express = require('express');
|
|||||||
const app = express();
|
const app = express();
|
||||||
const serveStatic = require('serve-static');
|
const serveStatic = require('serve-static');
|
||||||
|
|
||||||
|
const chargebee = require('chargebee');
|
||||||
|
|
||||||
const isProduction = app.get('env') === 'production';
|
const isProduction = app.get('env') === 'production';
|
||||||
|
|
||||||
// workaround for libssl_conf.so error triggered by phantomjs
|
// workaround for libssl_conf.so error triggered by phantomjs
|
||||||
@@ -110,6 +112,14 @@ if (app.get('env') == 'development') {
|
|||||||
|
|
||||||
module.exports = app;
|
module.exports = app;
|
||||||
|
|
||||||
|
// ChargeBee Integration (Optional)
|
||||||
|
if (config.get('chargebee_integration')) {
|
||||||
|
chargebee.configure({
|
||||||
|
site: config.get('chargebee_site'),
|
||||||
|
api_key: config.get('chargebee_api_key')
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// CONNECT TO DATABASE
|
// CONNECT TO DATABASE
|
||||||
db.init();
|
db.init();
|
||||||
|
|
||||||
|
|||||||
@@ -57,6 +57,9 @@
|
|||||||
<script src="/javascripts/spacedeck_directives.js"></script>
|
<script src="/javascripts/spacedeck_directives.js"></script>
|
||||||
<script src="/javascripts/spacedeck_vue.js"></script>
|
<script src="/javascripts/spacedeck_vue.js"></script>
|
||||||
|
|
||||||
|
<!-- TODO: only include based on config -->
|
||||||
|
<script src="https://js.chargebee.com/v2/chargebee.js"></script>
|
||||||
|
|
||||||
<script>if (window.module) module = window.module;</script>
|
<script>if (window.module) module = window.module;</script>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user