mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-01-23 23:46:52 +00:00
316bd65296
* mws authentication * add more tests and permission checkers * add logic to ensure that only authenticated users' requests are handled * add custom login page * Implement user authentication as well as session handling * work on user operations authorization * add middleware to route handlers for bags & tiddlers routes * add feature that only returns the tiddlers and bags which the user has permission to access on index page * refactor auth routes & added user management page * fix Ci Test failure issue * fix users list page, add manage roles page * add commands and scripts to create new user & assign roles and permissions * resolved ci-test failure * add ACL permissions to bags & tiddlers on creation * fix comments and access control list bug * fix indentation issues * working on user profile edit * remove list users command & added support for database in server options * implement user profile update and password change feature * update plugin readme * implement command which triggers protected mode on the server * revert server-wide auth flag. Implement selective authorization * ACL management feature * Complete Access control list implementation * Added support to manage users' assigned role by admin * fix comments * fix comment * Add user profile management and account deletion functionality * add success and error message feedback for user profile operations * fix indentation issues * Add command to create admin user if none exists when the start command is executed * refactor annonymous user flow with create admin implementation * remove mws-add-user from start command
160 lines
3.4 KiB
Plaintext
160 lines
3.4 KiB
Plaintext
title: $:/plugins/tiddlywiki/multiwikiserver/templates/manage-user
|
|
|
|
<$tiddler tiddler="$:/plugins/tiddlywiki/multiwikiserver/templates/mws-header">
|
|
<$set name="page-title" value="User Profile">
|
|
<$transclude/>
|
|
</$set>
|
|
</$tiddler>
|
|
<div class="main-wrapper">
|
|
<div class="user-profile-container">
|
|
<div class="user-profile-header">
|
|
<div class="user-profile-avatar">
|
|
<$text text={{{ [<user-initials>uppercase[]] }}}/>
|
|
</div>
|
|
<h1 class="user-profile-name"><$text text={{{ [<user>jsonget[username]] }}}/></h1>
|
|
<p class="user-profile-email"><$text text={{{ [<user>jsonget[email]] }}}/></p>
|
|
</div>
|
|
|
|
<div class="user-profile-details">
|
|
<div class="user-profile-item">
|
|
<span class="user-profile-label">User ID:</span>
|
|
<span class="user-profile-value"><$text text={{{ [<user>jsonget[user_id]] }}}/></span>
|
|
</div>
|
|
<div class="user-profile-item">
|
|
<span class="user-profile-label">Created At:</span>
|
|
<span class="user-profile-value"><$text text={{{ [<user>jsonget[created_at]split[T]first[]] }}}/></span>
|
|
</div>
|
|
<div class="user-profile-item">
|
|
<span class="user-profile-label">Last Login:</span>
|
|
<span class="user-profile-value"><$text text={{{ [<user>jsonget[last_login]split[T]first[]] }}}/></span>
|
|
</div>
|
|
|
|
<div class="user-profile-roles">
|
|
<h2>User Role</h2>
|
|
<ul>
|
|
<li>
|
|
<$text text={{{ [<user-role>jsonget[role_name]] }}}/>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<% if [<user-is-admin>match[yes]] %>
|
|
<$tiddler tiddler="$:/plugins/tiddlywiki/multiwikiserver/templates/manage-user-account">
|
|
<$transclude/>
|
|
</$tiddler>
|
|
<% elseif [<is-current-user-profile>match[yes]] %>
|
|
<$tiddler tiddler="$:/plugins/tiddlywiki/multiwikiserver/templates/manage-user-account">
|
|
<$transclude/>
|
|
</$tiddler>
|
|
<% endif %>
|
|
|
|
<$let flash-message={{{ [[$:/state/mws/flash-message]get[text]] }}}>
|
|
<$reveal type="nomatch" state="$:/state/mws/flash-message" text="">
|
|
<div class="flash-message">
|
|
<$text text=<<flash-message>>/>
|
|
</div>
|
|
<$action-setfield $tiddler="$:/state/mws/flash-message" text=""/>
|
|
</$reveal>
|
|
</$let>
|
|
</div>
|
|
|
|
<style>
|
|
.main-wrapper {
|
|
display: flex;
|
|
flex-direction: row;
|
|
gap: 5px;
|
|
max-width: 80vw;
|
|
margin: auto;
|
|
}
|
|
|
|
.user-profile-container {
|
|
flex: 4;
|
|
margin: 2rem auto;
|
|
background: #fff;
|
|
border-radius: 8px;
|
|
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
|
|
overflow: hidden;
|
|
max-width: 600px;
|
|
}
|
|
|
|
.user-profile-header {
|
|
background: #3498db;
|
|
color: #fff;
|
|
padding: 2rem;
|
|
text-align: center;
|
|
}
|
|
|
|
.user-profile-avatar {
|
|
width: 120px;
|
|
height: 120px;
|
|
border-radius: 50%;
|
|
margin: 0 auto 1rem;
|
|
background: #fff;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
font-size: 3rem;
|
|
color: #3498db;
|
|
}
|
|
|
|
.user-profile-avatar * {
|
|
color: #3498db;
|
|
}
|
|
|
|
.user-profile-name {
|
|
font-size: 1.5rem;
|
|
margin: 0;
|
|
}
|
|
|
|
.user-profile-email {
|
|
font-size: 1rem;
|
|
opacity: 0.8;
|
|
margin: 0.5rem 0 0;
|
|
}
|
|
|
|
.user-profile-details {
|
|
padding: 2rem;
|
|
}
|
|
|
|
.user-profile-item {
|
|
margin-bottom: 1rem;
|
|
}
|
|
|
|
.user-profile-label {
|
|
font-weight: bold;
|
|
color: #555;
|
|
}
|
|
|
|
.user-profile-value {
|
|
color: #333;
|
|
}
|
|
|
|
.user-profile-roles {
|
|
margin-top: 2rem;
|
|
}
|
|
|
|
.user-profile-roles h2 {
|
|
font-size: 1.2rem;
|
|
color: #3498db;
|
|
margin-bottom: 1rem;
|
|
}
|
|
|
|
.user-profile-roles ul {
|
|
list-style-type: none;
|
|
padding: 0;
|
|
margin: 0;
|
|
}
|
|
|
|
.user-profile-roles li {
|
|
background: #f1f1f1;
|
|
padding: 0.5rem 1rem;
|
|
border-radius: 20px;
|
|
display: inline-block;
|
|
margin-right: 0.5rem;
|
|
margin-bottom: 0.5rem;
|
|
font-size: 0.9rem;
|
|
}
|
|
</style>
|