mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-05 05:29:26 +08:00
* feat(auth): init auth package & collection * feat(auth): register * feat(auth): use authenticator * feat(auth): mapRoles * feat(auth): refactor * feat(auth): base auth class * feat(auth): add plugin * chore(auth): test * chore(auth): add test cases * feat(auth): authenticators pane * chore(auth): custom hook useAuthTypes * feat(auth): authenticator pane * chore(auth): store options schema using context * feat(auth): signInPage provider * feat(auth): signUpPage provider * chore(auth): solve build errors * chore(auth): add dependency * chore(auth): remove dependency cycles * chore(auth): add plugin-auth to preset * chore(auth): fix test * feat(auth): authenticator enable status * fix(test): fix test using new authentication * feat(auth): migration, set up basic auth * chore(auth): can set options ui by component * fix(test): workflow manunal.test * fix(test): typo * feat(auth): support multi-language * chore(auth): imporve code * chore(auth): hide button if no configuration * chore(auth): readme * chore(auth): remove allowSignup prop * chore(auth): move configure pane to edit form * fix(auth): jwt options bug * feat(auth): init sms-auth * chore(auth): at least authenticator required * chore(auth): add test * feat(auth): support sms auth * fix(auth): fix test * chore(auth): move findOrCreateUser to AuthModel * chore(auth): history compatible processing * feat(auth): support SAML auth * chore(auth): saml auth list * chore(saml-auth): improve ui * Merge branch 'main' into feat/authentication * chore(auth): improve code * fix(saml-auth): fix bug * fix(saml-auth): fix saml options * chore(saml-auth): compatible processing && ut * fix(auth): signin page bug * chore(auth): saml compatible processing * feat(auth): oidc-auth * fix(oidc-auth): bug * fix(oidc-auth): bug * fix(auth): fix test * chore(auth): filter enabled authenticator * chore(oidc): add field map * chore(auth): update readme * docs(auth): create sms-auth readme * feat(auth): allow signup config * test(auth): fix test * feat(auth): allow saml and oidc use http * chore(oidc-auth): extends timeout * docs(auth): update readme * feat(auth): support sort * docs(saml): update readme * feat(auth): support sort all authenticator * Merge branch 'main' into feat/authentication * Merge branch 'main' into feat/authentication * feat: improve code * docs(auth): add doc * Merge branch 'main' into feat/authentication * chore: update yarn.lock * feat: improve code * chore(acl): write role to acl if it exists in database and not found … (#2001) * chore(acl): write role to acl if it exists in database and not found in acl * fix: test * fix: eager load with nested association (#2002) * chore: upgrade vitest * chore: edit * refactor: auth class * fix: set options * chore(acl): write role to acl if it exists in database and not found … (#2001) * chore(acl): write role to acl if it exists in database and not found in acl * fix: test * fix: eager load with nested association (#2002) * chore: upgrade vitest * chore: add migrations * test: fix api-client test * chore: add sms-auth * feat: avoid no permission after auth type disabled * fix: translation --------- Co-authored-by: chenos <chenlinxh@gmail.com>
125 lines
2.6 KiB
TypeScript
125 lines
2.6 KiB
TypeScript
import { ACL } from '@nocobase/acl';
|
|
import { Database } from '@nocobase/database';
|
|
import PluginUser from '@nocobase/plugin-users';
|
|
import { MockServer } from '@nocobase/test';
|
|
import { prepareApp } from './prepare';
|
|
|
|
describe('own test', () => {
|
|
let app: MockServer;
|
|
let db: Database;
|
|
let acl: ACL;
|
|
|
|
let pluginUser: PluginUser;
|
|
let adminToken: string;
|
|
let userToken: string;
|
|
|
|
let admin;
|
|
let user;
|
|
|
|
let role;
|
|
let agent;
|
|
let adminAgent;
|
|
let userAgent;
|
|
|
|
afterEach(async () => {
|
|
await app.destroy();
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
app = await prepareApp();
|
|
db = app.db;
|
|
|
|
const PostCollection = db.collection({
|
|
name: 'posts',
|
|
fields: [
|
|
{ type: 'string', name: 'title' },
|
|
{ type: 'belongsToMany', name: 'tags' },
|
|
],
|
|
createdBy: true,
|
|
});
|
|
|
|
const TagCollection = db.collection({
|
|
name: 'tags',
|
|
fields: [
|
|
{ type: 'string', name: 'name' },
|
|
{ type: 'belongsToMany', name: 'posts' },
|
|
],
|
|
createdBy: true,
|
|
});
|
|
|
|
const TestCollection = db.collection({
|
|
name: 'tests',
|
|
fields: [{ type: 'string', name: 'name' }],
|
|
});
|
|
|
|
await db.sync();
|
|
|
|
agent = app.agent();
|
|
|
|
acl = app.acl;
|
|
|
|
role = await db.getRepository('roles').findOne({
|
|
filter: {
|
|
name: 'admin',
|
|
},
|
|
});
|
|
|
|
admin = await db.getRepository('users').findOne();
|
|
|
|
pluginUser = app.getPlugin('users');
|
|
|
|
adminAgent = app.agent().login(admin);
|
|
|
|
user = await db.getRepository('users').create({
|
|
values: {
|
|
nickname: 'test',
|
|
roles: ['admin'],
|
|
},
|
|
});
|
|
|
|
userAgent = app.agent().login(user);
|
|
});
|
|
|
|
it('should list without createBy', async () => {
|
|
await adminAgent
|
|
.patch('/roles/admin')
|
|
.send({
|
|
strategy: {
|
|
actions: ['view:own'],
|
|
},
|
|
})
|
|
.set({ Authorization: 'Bearer ' + adminToken });
|
|
|
|
const response = await userAgent.get('/tests:list');
|
|
expect(response.statusCode).toEqual(200);
|
|
});
|
|
|
|
it('should delete with createdBy', async () => {
|
|
await adminAgent.resource('roles').update({
|
|
filterByTk: 'admin',
|
|
values: {
|
|
strategy: {
|
|
actions: ['view:own', 'create', 'destroy:own'],
|
|
},
|
|
},
|
|
});
|
|
|
|
let response = await userAgent.resource('posts').create({
|
|
values: {
|
|
title: 't1',
|
|
},
|
|
});
|
|
|
|
expect(response.statusCode).toEqual(200);
|
|
|
|
const data = response.body;
|
|
const id = data.data['id'];
|
|
|
|
response = await userAgent.resource('posts').destroy({
|
|
filterByTk: id,
|
|
});
|
|
expect(response.statusCode).toEqual(200);
|
|
expect(await db.getRepository('posts').count()).toEqual(0);
|
|
});
|
|
});
|