Skip to content

ssergomol/E-Wallet

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation


E-Wallet

Содержание
  1. Описание проекта
  2. Возможности сервиса
  3. Установка и запуск сервера
  4. Контакты

Описание проекта

Сервис для управления балансом пользователей, который позволяет осуществлять основные денежные операции

Технологии

  • GoLang-logo
  • PostgreSQL-logo
  • Docker-logo

(back to top)

Возможности сервиса

  • Сервис предоставляет HTTP API в формате JSON
  • Зачисление средств на баланс
  • Cписание денег c баланса
  • Получение баланса пользователя
  • Восстановление истории запросов для отдельного пользователя
    в случае, если сервер упадёт

(back to top)

Установка и запуск сервера

  1. Установите Docker и docker-compose для своей ОС https://docs.docker.com/compose/install/
  2. Склонируйте репозиторий и перейдите в корень проекта
git clone https://github.com/ssergomol/E-Wallet.git && cd ./E-Wallet
  1. Выполните
docker-compose up

(back to top)

Примеры запросов и возможные ответы

  1. Метод зачисление средств на баланс
    Принимает ID пользователя, ID операции (0 в данном случае) и сумму зачисления

Запрос:

curl --header "Content-Type: application/json" \
  --request POST \
  --data '{"user_id":0, "service_id": 0, "price": "100.00"}' \
  http://localhost:8080/balance

Тело ответа (история запросов):

[
    {
        "user_id": 0,
        "service_id":0,
        "price":"100.00",
        "description":"Replenish balance"
    }
]
  1. Метод Cписания денег c баланса
    Принимает ID пользователя, ID услуги (1 в данном случае) и сумму списания

Запрос:

curl --header "Content-Type: application/json" \
  --request POST \
  --data \
  '{ "id": 0, "user_id": 0, "service_id": 1, "price":"10.00"}' \
  http://localhost:8080/accounts

Тело ответа (история запросов):

[
    {
        "user_id": 0,
        "service_id":0,
        "price":"100.00",
        "description":"Replenish balance"
    },
    {
       "user_id": 0,
        "service_id":1,
        "price":"10.00",
        "description":"Spend funds" 
    }
]
  1. Метод получения баланса пользователя
    Принимает id пользователя Запрос:
curl --header "Content-Type: application/json" \
  --request GET \
  --data \
  '{ "id": 0 }' \
  http://localhost:8080/balance

Тело ответа (в случае успеха возвращает id пользователя и его баланс):

{ 
    "id": 0,
    "sum": "1000.00"
}

Контакты

Сергей Молчанов - @ssergomol - ssergomoll@gmail.com

(back to top)

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published