Class: OpenAI::Resources::Skills

Inherits:
Object
  • Object
show all
Defined in:
lib/openai/resources/skills.rb,
lib/openai/resources/skills/content.rb,
lib/openai/resources/skills/versions.rb,
lib/openai/resources/skills/versions/content.rb

Defined Under Namespace

Classes: Content, Versions

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(client:) ⇒ Skills

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns a new instance of Skills.

Parameters:



133
134
135
136
137
# File 'lib/openai/resources/skills.rb', line 133

def initialize(client:)
  @client = client
  @content = OpenAI::Resources::Skills::Content.new(client: client)
  @versions = OpenAI::Resources::Skills::Versions.new(client: client)
end

Instance Attribute Details

#contentOpenAI::Resources::Skills::Content (readonly)



7
8
9
# File 'lib/openai/resources/skills.rb', line 7

def content
  @content
end

#versionsOpenAI::Resources::Skills::Versions (readonly)



10
11
12
# File 'lib/openai/resources/skills.rb', line 10

def versions
  @versions
end

Instance Method Details

#create(files: nil, request_options: {}) ⇒ OpenAI::Models::Skill

Create a new skill.

Parameters:

Returns:

See Also:



23
24
25
26
27
28
29
30
31
32
33
# File 'lib/openai/resources/skills.rb', line 23

def create(params = {})
  parsed, options = OpenAI::SkillCreateParams.dump_request(params)
  @client.request(
    method: :post,
    path: "skills",
    headers: {"content-type" => "multipart/form-data"},
    body: parsed,
    model: OpenAI::Skill,
    options: options
  )
end

#delete(skill_id, request_options: {}) ⇒ OpenAI::Models::DeletedSkill

Delete a skill by its ID.

Parameters:

  • skill_id (String)

    The identifier of the skill to delete.

  • request_options (OpenAI::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



121
122
123
124
125
126
127
128
# File 'lib/openai/resources/skills.rb', line 121

def delete(skill_id, params = {})
  @client.request(
    method: :delete,
    path: ["skills/%1$s", skill_id],
    model: OpenAI::DeletedSkill,
    options: params[:request_options]
  )
end

#list(after: nil, limit: nil, order: nil, request_options: {}) ⇒ OpenAI::Internal::CursorPage<OpenAI::Models::Skill>

Some parameter documentations has been truncated, see Models::SkillListParams for more details.

List all skills for the current project.

Parameters:

  • after (String)

    Identifier for the last item from the previous pagination request

  • limit (Integer)

    Number of items to retrieve

  • order (Symbol, OpenAI::Models::SkillListParams::Order)

    Sort order of results by timestamp. Use ‘asc` for ascending order or `desc` for

  • request_options (OpenAI::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



97
98
99
100
101
102
103
104
105
106
107
108
# File 'lib/openai/resources/skills.rb', line 97

def list(params = {})
  parsed, options = OpenAI::SkillListParams.dump_request(params)
  query = OpenAI::Internal::Util.encode_query_params(parsed)
  @client.request(
    method: :get,
    path: "skills",
    query: query,
    page: OpenAI::Internal::CursorPage,
    model: OpenAI::Skill,
    options: options
  )
end

#retrieve(skill_id, request_options: {}) ⇒ OpenAI::Models::Skill

Get a skill by its ID.

Parameters:

  • skill_id (String)

    The identifier of the skill to retrieve.

  • request_options (OpenAI::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



46
47
48
49
50
51
52
53
# File 'lib/openai/resources/skills.rb', line 46

def retrieve(skill_id, params = {})
  @client.request(
    method: :get,
    path: ["skills/%1$s", skill_id],
    model: OpenAI::Skill,
    options: params[:request_options]
  )
end

#update(skill_id, default_version:, request_options: {}) ⇒ OpenAI::Models::Skill

Update the default version pointer for a skill.

Parameters:

  • skill_id (String)

    The identifier of the skill.

  • default_version (String)

    The skill version number to set as default.

  • request_options (OpenAI::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



68
69
70
71
72
73
74
75
76
77
# File 'lib/openai/resources/skills.rb', line 68

def update(skill_id, params)
  parsed, options = OpenAI::SkillUpdateParams.dump_request(params)
  @client.request(
    method: :post,
    path: ["skills/%1$s", skill_id],
    body: parsed,
    model: OpenAI::Skill,
    options: options
  )
end