aboutsummaryrefslogtreecommitdiff
path: root/nixpkgs/nixos/modules/services/networking/flashpolicyd.nix
diff options
context:
space:
mode:
Diffstat (limited to 'nixpkgs/nixos/modules/services/networking/flashpolicyd.nix')
-rw-r--r--nixpkgs/nixos/modules/services/networking/flashpolicyd.nix84
1 files changed, 84 insertions, 0 deletions
diff --git a/nixpkgs/nixos/modules/services/networking/flashpolicyd.nix b/nixpkgs/nixos/modules/services/networking/flashpolicyd.nix
new file mode 100644
index 00000000000..9c51b88ef67
--- /dev/null
+++ b/nixpkgs/nixos/modules/services/networking/flashpolicyd.nix
@@ -0,0 +1,84 @@
+{ config, lib, pkgs, ... }:
+
+with lib;
+
+let
+
+ cfg = config.services.flashpolicyd;
+
+ flashpolicyd = pkgs.stdenv.mkDerivation {
+ name = "flashpolicyd-0.6";
+
+ src = pkgs.fetchurl {
+ name = "flashpolicyd_v0.6.zip";
+ url = "https://download.adobe.com/pub/adobe/devnet/flashplayer/articles/socket_policy_files/flashpolicyd_v0.6.zip";
+ sha256 = "16zk237233npwfq1m4ksy4g5lzy1z9fp95w7pz0cdlpmv0fv9sm3";
+ };
+
+ buildInputs = [ pkgs.unzip pkgs.perl ];
+
+ installPhase = "mkdir $out; cp -pr * $out/; chmod +x $out/*/*.pl";
+ };
+
+ flashpolicydWrapper = pkgs.writeScriptBin "flashpolicyd"
+ ''
+ #! ${pkgs.runtimeShell}
+ exec ${flashpolicyd}/Perl_xinetd/in.flashpolicyd.pl \
+ --file=${pkgs.writeText "flashpolixy.xml" cfg.policy} \
+ 2> /dev/null
+ '';
+
+in
+
+{
+
+ ###### interface
+
+ options = {
+
+ services.flashpolicyd = {
+
+ enable = mkOption {
+ default = false;
+ description =
+ ''
+ Whether to enable the Flash Policy server. This is
+ necessary if you want Flash applications to make
+ connections to your server.
+ '';
+ };
+
+ policy = mkOption {
+ default =
+ ''
+ <?xml version="1.0"?>
+ <!DOCTYPE cross-domain-policy SYSTEM "/xml/dtds/cross-domain-policy.dtd">
+ <cross-domain-policy>
+ <site-control permitted-cross-domain-policies="master-only"/>
+ <allow-access-from domain="*" to-ports="*" />
+ </cross-domain-policy>
+ '';
+ description = "The policy to be served. The default is to allow connections from any domain to any port.";
+ };
+
+ };
+
+ };
+
+
+ ###### implementation
+
+ config = mkIf cfg.enable {
+
+ services.xinetd.enable = true;
+
+ services.xinetd.services = singleton
+ { name = "flashpolicy";
+ port = 843;
+ unlisted = true;
+ server = "${flashpolicydWrapper}/bin/flashpolicyd";
+ };
+
+ };
+
+}