Ghost/ghost/members-ssr
2021-05-24 10:26:15 +01:00
..
test Ran slimer new members-ssr 2019-04-16 12:22:55 +02:00
.eslintrc.js Ran slimer new members-ssr 2019-04-16 12:22:55 +02:00
example.js Updated example.js to reflect new API 2019-09-16 13:58:05 +08:00
index.js Moved members geolocation fetch/update into members-ssr (#151) 2020-06-04 13:20:19 +01:00
LICENSE 2021 2021-01-25 16:34:32 +00:00
package.json Update dependency @types/cookies to v0.7.6 2021-05-24 10:26:15 +01:00
README.md 2021 2021-01-25 16:34:32 +00:00
tsconfig.json Added tsconfig.json to members-ssr 2019-09-16 13:58:05 +08:00

Members Ssr

Install

npm install members-ssr --save

or

yarn add members-ssr

Usage

const MembersSSR = require('./');

const {
    exchangeTokenForSession,
    getMemberDataFromSession,
    deleteSession
} = MembersSSR({
    cookieMaxAge: 1000 * 60 * 60 * 24 * 184, // 184 days max cookie age (default)
    cookieSecure: true, // Secure cookie (default)
    cookieName: 'members-ssr', // Name of cookie (default)
    cookiePath: '/', // Path of cookie (default)
    cookieKeys: 'some-coole-secret', // Key to sign cookie with
    getMembersApi: () => membersApiInstance // Used to fetch data and verify tokens
});

const handleError = res => err => {
    res.writeHead(err.statusCode);
    res.end(err.message);
};

require('http').createServer((req, res) => {
    if (req.method.toLowerCase() === 'post') {
        exchangeTokenForSession(req, res).then((member) => {
            res.writeHead(200);
            res.end(JSON.stringify(member));
        }).catch(handleError(res));
    } else if (req.method.toLowerCase() === 'delete') {
        deleteSession(req, res).then(() => {
            res.writeHead(204);
            res.end();
        }).catch(handleError(res));
    } else {
        getMemberDataFromSession(req, res).then((member) => {
            res.writeHead(200, {
                'Content-Type': 'application/json'
            });
            res.end(JSON.stringify(member));
        }).catch(handleError(res));
    }
}).listen(3665);

Develop

This is a mono repository, managed with lerna.

Follow the instructions for the top-level repo.

  1. git clone this repo & cd into it as usual
  2. Run yarn to install top-level dependencies.

Run

  • yarn dev

Test

  • yarn lint run just eslint
  • yarn test run lint and tests

Copyright & License

Copyright (c) 2013-2021 Ghost Foundation - Released under the MIT license.