poodinis/example/annotations/app.d

68 lines
1.8 KiB
D
Raw Normal View History

2017-02-13 20:20:35 +01:00
/**
* Poodinis Dependency Injection Framework
2023-01-11 00:01:51 +01:00
* Copyright 2014-2023 Mike Bierlee
2017-02-13 20:20:35 +01:00
* This software is licensed under the terms of the MIT license.
* The full terms of the license can be found in the LICENSE file.
*/
import poodinis;
import std.random;
import std.digest.md;
import std.stdio;
import std.conv;
class SecurityAuditor {
void submitAudit() {
2017-02-13 20:20:35 +01:00
writeln("Hmmmyes I have received your audit. It is.... adequate.");
}
}
class SuperSecurityDevice {
2017-02-13 20:20:35 +01:00
private int seed;
this() {
2017-02-13 20:20:35 +01:00
auto randomGenerator = Random(unpredictableSeed);
seed = uniform(0, 999, randomGenerator);
}
string getPassword() {
2017-02-13 20:20:35 +01:00
return to!string(seed) ~ "t1m3sp13!!:";
}
}
class SecurityManager {
@Inject private SuperSecurityDevice levelOneSecurity;
2017-02-13 20:20:35 +01:00
@Inject @AssignNewInstance private SuperSecurityDevice levelTwoSecurity;
2017-02-13 20:20:35 +01:00
@Inject @OptionalDependency private SecurityAuditor auditor;
2017-02-13 20:20:35 +01:00
void doAudit() {
if (auditor !is null) {
2017-02-13 20:20:35 +01:00
auditor.submitAudit();
} else {
2017-02-13 20:20:35 +01:00
writeln("I uh, will skip the audit for now...");
}
}
}
void main() {
2017-02-13 20:20:35 +01:00
auto dependencies = new shared DependencyContainer();
dependencies.register!SuperSecurityDevice; // Registered with the default "Single instance" scope
dependencies.register!SecurityManager;
auto manager = dependencies.resolve!SecurityManager;
writeln("Password for user one: " ~ manager.levelOneSecurity.getPassword());
writeln("Password for user two: " ~ manager.levelTwoSecurity.getPassword());
if (manager.levelOneSecurity is manager.levelTwoSecurity) {
2017-02-13 20:20:35 +01:00
writeln("SECURITY BREACH!!!!!"); // Should not be printed since levelTwoSecurity is a new instance.
} else {
2017-02-13 20:20:35 +01:00
writeln("Security okay!");
}
manager.doAudit(); // Will not cause the SecurityAuditor to print, since we didn't register a SecurityAuditor.
}