blob: f751d520739a6801304f3bf5319e2f644e5758e1 [file] [log] [blame]
#!/usr/bin/env python
"""
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you 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
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
Slider Agent
"""
__all__ = ["File", "Directory", "Link", "Execute", "ExecuteScript", "Mount"]
from resource_management.core.base import Resource, ForcedListArgument, ResourceArgument, BooleanArgument
class File(Resource):
action = ForcedListArgument(default="create")
path = ResourceArgument(default=lambda obj: obj.name)
backup = ResourceArgument()
mode = ResourceArgument()
owner = ResourceArgument()
group = ResourceArgument()
content = ResourceArgument()
# whether to replace files with different content
replace = ResourceArgument(default=True)
actions = Resource.actions + ["create", "delete"]
class Directory(Resource):
action = ForcedListArgument(default="create")
path = ResourceArgument(default=lambda obj: obj.name)
mode = ResourceArgument()
owner = ResourceArgument()
group = ResourceArgument()
content = ResourceArgument()
recursive = BooleanArgument(default=False) # this work for 'create', 'delete' is anyway recursive
actions = Resource.actions + ["create", "delete"]
class Link(Resource):
action = ForcedListArgument(default="create")
path = ResourceArgument(default=lambda obj: obj.name)
to = ResourceArgument(required=True)
hard = BooleanArgument(default=False)
actions = Resource.actions + ["create", "delete"]
class Execute(Resource):
action = ForcedListArgument(default="run")
"""
Recommended:
command = ('rm','-f','myfile')
Not recommended:
command = 'rm -f myfile'
The first one helps to stop escaping issues
"""
command = ResourceArgument(default=lambda obj: obj.name)
creates = ResourceArgument()
cwd = ResourceArgument()
# this runs command with a specific env variables, env={'JAVA_HOME': '/usr/jdk'}
environment = ResourceArgument()
user = ResourceArgument()
group = ResourceArgument()
returns = ForcedListArgument(default=0)
tries = ResourceArgument(default=1)
try_sleep = ResourceArgument(default=0) # seconds
path = ForcedListArgument(default=[])
actions = Resource.actions + ["run"]
logoutput = BooleanArgument(default=False)
"""
if on_timeout is not set leads to failing after x seconds,
otherwise calls on_timeout
"""
timeout = ResourceArgument() # seconds
on_timeout = ResourceArgument()
"""
Wait for command to finish or not.
NOTE:
In case of False, since any command results are skipped, it disables some functionality:
- non-zero return code failure
- logoutput
- tries
- try_sleep
"""
wait_for_finish = BooleanArgument(default=True)
"""
if wait_for_finish is True then optionally the caller can ask for the pid to be written
"""
pid_file = ResourceArgument()
poll_after = ResourceArgument() #seconds
class ExecuteScript(Resource):
action = ForcedListArgument(default="run")
code = ResourceArgument(required=True)
cwd = ResourceArgument()
environment = ResourceArgument()
interpreter = ResourceArgument(default="/bin/bash")
user = ResourceArgument()
group = ResourceArgument()
actions = Resource.actions + ["run"]
class Mount(Resource):
action = ForcedListArgument(default="mount")
mount_point = ResourceArgument(default=lambda obj: obj.name)
device = ResourceArgument()
fstype = ResourceArgument()
options = ResourceArgument(default=["defaults"])
dump = ResourceArgument(default=0)
passno = ResourceArgument(default=2)
actions = Resource.actions + ["mount", "umount", "remount", "enable",
"disable"]