Skip to main content

Установка

Эти параграфы помогут вам развернуть Casnode на вашем сервере. Если вы хотите установить Casnode с помощью панели BT или Docker, пожалуйста, ознакомьтесь с подробностями на сайте: BT Panel и Docker.

Сначала клонируйте кастронд:

git clone https://github.com/casbin/casnode

и выполните эти шаги, чтобы легко настроить свой собственный форум!

Производственная среда

1. Настроить корпус

Кашузел использует Casdoor для управления членами. Поэтому вам нужно создать организацию и приложение для Casnode в экземпляре Касдвери.

Выполните следующие шаги для настройки кассена для Casnode:

  • Перейдите в Касдорф (нажмите здесь для деталей Касдор)

  • Войдите в организацию "Встроенная"

  • Нажмите организаций в верхней панели

  • Нажмите кнопку добавить

  • Remember the Organization name, here I use casnode as my organization name: организация

  • Нажмите Приложения в верхней панели

  • Нажмите кнопку добавить

  • Запомнить имя приложения, здесь я использую форум в качестве моего имени приложения:

  • Нажмите Изменить

приложение

  • Выберите организацию, которую вы только что создали в качестве организации приложения

выбрать

редиректы

  • Нажмите Сохранить и запомните ID клиента и ключ клиента

клиент

2. Изменить conf/app.conf

Вот объяснение элементов конфигурации:

Database connection

Casnode database

Имя водителя = mysql
dataSourceName = root:123@tcp(localhost:3306)/
dbName = casnode

Casdoor database

casdoorDbName = casdoor
tip

Casdoor's driverName and dataSourceName are the same as casnode by default. If your Casdoor and Casnode are not in the same database, you can set up the casdoor database in casdoor/adapter.go

Here we provide an example:

  1. Add casdoor configuration in conf/app.conf:

    casdoorDriverName =
    casdoorDataSourceName =
  2. Modify the func InitCasdoorAdapter():

        adapter = NewAdapter(beego.AppConfig.String("casdoorDriverName"), beego.AppConfig.String("casdoorDriverName"), beego.AppConfig.String("casdoorDbName"))

Object Storage Service (Casnode uses OSS to store resources)

OSSProvider = ""
accessKeyID = ""
accessKeySecret = ""
OSSCustomDomain = ""
OSSBasicPath = ""
OSSRegion = ""
OSSEndPoint = ""
OSSBucket = ""

If you can not access Google in normal ways, you need to set up a http proxy here:

httpProxy = "127.0.0.1:10808"

Casdoor config

# Your Casdoor endpoint in step 1
casdoorEndpoint = http://localhost:8000

# Client ID you copied in step 1
clientId = xxx

# Client Secret you copied in step 1
clientSecret = xxx

jwtSecret = CasdoorSecret

# Organization name in step 1
casdoorOrganization = "casnode"

3. Изменить web/src/Conf.js

export const AuthConfig = {
// Your Casdoor endpoint in step 1
serverUrl: "http://localhost:7001",

// Client ID you copied in step 1
clientId: "014ae4bd048734ca2dea",

// Application name you copied in step 1
appName: "app-casnode",

// Organization name you copied in step 1
organizationName: "casnode",
};

4. Построить фронт

In folder web, run the following commands:

yarn install && yarn run build

5. Собрать конец

In repository root, run:

go build
./casnode

Then the Casnode app should run on port 7000. You can setup a nginx proxy pass to manage SSL or something else.

For most of site owners who want to develop a forum using Casnode, steps above is enough. But if you are a developer, want to contribute to Casnode, or modify the code to suit your own environment, then you can run Casnode in the developing mode. Please follow these steps to start developing mode:

Окружение Dev

1. Сделайте шаг 1-3 выше

4. Вернуться к концу

go run main.go

5. Запустить конец фронта

In web folder:

yarn install
yarn run start

Now, Casnode runs its front end at port 3000 and runs it's back end at port 7000. You can modify the code and see what will happen.

caution

The front end uses these codes to determine whether it is a dev mode:

export function initServerUrl() {
const hostname = window.location.hostname;
if (hostname === "localhost") {
ServerUrl = `http://${hostname}:7000`;
}
}

It means if hostname is localhost, then you are in dev mode. If not, then you are in productive mode. Port of the back end is not same in dev mode and productive mode, so please do not use 127.0.0.1 instead of localhost in your browser in dev mode.