forked from Shuffle/openapi-apps
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathunpacme.yaml
261 lines (261 loc) · 19.6 KB
/
unpacme.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
basePath: /api/v1
components:
securitySchemes:
ApiKeyAuth:
in: header
name: Authorization
type: apiKey
host: api.unpac.me
info:
contact:
email: [email protected]
name: '@unpacme'
url: https://api.unpac.me/
description: "\n# Introduction\nWelcome to the UNPACME API! All the malware unpacking\
\ and file analysis features that you are familiar with on the [unpac.me](https://www.unpac.me/)\
\ website are available through our API. You can easily integrate our unpacker\
\ into your malware analysis pipeline and begin unpacking at scale!\n\n\n# Authentication\n\
The public UNPACME API is publicly available and can be accessed without authentication.\n\
\nIn order to use the private UNPACME API you must sign up for an account with\
\ UNPACME. Once you have a valid user account you can view your personal API key\
\ in your user profile. \n\n<SecurityDefinitions />\n\n# Response Structure\n\
When interacting with the UNPACME API, if the request was correctly handled, a\
\ <b>200</b> HTTP status code will be returned. The body of the response will\
\ usually be a JSON object (except for file downloads).\n\n## Response Status\
\ Codes\n\nStatus Code | Description | Notes\n------------- | ------------- |\
\ -\n200 | OK | The request was successful\n400 | Bad Request | The request\
\ was somehow incorrect. This can be caused by missing arguments or arguments\
\ with wrong values.\n401 | Unauthorized | The supplied credentials, if any, are\
\ not sufficient to access the resource\n403 | Forbidden | The account does not\
\ have enough privileges to make the request.\n404 | Not Found | The requested\
\ resource is not found\n429 | Too Many Requests | The request frequency has\
\ exceeded one of the account quotas (minute, daily or monthly). Monthly quotas\
\ are reset on the 1st of the month at 00:00 UTC.\n500 | Server Error | The server\
\ could not return the representation due to an internal server error\n\n\n##\
\ Error Response\n\nIf an error has occurred while handling the request an error\
\ status code will be returend along with a JSON error message with the following\
\ properties.\n\n\nProperty | Description\n------------- | -------------\nError\
\ | The error type\nDescription | A more informative message\n\n# Example Clients\n\
\nThe following clients can be used to interact with the UNPACME API directly\
\ and are provided as examples. These clients are community projects and are not\
\ maintained or developed by UNPACME. UNPACME makes no claim as to the safety\
\ of these clients, use at your own risk.\n\n - [UnpacMe Client](https://github.com/larsborn/UnpacMeClient)\
\ (Python)\n - [UnpacMe Library](https://github.com/R3MRUM/unpacme) (Python)\n\
\n<br>\n"
termsOfService: https://www.unpac.me/tos
title: UnpacMe
version: '1.0'
x-logo: 
openapi: 3.0.0
paths:
/private/download/{sample_hash}:
get:
description: Downloads sample binary
parameters:
- description: Generated by shuffler.io OpenAPI
in: path
name: sample_hash
required: true
schema:
type: string
responses:
default:
description: default
schema: {}
summary: Download sample by hash
/private/feed/unpacked:
get:
description: Returns full feed of unpacked samples
parameters:
- description: Scroll feed to cursor
in: query
name: cursor
required: false
schema:
type: string
responses:
default:
description: default
schema: {}
summary: Get full unpacked sample feed
/private/feed/unpacked/yara:
get:
description: Returns list of all yara tags available for the feed
parameters: []
responses:
default:
description: default
schema: {}
summary: Get list of yara tags in feed
/private/feed/unpacked/yara/{yara_rule}:
get:
description: Returns full feed of unpacked samples filtered by the yara rule
parameters:
- description: Generated by shuffler.io OpenAPI
in: path
name: yara_rule
required: true
schema:
type: string
responses:
default:
description: default
schema: {}
summary: Get full unpacked sample feed filtered by yara rule
/private/history:
get:
description: Returns submission history
parameters:
- description: Scroll history to cursor
in: query
name: cursor
required: false
schema:
type: string
responses:
default:
description: default
schema: {}
summary: Get history
/private/results/{unpack_id}:
get:
description: Returns unpack results
parameters:
- description: Generated by shuffler.io OpenAPI
in: path
name: unpack_id
required: true
schema:
type: string
responses:
default:
description: default
schema: {}
summary: Get unpack results by ID
/private/search/hash/{sample_hash}:
get:
description: Returns submission history
parameters:
- description: Generated by shuffler.io OpenAPI
in: path
name: sample_hash
required: true
schema:
type: string
responses:
default:
description: default
schema: {}
summary: Search for parent submission by hash
/private/status/{unpack_id}:
get:
description: Returns a submission status
parameters:
- description: Generated by shuffler.io OpenAPI
in: path
name: unpack_id
required: true
schema:
type: string
responses:
default:
description: default
schema: {}
summary: Get unpack status by ID
/private/upload/:
post:
description: Queues sample for unpacking
parameters:
- description: Mark sample as private (only available to PRO users)
in: query
name: private
required: false
schema:
type: string
responses:
default:
description: default
schema: {}
summary: Submit sample for unpacking
/private/user/access:
get:
description: Returns user settings
parameters: []
responses:
default:
description: default
schema: {}
summary: Get user settings
/private/user/malpedia:
delete:
description: Removes Malpedia authentication and deletes Malpedia token
parameters: []
responses:
default:
description: default
schema: {}
summary: Remove Malpedia authentication
get:
description: Returns user Malpedia info
parameters: []
responses:
default:
description: default
schema: {}
summary: Get user Malpedia info
post:
description: Authenticate user to Malpedia using API token
parameters: []
responses:
default:
description: default
schema: {}
summary: Authenticate user to Malpedia
/public/feed:
get:
description: Returns public feed of unpacked samples
parameters: []
responses:
default:
description: default
schema: {}
summary: Get public feed
/public/results/{unpack_id}:
get:
description: Returns unpack results
parameters:
- description: Generated by shuffler.io OpenAPI
in: path
name: unpack_id
required: true
schema:
type: string
responses:
default:
description: default
schema: {}
summary: Get unpack results by ID
/public/status/{unpack_id}:
get:
description: Returns a submission status
parameters:
- description: Generated by shuffler.io OpenAPI
in: path
name: unpack_id
required: true
schema:
type: string
responses:
default:
description: default
schema: {}
summary: Get unpack status by ID
schemes:
- 'https:'
servers:
- url: https://api.unpac.me/api/v1
tags:
- name: public
- name: unpacking
- name: feed
- name: user