Returns the editor role. Encapsulates all viewer's permissions and permissions for actions that
modify the state of a resource.
See Also:Understanding Roles
If the value contains no slash character ('/'), the prefix"roles/""is
prepended. This slightly simplifies usage forpredefined roles. Forcustom roles, call this
method with the fully-qualified name, eg"projects/XXX/roles/YYY".
See Also:Viewing the Grantable Roles on Resources
Returns the owner role. Encapsulates all editor's permissions and permissions to manage access
control for a resource or manage the billing options for a project.
See Also:Understanding Roles
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Hard to understand","hardToUnderstand","thumb-down"],["Incorrect information or sample code","incorrectInformationOrSampleCode","thumb-down"],["Missing the information/samples I need","missingTheInformationSamplesINeed","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-09-04 UTC."],[],[],null,["# Class Role (2.59.0)\n\nVersion latestkeyboard_arrow_down\n\n- [2.59.0 (latest)](/java/docs/reference/google-cloud-core/latest/com.google.cloud.Role)\n- [2.58.2](/java/docs/reference/google-cloud-core/2.58.2/com.google.cloud.Role)\n- [2.57.0](/java/docs/reference/google-cloud-core/2.57.0/com.google.cloud.Role)\n- [2.56.0](/java/docs/reference/google-cloud-core/2.56.0/com.google.cloud.Role)\n- [2.55.0](/java/docs/reference/google-cloud-core/2.55.0/com.google.cloud.Role)\n- [2.53.1](/java/docs/reference/google-cloud-core/2.53.1/com.google.cloud.Role)\n- [2.52.0](/java/docs/reference/google-cloud-core/2.52.0/com.google.cloud.Role)\n- [2.51.0](/java/docs/reference/google-cloud-core/2.51.0/com.google.cloud.Role)\n- [2.50.0](/java/docs/reference/google-cloud-core/2.50.0/com.google.cloud.Role)\n- [2.49.1](/java/docs/reference/google-cloud-core/2.49.1/com.google.cloud.Role)\n- [2.48.0](/java/docs/reference/google-cloud-core/2.48.0/com.google.cloud.Role)\n- [2.47.0](/java/docs/reference/google-cloud-core/2.47.0/com.google.cloud.Role)\n- [2.45.0](/java/docs/reference/google-cloud-core/2.45.0/com.google.cloud.Role)\n- [2.44.1](/java/docs/reference/google-cloud-core/2.44.1/com.google.cloud.Role)\n- [2.43.0](/java/docs/reference/google-cloud-core/2.43.0/com.google.cloud.Role)\n- [2.42.0](/java/docs/reference/google-cloud-core/2.42.0/com.google.cloud.Role)\n- [2.41.0](/java/docs/reference/google-cloud-core/2.41.0/com.google.cloud.Role)\n- [2.40.0](/java/docs/reference/google-cloud-core/2.40.0/com.google.cloud.Role)\n- [2.39.0](/java/docs/reference/google-cloud-core/2.39.0/com.google.cloud.Role)\n- [2.38.1](/java/docs/reference/google-cloud-core/2.38.1/com.google.cloud.Role)\n- [2.37.0](/java/docs/reference/google-cloud-core/2.37.0/com.google.cloud.Role)\n- [2.36.1](/java/docs/reference/google-cloud-core/2.36.1/com.google.cloud.Role)\n- [2.35.0](/java/docs/reference/google-cloud-core/2.35.0/com.google.cloud.Role)\n- [2.33.0](/java/docs/reference/google-cloud-core/2.33.0/com.google.cloud.Role)\n- [2.32.0](/java/docs/reference/google-cloud-core/2.32.0/com.google.cloud.Role)\n- [2.31.0](/java/docs/reference/google-cloud-core/2.31.0/com.google.cloud.Role)\n- [2.29.0](/java/docs/reference/google-cloud-core/2.29.0/com.google.cloud.Role)\n- [2.28.0](/java/docs/reference/google-cloud-core/2.28.0/com.google.cloud.Role)\n- [2.27.0](/java/docs/reference/google-cloud-core/2.27.0/com.google.cloud.Role)\n- [2.26.0](/java/docs/reference/google-cloud-core/2.26.0/com.google.cloud.Role)\n- [2.25.0](/java/docs/reference/google-cloud-core/2.25.0/com.google.cloud.Role)\n- [2.24.1](/java/docs/reference/google-cloud-core/2.24.1/com.google.cloud.Role)\n- [2.23.0](/java/docs/reference/google-cloud-core/2.23.0/com.google.cloud.Role)\n- [2.22.1](/java/docs/reference/google-cloud-core/2.22.1/com.google.cloud.Role)\n- [2.21.1](/java/docs/reference/google-cloud-core/2.21.1/com.google.cloud.Role)\n- [2.20.1](/java/docs/reference/google-cloud-core/2.20.1/com.google.cloud.Role)\n- [2.13.0](/java/docs/reference/google-cloud-core/2.13.0/com.google.cloud.Role)\n- [2.12.0](/java/docs/reference/google-cloud-core/2.12.0/com.google.cloud.Role)\n- [2.11.0](/java/docs/reference/google-cloud-core/2.11.0/com.google.cloud.Role)\n- [2.9.4](/java/docs/reference/google-cloud-core/2.9.4/com.google.cloud.Role)\n- [2.8.27](/java/docs/reference/google-cloud-core/2.8.27/com.google.cloud.Role)\n- [2.7.1](/java/docs/reference/google-cloud-core/2.7.1/com.google.cloud.Role)\n- [2.6.1](/java/docs/reference/google-cloud-core/2.6.1/com.google.cloud.Role)\n- [2.5.11](/java/docs/reference/google-cloud-core/2.5.11/com.google.cloud.Role)\n- [2.4.0](/java/docs/reference/google-cloud-core/2.4.0/com.google.cloud.Role)\n- [2.3.5](/java/docs/reference/google-cloud-core/2.3.5/com.google.cloud.Role) \n\n public final class Role implements Serializable\n\nA role in a IAM [Policy](/java/docs/reference/google-cloud-core/latest/com.google.cloud.Policy). Project owners can grant access to team members to access\nproject's resources and APIs by granting IAM roles to team members.\nSee Also: [Viewing the Grantable Roles on Resources](https://cloud.google.com/iam/docs/viewing-grantable-roles), [Understanding Roles](https://cloud.google.com/iam/docs/understanding-roles) \n\nInheritance\n-----------\n\n[Object](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html) \\\u003e Role \n\nImplements\n----------\n\n[Serializable](https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html) \n\nInherited Members\n-----------------\n\n[Object.clone()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#clone--) \n[Object.equals(Object)](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#equals-java.lang.Object-) \n[Object.finalize()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#finalize--) \n[Object.getClass()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#getClass--) \n[Object.hashCode()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#hashCode--) \n[Object.notify()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#notify--) \n[Object.notifyAll()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#notifyAll--) \n[Object.toString()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#toString--) \n[Object.wait()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#wait--) \n[Object.wait(long)](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#wait-long-) \n[Object.wait(long,int)](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#wait-long-int-)\n\nStatic Methods\n--------------\n\n### editor()\n\n public static Role editor()\n\nReturns the editor role. Encapsulates all viewer's permissions and permissions for actions that\nmodify the state of a resource.\nSee Also: [Understanding Roles](https://cloud.google.com/iam/docs/understanding-roles)\n\n### of(String value)\n\n public static Role of(String value)\n\nReturns a new role given its string value.\n\nIf the value contains no slash character (`'/'`), the prefix `\"roles/\"\"` is\nprepended. This slightly simplifies usage for [predefined roles](https://cloud.google.com/iam/docs/understanding-roles). For [custom roles](https://cloud.google.com/iam/docs/creating-custom-roles), call this\nmethod with the fully-qualified name, eg `\"projects/XXX/roles/YYY\"`.\nSee Also: [Viewing the Grantable Roles on Resources](https://cloud.google.com/iam/docs/viewing-grantable-roles)\n\n### owner()\n\n public static Role owner()\n\nReturns the owner role. Encapsulates all editor's permissions and permissions to manage access\ncontrol for a resource or manage the billing options for a project.\nSee Also: [Understanding Roles](https://cloud.google.com/iam/docs/understanding-roles)\n\n### viewer()\n\n public static Role viewer()\n\nReturns the viewer role. Encapsulates the permission for read-only actions that preserve state\nof a resource.\nSee Also: [Understanding Roles](https://cloud.google.com/iam/docs/understanding-roles)\n\nMethods\n-------\n\n### equals(Object obj)\n\n public boolean equals(Object obj)\n\n**Overrides** \n[Object.equals(Object)](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#equals-java.lang.Object-)\n\n### getValue()\n\n public String getValue()\n\nReturns the string identifier for this role. For example, `\"roles/viewer\"`, `\n\"roles/editor\"`, or `\"roles/owner\"`.\n\n### hashCode()\n\n public int hashCode()\n\n**Overrides** \n[Object.hashCode()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#hashCode--)\n\n### toString()\n\n public String toString()\n\n**Overrides** \n[Object.toString()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#toString--)"]]