diff options
author | Manuel Munz <freifunk@somakoma.de> | 2012-04-15 20:26:10 +0000 |
---|---|---|
committer | Manuel Munz <freifunk@somakoma.de> | 2012-04-15 20:26:10 +0000 |
commit | 84dadb80ab8b2af0f761c44d1cdc012ebc6d8a5b (patch) | |
tree | 602f20649f2a9c07286efe85ef90f84020982572 /applications/luci-transmission/luasrc/model/cbi/transmission.lua | |
parent | 4525a7b59d1f4004896b4a09d1c71b77da2e75a6 (diff) |
applications/transmission: Add support for transmission. Patch by Gabor Varga. #392
Diffstat (limited to 'applications/luci-transmission/luasrc/model/cbi/transmission.lua')
-rw-r--r-- | applications/luci-transmission/luasrc/model/cbi/transmission.lua | 231 |
1 files changed, 231 insertions, 0 deletions
diff --git a/applications/luci-transmission/luasrc/model/cbi/transmission.lua b/applications/luci-transmission/luasrc/model/cbi/transmission.lua new file mode 100644 index 0000000000..fa036fb0f9 --- /dev/null +++ b/applications/luci-transmission/luasrc/model/cbi/transmission.lua @@ -0,0 +1,231 @@ +--[[ +LuCI - Lua Configuration Interface - Transmission support + +Copyright 2012 Gabor Varga <vargagab@gmail.com> + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +$Id$ +]]-- + +require("luci.sys") +require("luci.util") +require("luci.model.ipkg") + +local uci = require "luci.model.uci".cursor() +local trport = uci:get_first("transmission", "transmission", "rpc_port") +local running = (luci.sys.call("pidof transmission-daemon > /dev/null") == 0) +local webinstalled = luci.model.ipkg.installed("transmission-web") +local button = "" +if running and webinstalled then + button = " <input type=\"button\" value=\" " .. translate("Open Web Interface") .. " \" onclick=\"window.open('http://'+window.location.host+':" .. trport .. "')\"/>" +end + +m = Map("transmission", "Transmission", translate("Transmission daemon is a simple bittorrent client, here you can configure the settings.") .. button) + +s=m:section(TypedSection, "transmission", translate("Global settings")) +s.addremove=false +s.anonymous=true + +enable=s:option(Flag, "enabled", translate("Enabled")) +enable.rmempty=false +config_dir=s:option(Value, "config_dir", translate("Config file directory")) +user=s:option(ListValue, "user", translate("Run daemon as user")) +local p_user +for _, p_user in luci.util.vspairs(luci.util.split(luci.sys.exec("cat /etc/passwd | cut -f 1 -d :"))) do + user:value(p_user) +end +cache_size_mb=s:option(Value, "cache_size_mb", translate("Cache size in MB")) + +bandwidth=m:section(TypedSection, "transmission", translate("Bandwidth settings")) +bandwidth.anonymous=true +alt_speed_enabled=bandwidth:option(Flag, "alt_speed_enabled", translate("Alternative speed enabled")) +alt_speed_enabled.enabled="true" +alt_speed_enabled.disabled="false" +alt_speed_down=bandwidth:option(Value, "alt_speed_down", translate("Alternative download speed"), "KB/s") +alt_speed_down:depends("alt_speed_enabled", "true") +alt_speed_up=bandwidth:option(Value, "alt_speed_up", translate("Alternative upload speed"), "KB/s") +alt_speed_up:depends("alt_speed_enabled", "true") +speed_limit_down_enabled=bandwidth:option(Flag, "speed_limit_down_enabled", translate("Speed limit down enabled")) +speed_limit_down_enabled.enabled="true" +speed_limit_down_enabled.disabled="false" +speed_limit_down=bandwidth:option(Value, "speed_limit_down", translate("Speed limit down"), "KB/s") +speed_limit_down:depends("speed_limit_down_enabled", "true") +speed_limit_up_enabled=bandwidth:option(Flag, "speed_limit_up_enabled", translate("Speed limit up enabled")) +speed_limit_up_enabled.enabled="true" +speed_limit_up_enabled.disabled="false" +speed_limit_up=bandwidth:option(Value, "speed_limit_up", translate("Speed limit up"), "KB/s") +speed_limit_up:depends("speed_limit_up_enabled", "true") +upload_slots_per_torrent=bandwidth:option(Value, "upload_slots_per_torrent", translate("Upload slots per torrent")) + +blocklists=m:section(TypedSection, "transmission", translate("Blocklists")) +blocklists.anonymous=true +blocklist_enabled=blocklists:option(Flag, "blocklist_enabled", translate("Block list enabled")) +blocklist_enabled.enabled="true" +blocklist_enabled.disabled="false" +blocklist_url=blocklists:option(Value, "blocklist_url", translate("Blocklist URL")) +blocklist_url:depends("blocklist_enabled", "true") + +fileslocations=m:section(TypedSection, "transmission", translate("Files and Locations")) +fileslocations.anonymous=true +download_dir=fileslocations:option(Value, "download_dir", translate("Download directory")) +incomplete_dir_enabled=fileslocations:option(Flag, "incomplete_dir_enabled", translate("Incomplete directory enabled")) +incomplete_dir_enabled.enabled="true" +incomplete_dir_enabled.disabled="false" +incomplete_dir=fileslocations:option(Value, "incomplete_dir", translate("Incomplete directory")) +incomplete_dir:depends("incomplete_dir_enabled", "true") +preallocation=fileslocations:option(ListValue, "preallocation", translate("preallocation")) +preallocation:value("0", translate("Off")) +preallocation:value("1", translate("Fast")) +preallocation:value("2", translate("Full")) +prefetch_enabled=fileslocations:option(Flag, "prefetch_enabled", translate("Prefetch enabled")) +rename_partial_files=fileslocations:option(Flag, "rename_partial_files", translate("Rename partial files")) +rename_partial_files.enableid="true" +rename_partial_files.disabled="false" +start_added_torrents=fileslocations:option(Flag, "start_added_torrents", translate("Automatically start added torrents")) +start_added_torrents.enabled="true" +start_added_torrents.disabled="false" +trash_original_torrent_files=fileslocations:option(Flag, "trash_original_torrent_files", translate("Trash original torrent files")) +trash_original_torrent_files.enabled="true" +trash_original_torrent_files.disabled="false" +umask=fileslocations:option(Value, "umask", "umask") +watch_dir_enabled=fileslocations:option(Flag, "watch_dir_enabled", translate("Enable watch directory")) +watch_dir_enabled.enabled="true" +watch_dir_enabled.disabled="false" +watch_dir=fileslocations:option(Value, "watch_dir", translate("Watch directory")) +watch_dir:depends("watch_dir_enabled", "true") + +misc=m:section(TypedSection, "transmission", translate("Miscellaneous")) +misc.anonymous=true +dht_enabled=misc:option(Flag, "dht_enabled", translate("DHT enabled")) +dht_enabled.enabled="true" +dht_enabled.disabled="false" +encryption=misc:option(ListValue, "encryption", translate("Encryption")) +encryption:value("0", translate("Off")) +encryption:value("1", translate("Preferred")) +encryption:value("2", translate("Forced")) +lazy_bitfield_enabled=misc:option(Flag, "lazy_bitfield_enabled", translate("Lazy bitfield enabled")) +lazy_bitfield_enabled.enabled="true" +lazy_bitfield_enabled.disabled="false" +lpd_enabled=misc:option(Flag, "lpd_enabled", translate("LPD enabled")) +lpd_enabled.enabled="true" +lpd_enabled.disabled="false" +message_level=misc:option(ListValue, "message_level", translate("Message level")) +message_level:value("0", translate("None")) +message_level:value("1", translate("Error")) +message_level:value("2", translate("Info")) +message_level:value("3", translate("Debug")) +pex_enabled=misc:option(Flag, "pex_enabled", translate("PEX enabled")) +pex_enabled.enabled="true" +pex_enabled.disabled="false" +script_torrent_done_enabled=misc:option(Flag, "script_torrent_done_enabled", translate("Script torrent done enabled")) +script_torrent_done_enabled.enabled="true" +script_torrent_done_enabled.disabled="false" +script_torrent_done_filename=misc:option(Value, "script_torrent_done_filename", translate("Script torrent done filename")) +script_torrent_done_filename:depends("script_torrent_done_enabled", "true") +idle_seeding_limit_enabled=misc:option(Flag, "idle_seeding_limit_enabled", translate("Idle seeding limit enabled")) +idle_seeding_limit_enabled.enabled="true" +idle_seeding_limit_enabled.disabled="false" +idle_seeding_limit=misc:option(Value, "idle_seeding_limit", translate("Idle seeding limit")) +idle_seeding_limit:depends("idle_seeding_limit_enabled", "true") +utp_enabled=misc:option(Flag, "utp_enabled", translate("uTP enabled")) +utp_enabled.enabled="true" +utp_enabled.disabled="false" + +peers=m:section(TypedSection, "transmission", translate("Peer settings")) +peers.anonymous=true +bind_address_ipv4=peers:option(Value, "bind_address_ipv4", translate("Binding address IPv4")) +bind_address_ipv4.default="0.0.0.0" +bind_address_ipv6=peers:option(Value, "bind_address_ipv6", translate("Binding address IPv6")) +bind_address_ipv6.default="::" +peer_congestion_algorithm=peers:option(Value, "peer_congestion_algorithm", translate("Peer congestion algorithm")) +peer_limit_global=peers:option(Value, "peer_limit_global", translate("Global peer limit")) +peer_limit_per_torrent=peers:option(Value, "peer_limit_per_torrent", translate("Peer limit per torrent")) +peer_socket_tos=peers:option(Value, "peer_socket_tos", translate("Peer socket tos")) + +peerport=m:section(TypedSection, "transmission", translate("Peer Port settings")) +peerport.anonymous=true +peer_port=peerport:option(Value, "peer_port", translate("Peer port")) +peer_port_random_on_start=peerport:option(Flag, "peer_port_random_on_start", translate("Peer port random on start")) +peer_port_random_on_start.enabled="true" +peer_port_random_on_start.disabled="false" +peer_port_random_high=peerport:option(Value, "peer_port_random_high", translate("Peer port random high")) +peer_port_random_high:depends("peer_port_random_on_start", "true") +peer_port_random_low=peerport:option(Value, "peer_port_random_low", translate("Peer port random low")) +peer_port_random_low:depends("peer_port_random_on_start", "true") +port_forwarding_enabled=peerport:option(Flag, "port_forwarding_enabled", translate("Port forwarding enabled")) +port_forwarding_enabled.enabled="true" +port_forwarding_enabled.disabled="false" + +rpc=m:section(TypedSection, "transmission", translate("RPC settings")) +rpc.anonymous=true +rpc_enabled=rpc:option(Flag, "rpc_enabled", translate("RPC enabled")) +rpc_enabled.enabled="true" +rpc_enabled.disabled="false" +rpc_port=rpc:option(Value, "rpc_port", translate("RPC port")) +rpc_port:depends("rpc_enabled", "true") +rpc_bind_address=rpc:option(Value, "rpc_bind_address", translate("RPC bind address")) +rpc_bind_address:depends("rpc_enabled", "true") +rpc_url=rpc:option(Value, "rpc_url", translate("RPC URL")) +rpc_url:depends("rpc_enabled", "true") +rpc_whitelist_enabled=rpc:option(Flag, "rpc_whitelist_enabled", translate("RPC whitelist enabled")) +rpc_whitelist_enabled.enabled="true" +rpc_whitelist_enabled.disabled="false" +rpc_whitelist_enabled:depends("rpc_enabled", "true") +rpc_whitelist=rpc:option(Value, "rpc_whitelist", translate("RPC whitelist")) +rpc_whitelist:depends("rpc_whitelist_enabled", "true") +rpc_authentication_required=rpc:option(Flag, "rpc_authentication_required", translate("RPC authentication required")) +rpc_authentication_required.enabled="true" +rpc_authentication_required.disabled="false" +rpc_authentication_required:depends("rpc_enabled", "true") +rpc_username=rpc:option(Value, "rpc_username", translate("RPC username")) +rpc_username:depends("rpc_authentication_required", "true") +rpc_password=rpc:option(Value, "rpc_password", translate("RPC password")) +rpc_password:depends("rpc_authentication_required", "true") +rpc_password.password = true + +scheduling=m:section(TypedSection, "transmission", translate("Scheduling")) +scheduling.anonymous=true +alt_speed_time_enabled=scheduling:option(Flag, "alt_speed_time_enabled", translate("Alternative speed timing enabled")) +alt_speed_time_enabled.enabled="true" +alt_speed_time_enabled.disabled="false" +alt_speed_time_enabled.default="false" +alt_speed_time_enabled:depends("alt_speed_enabled", "true") +alt_speed_time_day=scheduling:option(Value, "alt_speed_time_day", translate("Alternative speed time day"), translate("Number/bitfield. Start with 0, then for each day you want the scheduler enabled, add a value. For Sunday - 1, Monday - 2, Tuesday - 4, Wednesday - 8, Thursday - 16, Friday - 32, Saturday - 64")) +alt_speed_time_day:depends("alt_speed_time_enabled", "true") +alt_speed_time_begin=scheduling:option(Value, "alt_speed_time_begin", translate("Alternative speed time begin"), translate("in minutes from midnight")) +alt_speed_time_begin:depends("alt_speed_time_enabled", "true") +alt_speed_time_end=scheduling:option(Value, "alt_speed_time_end", translate("Alternative speed time end"), translate("in minutes from midnight")) +alt_speed_time_end:depends("alt_speed_time_enabled", "true") +ratio_limit_enabled=scheduling:option(Flag, "ratio_limit_enabled", translate("Ratio limit enabled")) +ratio_limit_enabled.enabled="true" +ratio_limit_enabled.disabled="false" +ratio_limit=scheduling:option(Value, "ratio_limit", translate("Ratio limit")) +ratio_limit:depends("ratio_limit_enabled", "true") + +queueing=m:section(TypedSection, "transmission", translate("Queueing")) +queueing.anonymous=true +download_queue_enabled=queueing:option(Flag, "download_queue_enabled", translate("Download queue enabled")) +download_queue_enabled.enabled="true" +download_queue_enabled.disabled="false" +download_queue_size=queueing:option(Value, "download_queue_size", translate("Download queue size")) +download_queue_size:depends("download_queue_enabled", "true") +queue_stalled_enabled=queueing:option(Flag, "queue_stalled_enabled", translate("Queue stalled enabled")) +queue_stalled_enabled.enabled="true" +queue_stalled_enabled.disabled="false" +queue_stalled_minutes=queueing:option(Value, "queue_stalled_minutes", translate("Queue stalled minutes")) +queue_stalled_minutes:depends("queue_stalled_enabled", "true") +seed_queue_enabled=queueing:option(Flag, "seed_queue_enabled", translate("Seed queue enabled")) +seed_queue_enabled.enabled="true" +seed_queue_enabled.disabled="false" +seed_queue_size=queueing:option(Value, "seed_queue_size", translate("Seed queue size")) +seed_queue_size:depends("seed_queue_enabled", "true") +scrape_paused_torrents_enabled=queueing:option(Flag, "scrape_paused_torrents_enabled", translate("Scrape paused torrents enabled")) +scrape_paused_torrents_enabled.enabled="true" +scrape_paused_torrents_enabled.disabled="false" + +return m |