Skip to content

Latest commit

 

History

History
101 lines (66 loc) · 2.79 KB

README.md

File metadata and controls

101 lines (66 loc) · 2.79 KB

wiselike

自己的 wiselike 自己救

Development

Getting start

# install dependencies
yarn install

# develop web
yarn dev-web # port 8000

# webpack-bundle-analyzer
npm run build --report #http://127.0.0.1:8888/

# .env
cp .env.example .env
# Then update .env for DISCOURSE_SSO_SECRET, DISCOURSE_API_KEY and DISCOURSE_API_USERNAME

# develop API proxy (requires .env to be set)
yarn dev-proxy # port 9000

Proxy Server Development

Proxy APIs

With yarn dev-proxy, proxy server is serving on http://localhost:9000 by default.

Login
  • GET https://proxy.wiselike.tw/login
  • return json: {'sso': '{sso}', 'sig': '{sig}', 'username': '{username}'}
List all users
  • GET https://proxy.wiselike.tw/users
Get user profile
  • GET https://proxy.wiselike.tw/users/{user}
Get my profile
  • GET https://proxy.wiselike.tw/me?sso={sso}&sig={sig}
Get my username
  • GET https://proxy.wiselike.tw/whoami?sso={sso}&sig={sig}
Get wisdoms of a user
  • GET https://proxy.wiselike.tw/users/{user}/wisdoms
Ask a question
  • POST https://proxy.wiselike.tw/users/{user}/wisdoms?sso={sso}&sig={sig}
  • HTTP Body: ?title={title}&raw={raw}
Replay question
  • POST https://proxy.wiselike.tw/users/{user}/wisdoms/topic?sso={sso}&sig={sig}
Create Profile
  • POST https://proxy.wiselike.tw/users/{user}/createprofile?sso={sso}&sig={sig}

sso, sig and username

  • sso and sig should keep private, after signing in through the proxy /login API, browser stores sso and sig in Localstroage. You should pass sso and sig to proxy APIs on all user-specific operations.
  • username was stored in localStorage too after signing in. However, please use username only for display purpose, never trust its value.

Production

node build/build.js

pm2 start ./ecosystem.config.js

(After Discourse v1.9.3 change [slug generation method] setting from 'none' to 'ascii'.)

Design - Naming

Entities

  • Profile - A profile page of a member
  • Wisdom - A thread of a question and its replies. A Wisdom belongs to a profile.
  • Member - A registered user.
  • Guest - A guest user.

Actions

  • Register / Login
  • Ask - Ask a quesion
  • Answer / Reply - Answer / reply to a question.
  • Subscribe
  • Appreciate

Design - User stories

  • As a guest, I can sign on by Discourse SSO
  • As a member, I can ask questions on s page, these unanswered questions prviate are only accessible by the authors (askers) and the profile owner.
  • As a member, I can reply (answer) questions on my page, and then these answered questions public .
  • As a member, I can reply to any public Wisdoms.
  • As a guest, I can read any public Wisdoms.
  • As a member, I can update my profile (page) information.Wisdomsbecome Wisdomsaka someone