add room access options

This commit is contained in:
ghost 2023-12-05 19:44:43 +02:00
parent 96faf9464d
commit 71229df9e3
4 changed files with 23 additions and 6 deletions

6
.env
View File

@ -41,6 +41,12 @@ APP_KEVACOIN_MINE_ADDRESS=EDIT_ME
# Allowed room namespaces, separated with | (must be owned to accept posts)
APP_KEVACOIN_ROOM_NAMESPACES=EDIT_ME
# Allowed room namespaces for read only (e.g. project news) separated with |
APP_KEVACOIN_ROOM_NAMESPACES_READONLY=EDIT_ME
# Redirect from index page to default room
APP_KEVACOIN_ROOM_NAMESPACE_DEFAULT=EDIT_ME
# Allow remotes to create new rooms (namespaces)
APP_ADD_ROOM_REMOTE_IP_REGEX=/.*/

View File

@ -13,6 +13,8 @@ parameters:
app.kevacoin.username: '%env(APP_KEVACOIN_USERNAME)%'
app.kevacoin.password: '%env(APP_KEVACOIN_PASSWORD)%'
app.kevacoin.room.namespaces: '%env(APP_KEVACOIN_ROOM_NAMESPACES)%'
app.kevacoin.room.namespaces.readonly: '%env(APP_KEVACOIN_ROOM_NAMESPACES_READONLY)%'
app.kevacoin.room.namespace.default: '%env(APP_KEVACOIN_ROOM_NAMESPACE_DEFAULT)%'
app.kevacoin.mine.address: '%env(APP_KEVACOIN_MINE_ADDRESS)%'
app.kevacoin.mine.pool.url: '%env(APP_KEVACOIN_MINE_POOL_URL)%'
app.kevacoin.mine.solo.url: '%env(APP_KEVACOIN_MINE_SOLO_URL)%'

View File

@ -70,7 +70,7 @@ class ModuleController extends AbstractController
$name = $value['displayName'];
}
// Check namespace enabled as room in settings
// Check namespace enabled as room in .env
if (in_array($value['namespaceId'], $rooms))
{
$list[$value['namespaceId']] = $value['displayName'];
@ -95,6 +95,7 @@ class ModuleController extends AbstractController
Request $request
): Response
{
// Connect wallet
$client = new \Kevachat\Kevacoin\Client(
$this->getParameter('app.kevacoin.protocol'),
$this->getParameter('app.kevacoin.host'),
@ -103,18 +104,26 @@ class ModuleController extends AbstractController
$this->getParameter('app.kevacoin.password')
);
// Get room settings
$rooms = explode('|', $this->getParameter('app.kevacoin.room.namespaces'));
$readonly = explode('|', $this->getParameter('app.kevacoin.room.namespaces.readonly'));
// Get wallet namespaces (to enable post module there)
$namespaces = [];
$public = [];
foreach ((array) $client->kevaListNamespaces() as $value)
{
$namespaces[] = $value['namespaceId'];
// Check namespace enabled as room in .env
if (in_array($value['namespaceId'], $rooms) && !in_array($value['namespaceId'], $readonly))
{
$public[] = $value['namespaceId'];
}
}
return $this->render(
'default/module/post.html.twig',
[
'enabled' => in_array($request->get('namespace'), $namespaces),
'enabled' => in_array($request->get('namespace'), $public),
'namespace' => $request->get('namespace'),
'message' => $request->get('message'),
'user' => $request->get('user'),

View File

@ -23,7 +23,7 @@ class RoomController extends AbstractController
return $this->redirectToRoute(
'room_namespace',
[
'namespace' => explode('|', $this->getParameter('app.kevacoin.room.namespaces'))[0]
'namespace' => $this->getParameter('app.kevacoin.room.namespace.default')
]
);
}
@ -176,7 +176,7 @@ class RoomController extends AbstractController
return $this->redirectToRoute(
'room_namespace',
[
'namespace' => explode('|', $this->getParameter('app.kevacoin.room.namespaces'))[0]
'namespace' => $request->get('namespace')
]
);
}