Comments (8)
Casbin.NET follows Golang's Casbin's work flow. So please send a GitHub issue to: https://github.com/casbin/casbin/blob/master/internal_api.go#L22 first
from casbin.net.
I have go through GoLang's work flow.I have following doubts.
if !ruleAdded {
return ruleAdded, nil
}
it says if not equal to ruleAdded
return become true or not ?? What does return ruleAdded
mean here?Does it give true or false ?
from casbin.net.
This control structure means, that if ruleAdded
is false, it means if the rule is not added to the memory, the function returns false, nil(error)
.
from casbin.net.
This control structure means, that if
ruleAdded
is false, it means if the rule is not added to the memory, the functionreturns false, nil(error)
.
@divypatel9881
Now clear.Thanks for the response.
from casbin.net.
In InternalEnforcer.cs, there are 3 methods add or remove policy data. All these methods will add or delete data in memory first then call adapter to perform the mutation of data in data store behind the adapter.
It will cause data inconsistency issue if no revert or rollback logic in all those methods. Please refers to the bold area of the partial code below:
bool ruleAdded = model.AddPolicy(sec, ptype, rule); if (!ruleAdded) { return false; } if (adapter != null && autoSave) { try { await adapter.AddPolicyAsync(sec, ptype, rule); } catch (NotImplementedException) { } catch (Exception e) { **// rollback logic to revert the related memory data** throw e; } if (watcher != null) { // error intentionally ignored watcher.Update(); } }
Why not catching for NotImplementedException
? Don't we need to show at lease error message ?
from casbin.net.
I think we agreed on updating adapter first, then update memory in Golang: casbin/casbin#415 (comment). Let's follow the similar pattern in .NET. Can anyone make a PR for it?
from casbin.net.
@huazhikui @xcaptain @sagilio @twchiam can you work on this one?
from casbin.net.
from casbin.net.
Related Issues (20)
- .NET 6 support HOT 6
- InvalidOperationException when Enforcing HOT 4
- ParseException when pass a `RequestValue` to `Enforce` method HOT 9
- Fix CI error HOT 4
- An expression cannot be used in this context because it cannot be passed or returned by reference HOT 4
- Enforcer.Enforce throws exception when model contains similar definitions HOT 3
- Does using Casbin.NET support defining multiple M's in matchers? For example, m1 m2 HOT 3
- Casbin .NET doesn't support commas in policy HOT 3
- Where can I find ASP.NET 6 examples? HOT 7
- Check collection in ABAC with policy HOT 4
- Updating Policies directly on the IPolicyStore model not reflected in Enforcer HOT 4
- Rules work on Casbin Editor but not on Casbin.Net HOT 6
- Use semantic-release to auto release new versions HOT 2
- Apply politic to objects of different class going to excaption, but in posible in Go version HOT 5
- .NET library does not support multi-line mode with '\' line feeds HOT 1
- Cannot add named groups in Casbin v2 HOT 3
- Cannot get Policy with null value in EF core Adapter. HOT 8
- Enforcer hangs during multi-threaded modifications HOT 8
- bug: fix CI error: error: Response status code does not indicate success: 413 (The total packages size for the pending uploads is too large. The feed owner may have to upgrade the MyGet subscription to resolve this issue.). HOT 2
- How to return a custom type instead of using IQueryable type in IPolicyFilter HOT 3
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from casbin.net.