tiktokautouploader 3.5__py2.py3-none-any.whl → 3.14__py2.py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,14 +1,17 @@
1
1
  from playwright.sync_api import sync_playwright
2
2
  import json
3
3
  import time
4
+ import inference
4
5
  import subprocess
5
- from inference_sdk import InferenceHTTPClient
6
6
  import pkg_resources
7
7
  import requests
8
8
  from PIL import Image
9
9
  import sys
10
+ import base64
10
11
  import os
12
+ from dotenv import load_dotenv
11
13
  import warnings
14
+ load_dotenv()
12
15
  warnings.simplefilter("ignore")
13
16
 
14
17
 
@@ -132,6 +135,8 @@ def get_image_src(page):
132
135
  image_url = page.get_attribute("img#captcha-verify-image", "src")
133
136
  return image_url
134
137
 
138
+ os.getenv('ROBOFLOW_API_KEY')
139
+
135
140
  def download_image(image_url):
136
141
  response = requests.get(image_url)
137
142
  image_path = "captcha_image.jpg"
@@ -141,25 +146,18 @@ def download_image(image_url):
141
146
 
142
147
  def run_inference_on_image_tougher(image_path, object):
143
148
 
144
- k = 'n|KIeDZnRZiJ};iVHz;R'
145
- rk = ''.join(chr((ord(c) - 3) % 256) for c in k)
146
-
147
- CLIENT = InferenceHTTPClient(
148
- api_url="https://detect.roboflow.com",
149
- api_key=f"{rk}"
150
- )
151
-
152
- results = CLIENT.infer(image_path, model_id="captcha-2-6ehbe/2")
149
+ model = inference.get_model("captcha-2-6ehbe/2")
150
+ results = model.infer(image=image_path)
153
151
 
154
152
  class_names = []
155
153
  bounding_boxes = []
156
- for obj in results['predictions']:
157
- class_names.append(obj['class'])
154
+ for obj in results[0].predictions:
155
+ class_names.append(obj.class_name)
158
156
  bounding_boxes.append({
159
- "x": obj['x'],
160
- "y": obj['y'],
161
- "width": obj['width'],
162
- "height": obj['height']
157
+ "x": obj.x,
158
+ "y": obj.y,
159
+ "width": obj.width,
160
+ "height": obj.height
163
161
  })
164
162
 
165
163
  bounding_box = []
@@ -174,40 +172,34 @@ def run_inference_on_image_tougher(image_path, object):
174
172
 
175
173
  def run_inference_on_image(image_path):
176
174
 
177
- k = 'n|KIeDZnRZiJ};iVHz;R'
178
- rk = ''.join(chr((ord(c) - 3) % 256) for c in k)
179
-
180
- CLIENT = InferenceHTTPClient(
181
- api_url="https://detect.roboflow.com",
182
- api_key=f"{rk}"
183
- )
184
-
185
- results = CLIENT.infer(image_path, model_id="tk-3nwi9/2")
175
+ model = inference.get_model("tk-3nwi9/2")
176
+ results = model.infer(image=image_path)
186
177
 
187
178
  class_names = []
188
179
  bounding_boxes = []
189
- for obj in results['predictions']:
190
- class_names.append(obj['class'])
180
+ for obj in results[0].predictions:
181
+ class_names.append(obj.class_name)
191
182
  bounding_boxes.append({
192
- "x": obj['x'],
193
- "y": obj['y'],
194
- "width": obj['width'],
195
- "height": obj['height']
183
+ "x": obj.x,
184
+ "y": obj.y,
185
+ "width": obj.width,
186
+ "height": obj.height
196
187
  })
197
188
 
198
189
  already_written = []
199
190
  bounding_box = []
200
191
  class_to_click = []
201
- for i, detected_class in enumerate(class_names):
202
- if detected_class in already_written:
203
- class_to_click.append(detected_class)
192
+ for i, classes in enumerate(class_names):
193
+ if classes in already_written:
194
+ class_to_click.append(classes)
204
195
  bounding_box.append(bounding_boxes[i])
205
- index = already_written.index(detected_class)
196
+ index = already_written.index(classes)
206
197
  bounding_box.append(bounding_boxes[index])
207
198
 
208
- already_written.append(detected_class)
199
+ already_written.append(classes)
209
200
 
210
201
  found = False
202
+
211
203
  if len(class_to_click) == 1:
212
204
  found = True
213
205
 
@@ -235,14 +227,13 @@ def click_on_objects(page, object_coords):
235
227
 
236
228
 
237
229
 
238
- def upload_tiktok(video, description, accountname, hashtags=None, sound_name=None, sound_aud_vol='mix', schedule=None, day=None, copyrightcheck=False, suppressprint=False, headless=True):
230
+ def upload_tiktok(video, description, accountname, hashtags=None, sound_name=None, sound_aud_vol='mix', schedule=None, day=None, copyrightcheck=False, suppressprint=False):
239
231
 
240
232
  """
241
233
  UPLOADS VIDEO TO TIKTOK
242
234
  ------------------------------------------------------------------------------------------------------------------------------------------------c
243
235
  video (str) -> path to video to upload
244
236
  description (str) -> description for video
245
- accountname (str) -> account to upload on
246
237
  hashtags (str)(array) -> hashtags for video
247
238
  sound_name (str) -> name of tik tok sound to use for video
248
239
  sound_aud_vol (str) -> volume of tik tok sound, 'main', 'mix' or 'background', check documentation for more info -> https://github.com/haziq-exe/TikTokAutoUploader
@@ -250,7 +241,6 @@ def upload_tiktok(video, description, accountname, hashtags=None, sound_name=Non
250
241
  day (int) -> day to schedule video for, check documentation for more info -> https://github.com/haziq-exe/TikTokAutoUploader
251
242
  copyrightcheck (bool) -> include copyright check or not; CODE FAILS IF FAIL COPYRIGHT CHECK
252
243
  suppressprint (bool) -> True means function doesnt print anything to provide updates on progress
253
- headless (bool) -> run in headless mode or not
254
244
  --------------------------------------------------------------------------------------------------------------------------------------------
255
245
  """
256
246
  try:
@@ -286,7 +276,8 @@ def upload_tiktok(video, description, accountname, hashtags=None, sound_name=Non
286
276
 
287
277
  with sync_playwright() as p:
288
278
 
289
- browser = p.firefox.launch(headless=headless)
279
+ browser = p.firefox.launch(headless=True)
280
+
290
281
  context = browser.new_context()
291
282
  context.add_cookies(cookies)
292
283
  page = context.new_page()
@@ -472,16 +463,13 @@ def upload_tiktok(video, description, accountname, hashtags=None, sound_name=Non
472
463
  print("Description and Hashtags added")
473
464
 
474
465
  try:
475
- page.wait_for_selector('button.TUXButton.TUXButton--default.TUXButton--large.TUXButton--primary:has-text("Post")[aria-disabled="false"]', timeout=12000000)
466
+ page.wait_for_function("document.querySelector('.info-progress-num').textContent.trim() === '100%'", timeout=12000000)
476
467
  except:
477
468
  sys.exit("ERROR: TIK TOK TOOK TOO LONG TO UPLOAD YOUR FILE (>20min). Try again, if issue persists then try a lower file size or different wifi connection")
478
469
 
479
470
  time.sleep(0.2)
480
471
  if suppressprint == False:
481
472
  print("Tik tok done loading file onto servers")
482
-
483
- if (schedule == None) and (day != None):
484
- sys.exit("ERROR: CANT SCHEDULE FOR ANOTHER DAY USING 'day' WITHOUT ALSO INCLUDING TIME OF UPLOAD WITH 'schedule'; PLEASE ALSO INCLUDE TIME WITH 'schedule' PARAMETER")
485
473
 
486
474
  if schedule != None:
487
475
  try:
@@ -493,39 +481,31 @@ def upload_tiktok(video, description, accountname, hashtags=None, sound_name=Non
493
481
  except:
494
482
  sys.exit("SCHEDULE TIME ERROR: PLEASE MAKE SURE YOUR SCHEDULE TIME IS A STRING THAT FOLLOWS THE 24H FORMAT 'HH:MM', VIDEO SAVED AS DRAFT")
495
483
 
496
- page.locator('div.TUXRadioStandalone.TUXRadioStandalone--medium:has(input[value="schedule"])').click()
497
- # time.sleep(1)
498
- visible = False
499
- while visible == False:
500
- if page.locator('button.TUXButton.TUXButton--default.TUXButton--medium.TUXButton--primary:has-text("Allow")').nth(0).is_visible():
501
- page.locator('button.TUXButton.TUXButton--default.TUXButton--medium.TUXButton--primary:has-text("Allow")').nth(0).click()
502
- visible = True
503
- time.sleep(0.1)
504
- else:
505
- if page.locator('div.TUXTextInputCore-trailingIconWrapper').nth(1).is_visible():
506
- visible = True
507
- time.sleep(0.1)
484
+ page.locator('div.TUXRadioStandalone.TUXRadioStandalone--medium').nth(1).click()
485
+ time.sleep(1)
486
+ if page.locator('button.TUXButton.TUXButton--default.TUXButton--medium.TUXButton--primary:has-text("Allow")').nth(0).is_visible():
487
+ page.locator('button.TUXButton.TUXButton--default.TUXButton--medium.TUXButton--primary:has-text("Allow")').nth(0).click()
488
+ time.sleep(0.2)
489
+ else:
490
+ if page.locator('div.TUXTextInputCore-trailingIconWrapper').nth(1).is_visible():
491
+ time.sleep(0.2)
508
492
  if day != None:
509
- page.locator('div.TUXTextInputCore-leadingIconWrapper:has(svg > path[d="M15 3a1 1 0 0 0-1 1v3h-1.4c-3.36 0-5.04 0-6.32.65a6 6 0 0 0-2.63 2.63C3 11.56 3 13.24 3 16.6v16.8c0 3.36 0 5.04.65 6.32a6 6 0 0 0 2.63 2.63c1.28.65 2.96.65 6.32.65h22.8c3.36 0 5.04 0 6.32-.65a6 6 0 0 0 2.63-2.63c.65-1.28.65-2.96.65-6.32V16.6c0-3.36 0-5.04-.65-6.32a6 6 0 0 0-2.63-2.63C40.44 7 38.76 7 35.4 7H34V4a1 1 0 0 0-1-1h-2a1 1 0 0 0-1 1v3H18V4a1 1 0 0 0-1-1h-2Zm-2.4 8H14v3a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1v-3h12v3a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1v-3h1.4c1.75 0 2.82 0 3.62.07a5.11 5.11 0 0 1 .86.14h.03a2 2 0 0 1 .88.91 5.11 5.11 0 0 1 .14.86c.07.8.07 1.87.07 3.62v1.9H7v-1.9c0-1.75 0-2.82.07-3.62a5.12 5.12 0 0 1 .14-.86v-.03a2 2 0 0 1 .88-.87l.03-.01a5.11 5.11 0 0 1 .86-.14c.8-.07 1.87-.07 3.62-.07ZM7 22.5h34v10.9c0 1.75 0 2.82-.07 3.62a5.11 5.11 0 0 1-.14.86v.03a2 2 0 0 1-.88.87l-.03.01a5.11 5.11 0 0 1-.86.14c-.8.07-1.87.07-3.62.07H12.6c-1.75 0-2.82 0-3.62-.07a5.11 5.11 0 0 1-.89-.15 2 2 0 0 1-.87-.87l-.01-.03a5.12 5.12 0 0 1-.14-.86C7 36.22 7 35.15 7 33.4V22.5Z"])').click()
493
+ page.locator('div.TUXTextInputCore-trailingIconWrapper').nth(1).click()
510
494
  time.sleep(0.2)
511
495
  try:
512
- page.locator(f'span.day.valid:text-is("{day}")').click()
496
+ page.locator(f'span.day.valid:has-text("{day}")').click()
513
497
  except:
514
498
  sys.exit("SCHEDULE DAY ERROR: ERROR WITH SCHEDULED DAY, read documentation for more information on format of day")
515
499
  try:
500
+ time.sleep(1)
501
+ page.locator('div.TUXTextInputCore-trailingIconWrapper').nth(0).click()
516
502
  time.sleep(0.2)
517
- page.locator('div.TUXTextInputCore-leadingIconWrapper:has(svg > path[d="M24 2a22 22 0 1 0 0 44 22 22 0 0 0 0-44ZM6 24a18 18 0 1 1 36 0 18 18 0 0 1-36 0Z"])').click()
518
- time.sleep(0.2)
519
- page.locator(f'.tiktok-timepicker-option-text.tiktok-timepicker-right:text-is("{minute}")').scroll_into_view_if_needed()
503
+ page.locator(f'.tiktok-timepicker-option-text.tiktok-timepicker-right:has-text("{minute}")').nth(0).scroll_into_view_if_needed()
520
504
  time.sleep(0.2)
521
- page.locator(f'.tiktok-timepicker-option-text.tiktok-timepicker-right:text-is("{minute}")').click()
505
+ page.locator(f'.tiktok-timepicker-option-text.tiktok-timepicker-right:has-text("{minute}")').nth(0).click()
522
506
  time.sleep(0.2)
523
- if page.locator("div.tiktok-timepicker-time-picker-container").is_visible():
524
- time.sleep(0.1)
525
- else:
526
- page.locator('div.TUXTextInputCore-leadingIconWrapper:has(svg > path[d="M24 2a22 22 0 1 0 0 44 22 22 0 0 0 0-44ZM6 24a18 18 0 1 1 36 0 18 18 0 0 1-36 0Z"])').click()
527
- page.locator(f'.tiktok-timepicker-option-text.tiktok-timepicker-left:text-is("{hour}")').scroll_into_view_if_needed()
528
- page.locator(f'.tiktok-timepicker-option-text.tiktok-timepicker-left:text-is("{hour}")').click()
507
+ page.locator(f'.tiktok-timepicker-option-text:has-text("{hour}")').nth(0).scroll_into_view_if_needed()
508
+ page.locator(f'.tiktok-timepicker-option-text:has-text("{hour}")').nth(0).click()
529
509
  time.sleep(1)
530
510
 
531
511
  if suppressprint == False:
@@ -533,14 +513,93 @@ def upload_tiktok(video, description, accountname, hashtags=None, sound_name=Non
533
513
 
534
514
  except:
535
515
  sys.exit("SCHEDULING ERROR: VIDEO SAVED AS DRAFT")
516
+
517
+ if (schedule == None) and (day != None):
518
+ sys.exit("ERROR: CANT SCHEDULE FOR ANOTHER DAY USING 'day' WITHOUT ALSO INCLUDING TIME OF UPLOAD WITH 'schedule'; PLEASE ALSO INCLUDE TIME WITH 'schedule' PARAMETER")
536
519
 
537
- sound_fail = False
538
- if sound_name != None:
520
+ if(sound_name == None):
521
+ if copyrightcheck == True:
522
+ page.locator(".TUXSwitch-input").nth(0).click()
523
+ while copyrightcheck == True:
524
+ time.sleep(0.2)
525
+ if page.locator("span", has_text="No issues detected.").is_visible():
526
+ if suppressprint == False:
527
+ print("Copyright check complete")
528
+ break
529
+ if page.locator("span", has_text="Copyright issues detected.").is_visible():
530
+ sys.exit("COPYRIGHT CHECK FAILED: COPYRIGHT AUDIO DETECTED FROM TIKTOK")
531
+
532
+ if schedule == None:
533
+ page.click('button.TUXButton.TUXButton--default.TUXButton--large.TUXButton--primary:has-text("Post")', timeout=10000)
534
+ uploaded = False
535
+ checks = 0
536
+ while uploaded == False:
537
+ if page.locator(':has-text("Leaving the page does not interrupt")').nth(0).is_visible():
538
+ time.sleep(0.2)
539
+ break
540
+ time.sleep(0.2)
541
+ checks += 1
542
+ if checks > 100:
543
+ time.sleep(10)
544
+ if checks == 150:
545
+ break
546
+ else:
547
+ page.click('button.TUXButton.TUXButton--default.TUXButton--large.TUXButton--primary:has-text("Schedule")', timeout=10000)
548
+ uploaded = False
549
+ checks = 0
550
+ while uploaded == False:
551
+ if page.locator(':has-text("Leaving the page does not interrupt")').nth(0).is_visible():
552
+ time.sleep(0.2)
553
+ break
554
+ time.sleep(0.2)
555
+ checks += 1
556
+ if checks > 100:
557
+ time.sleep(10)
558
+ if checks == 150:
559
+ break
560
+ if suppressprint == False:
561
+ print("Done uploading video, NOTE: it may take a minute or two to show on TikTok")
562
+
563
+ page.close()
564
+
565
+ else:
539
566
  try:
540
- page.click("div.TUXButton-label:has-text('Edit video')")
567
+ page.click('button.TUXButton.TUXButton--default.TUXButton--large.TUXButton--secondary:has-text("Save draft")', timeout=10000)
568
+ except:
569
+ sys.exit("SAVE AS DRAFT BUTTON NOT FOUND; CANNOT ADD SOUND WITHOUT ABILITY TO SAVE DRAFTS")
570
+
571
+ time.sleep(0.5)
572
+ page.close()
573
+
574
+ browser = p.chromium.launch(headless=True)
575
+
576
+ context = browser.new_context()
577
+ context.add_cookies(cookies)
578
+ page = context.new_page()
579
+ url2 = 'https://www.tiktok.com/tiktokstudio/content?tab=draft'
580
+
581
+ while retries < 2:
582
+ try:
583
+ page.goto(url2, timeout=30000)
584
+ except:
585
+ retries +=1
586
+ time.sleep(5)
587
+ if retries == 2:
588
+ sys.exit("ERROR: TIK TOK PAGE FAILED TO LOAD, try again.")
589
+ else:
590
+ break
591
+
592
+ try:
593
+ page.wait_for_selector("path[d='M37.37 4.85a4.01 4.01 0 0 0-.99-.79 3 3 0 0 0-2.72 0c-.45.23-.81.6-1 .79a9 9 0 0 1-.04.05l-19.3 19.3c-1.64 1.63-2.53 2.52-3.35 3.47a36 36 0 0 0-4.32 6.16c-.6 1.1-1.14 2.24-2.11 4.33l-.3.6c-.4.75-.84 1.61-.8 2.43a2.5 2.5 0 0 0 2.37 2.36c.82.05 1.68-.4 2.44-.79l.59-.3c2.09-.97 3.23-1.5 4.33-2.11a36 36 0 0 0 6.16-4.32c.95-.82 1.84-1.71 3.47-3.34l19.3-19.3.05-.06a3 3 0 0 0 .78-3.71c-.22-.45-.6-.81-.78-1l-.02-.02-.03-.03-3.67-3.67a8.7 8.7 0 0 1-.06-.05ZM16.2 26.97 35.02 8.15l2.83 2.83L19.03 29.8c-1.7 1.7-2.5 2.5-3.33 3.21a32 32 0 0 1-7.65 4.93 32 32 0 0 1 4.93-7.65c.73-.82 1.51-1.61 3.22-3.32Z']")
594
+ page.click("path[d='M37.37 4.85a4.01 4.01 0 0 0-.99-.79 3 3 0 0 0-2.72 0c-.45.23-.81.6-1 .79a9 9 0 0 1-.04.05l-19.3 19.3c-1.64 1.63-2.53 2.52-3.35 3.47a36 36 0 0 0-4.32 6.16c-.6 1.1-1.14 2.24-2.11 4.33l-.3.6c-.4.75-.84 1.61-.8 2.43a2.5 2.5 0 0 0 2.37 2.36c.82.05 1.68-.4 2.44-.79l.59-.3c2.09-.97 3.23-1.5 4.33-2.11a36 36 0 0 0 6.16-4.32c.95-.82 1.84-1.71 3.47-3.34l19.3-19.3.05-.06a3 3 0 0 0 .78-3.71c-.22-.45-.6-.81-.78-1l-.02-.02-.03-.03-3.67-3.67a8.7 8.7 0 0 1-.06-.05ZM16.2 26.97 35.02 8.15l2.83 2.83L19.03 29.8c-1.7 1.7-2.5 2.5-3.33 3.21a32 32 0 0 1-7.65 4.93 32 32 0 0 1 4.93-7.65c.73-.82 1.51-1.61 3.22-3.32Z']")
595
+ page.wait_for_selector('div[data-contents="true"]')
596
+ page.wait_for_function("document.querySelector('.info-progress-num').textContent.trim() === '100%'", timeout=3000000)
597
+ time.sleep(0.2)
541
598
  except:
542
- sound_fail = True
543
- if sound_fail == False:
599
+ sys.exit("ERROR ADDING SOUND: Video saved as draft")
600
+
601
+ if sound_name != None:
602
+ page.click("div.TUXButton-label:has-text('Edit video')")
544
603
  page.wait_for_selector("input.search-bar-input")
545
604
  page.fill(f"input.search-bar-input", f"{sound_name}")
546
605
  time.sleep(0.2)
@@ -593,150 +652,11 @@ def upload_tiktok(video, description, accountname, hashtags=None, sound_name=Non
593
652
  page.click("div.TUXButton-label:has-text('Save edit')")
594
653
  if suppressprint == False:
595
654
  print("Added sound")
596
-
597
- if sound_fail == False:
655
+
598
656
  page.wait_for_selector('div[data-contents="true"]')
599
657
 
600
658
  if copyrightcheck == True:
601
- page.click('div.TUXSwitch:has(label.TUXSwitch-label:has-text("Run a copyright check")) input.TUXSwitch-input')
602
- while copyrightcheck == True:
603
- time.sleep(0.2)
604
- if page.locator("span", has_text="No issues detected.").is_visible():
605
- if suppressprint == False:
606
- print("Copyright check complete")
607
- break
608
- if page.locator("span", has_text="Copyright issues detected.").is_visible():
609
- sys.exit("COPYRIGHT CHECK FAILED: VIDEO SAVED AS DRAFT, COPYRIGHT AUDIO DETECTED FROM TIKTOK")
610
-
611
-
612
- try:
613
- if schedule == None:
614
- page.click('button.TUXButton.TUXButton--default.TUXButton--large.TUXButton--primary:has-text("Post")', timeout=10000)
615
- uploaded = False
616
- checks = 0
617
- while uploaded == False:
618
- if page.locator(':has-text("Leaving the page does not interrupt")').nth(0).is_visible():
619
- time.sleep(0.1)
620
- break
621
- time.sleep(0.2)
622
- checks += 1
623
- if checks == 25:
624
- break
625
- else:
626
- page.click('button.TUXButton.TUXButton--default.TUXButton--large.TUXButton--primary:has-text("Schedule")', timeout=10000)
627
- uploaded = False
628
- checks = 0
629
- while uploaded == False:
630
- if page.locator(':has-text("Leaving the page does not interrupt")').nth(0).is_visible():
631
- time.sleep(0.2)
632
- break
633
- time.sleep(0.2)
634
- checks += 1
635
- if checks == 25:
636
- break
637
- if suppressprint == False:
638
- print("Done uploading video, NOTE: it may take a minute or two to show on TikTok")
639
- except:
640
- time.sleep(2)
641
- sys.exit("POSSIBLE ERROR UPLOADING: Cannot confirm if uploaded successfully, Please check account in a minute or two to confirm.")
642
- time.sleep(1)
643
-
644
- page.close()
645
- else:
646
- try:
647
- page.click('button.TUXButton.TUXButton--default.TUXButton--large.TUXButton--secondary:has-text("Save draft")', timeout=10000)
648
- except:
649
- sys.exit("SAVE AS DRAFT BUTTON NOT FOUND; Please try account that has ability to save as draft")
650
-
651
- time.sleep(0.5)
652
- page.close()
653
-
654
- browser = p.chromium.launch(headless=headless)
655
-
656
- context = browser.new_context()
657
- context.add_cookies(cookies)
658
- page = context.new_page()
659
- url2 = 'https://www.tiktok.com/tiktokstudio/content?tab=draft'
660
-
661
- while retries < 2:
662
- try:
663
- page.goto(url2, timeout=30000)
664
- except:
665
- retries +=1
666
- time.sleep(5)
667
- if retries == 2:
668
- sys.exit("ERROR: TIK TOK PAGE FAILED TO LOAD, try again.")
669
- else:
670
- break
671
-
672
- try:
673
- page.wait_for_selector("path[d='M37.37 4.85a4.01 4.01 0 0 0-.99-.79 3 3 0 0 0-2.72 0c-.45.23-.81.6-1 .79a9 9 0 0 1-.04.05l-19.3 19.3c-1.64 1.63-2.53 2.52-3.35 3.47a36 36 0 0 0-4.32 6.16c-.6 1.1-1.14 2.24-2.11 4.33l-.3.6c-.4.75-.84 1.61-.8 2.43a2.5 2.5 0 0 0 2.37 2.36c.82.05 1.68-.4 2.44-.79l.59-.3c2.09-.97 3.23-1.5 4.33-2.11a36 36 0 0 0 6.16-4.32c.95-.82 1.84-1.71 3.47-3.34l19.3-19.3.05-.06a3 3 0 0 0 .78-3.71c-.22-.45-.6-.81-.78-1l-.02-.02-.03-.03-3.67-3.67a8.7 8.7 0 0 1-.06-.05ZM16.2 26.97 35.02 8.15l2.83 2.83L19.03 29.8c-1.7 1.7-2.5 2.5-3.33 3.21a32 32 0 0 1-7.65 4.93 32 32 0 0 1 4.93-7.65c.73-.82 1.51-1.61 3.22-3.32Z']")
674
- page.click("path[d='M37.37 4.85a4.01 4.01 0 0 0-.99-.79 3 3 0 0 0-2.72 0c-.45.23-.81.6-1 .79a9 9 0 0 1-.04.05l-19.3 19.3c-1.64 1.63-2.53 2.52-3.35 3.47a36 36 0 0 0-4.32 6.16c-.6 1.1-1.14 2.24-2.11 4.33l-.3.6c-.4.75-.84 1.61-.8 2.43a2.5 2.5 0 0 0 2.37 2.36c.82.05 1.68-.4 2.44-.79l.59-.3c2.09-.97 3.23-1.5 4.33-2.11a36 36 0 0 0 6.16-4.32c.95-.82 1.84-1.71 3.47-3.34l19.3-19.3.05-.06a3 3 0 0 0 .78-3.71c-.22-.45-.6-.81-.78-1l-.02-.02-.03-.03-3.67-3.67a8.7 8.7 0 0 1-.06-.05ZM16.2 26.97 35.02 8.15l2.83 2.83L19.03 29.8c-1.7 1.7-2.5 2.5-3.33 3.21a32 32 0 0 1-7.65 4.93 32 32 0 0 1 4.93-7.65c.73-.82 1.51-1.61 3.22-3.32Z']")
675
- page.wait_for_selector('div[data-contents="true"]')
676
- time.sleep(0.2)
677
- except:
678
- sys.exit("ERROR ADDING SOUND: Video saved as draft")
679
-
680
- if sound_name != None:
681
- page.click("div.TUXButton-label:has-text('Edit video')")
682
- page.wait_for_selector("input.search-bar-input")
683
- page.fill(f"input.search-bar-input", f"{sound_name}")
684
- time.sleep(0.2)
685
- page.click("div.TUXButton-label:has-text('Search')")
686
- try:
687
- page.wait_for_selector('div.music-card-container')
688
- page.click("div.music-card-container")
689
- page.wait_for_selector("div.TUXButton-label:has-text('Use')")
690
- page.click("div.TUXButton-label:has-text('Use')")
691
- except:
692
- sys.exit(f"ERROR: SOUND '{sound_name}' NOT FOUND")
693
- try:
694
- page.wait_for_selector('img[src=""]')
695
- page.click('img[src=""]')
696
- time.sleep(0.5)
697
- sliders = page.locator("input.scaleInput")
698
-
699
- if sound_aud_vol == 'background':
700
- slider1 = sliders.nth(0)
701
- bounding_box1 = slider1.bounding_box()
702
- if bounding_box1:
703
- x1 = bounding_box1["x"] + (bounding_box1["width"] * 0.92)
704
- y1 = bounding_box1["y"] + bounding_box1["height"] / 2
705
- page.mouse.click(x1, y1)
706
-
707
- slider2 = sliders.nth(1)
708
- bounding_box2 = slider2.bounding_box()
709
- if bounding_box2:
710
- x2 = bounding_box2["x"] + (bounding_box2["width"] * 0.097)
711
- y2 = bounding_box2["y"] + bounding_box2["height"] / 2
712
- page.mouse.click(x2, y2)
713
-
714
- if sound_aud_vol == 'main':
715
- slider1 = sliders.nth(0)
716
- bounding_box1 = slider1.bounding_box()
717
- if bounding_box1:
718
- x1 = bounding_box1["x"] + (bounding_box1["width"] * 0.092)
719
- y1 = bounding_box1["y"] + bounding_box1["height"] / 2
720
- page.mouse.click(x1, y1)
721
- slider2 = sliders.nth(1)
722
- bounding_box2 = slider2.bounding_box()
723
- if bounding_box2:
724
- x2 = bounding_box2["x"] + (bounding_box2["width"] * 0.92)
725
- y2 = bounding_box2["y"] + bounding_box2["height"] / 2
726
- page.mouse.click(x2, y2)
727
- except:
728
- sys.exit("ERROR ADJUSTING SOUND VOLUME: please try again.")
729
-
730
- page.wait_for_selector("div.TUXButton-label:has-text('Save edit')")
731
- page.click("div.TUXButton-label:has-text('Save edit')")
732
- if suppressprint == False:
733
- print("Added sound")
734
-
735
-
736
- page.wait_for_selector('div[data-contents="true"]')
737
-
738
- if copyrightcheck == True:
739
- page.click('div.TUXSwitch:has(label.TUXSwitch-label:has-text("Run a copyright check")) input.TUXSwitch-input')
659
+ page.locator(".TUXSwitch-input").nth(0).click()
740
660
  while copyrightcheck == True:
741
661
  time.sleep(0.2)
742
662
  if page.locator("span", has_text="No issues detected.").is_visible():
@@ -758,7 +678,9 @@ def upload_tiktok(video, description, accountname, hashtags=None, sound_name=Non
758
678
  break
759
679
  time.sleep(0.2)
760
680
  checks += 1
761
- if checks == 25:
681
+ if checks > 100:
682
+ time.sleep(10)
683
+ if checks == 150:
762
684
  break
763
685
  else:
764
686
  page.click('button.TUXButton.TUXButton--default.TUXButton--large.TUXButton--primary:has-text("Schedule")', timeout=10000)
@@ -766,19 +688,19 @@ def upload_tiktok(video, description, accountname, hashtags=None, sound_name=Non
766
688
  checks = 0
767
689
  while uploaded == False:
768
690
  if page.locator(':has-text("Leaving the page does not interrupt")').nth(0).is_visible():
769
- time.sleep(0.1)
691
+ time.sleep(0.2)
770
692
  break
771
693
  time.sleep(0.2)
772
694
  checks += 1
773
- if checks == 25:
695
+ if checks > 100:
696
+ time.sleep(10)
697
+ if checks == 150:
774
698
  break
775
699
  if suppressprint == False:
776
700
  print("Done uploading video, NOTE: it may take a minute or two to show on TikTok")
777
701
  except:
778
- time.sleep(2)
779
- sys.exit("POSSIBLE ERROR UPLOADING: Cannot confirm if uploaded successfully, Please check account in a minute or two to confirm.")
702
+ time.sleep(5)
703
+ sys.exit("ERROR UPLOADING: VIDEO HAS SAVED AS DRAFT BUT CANT UPLOAD")
780
704
  time.sleep(1)
781
705
 
782
- page.close()
783
-
784
- return "Completed"
706
+ page.close()
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: tiktokautouploader
3
- Version: 3.5
3
+ Version: 3.14
4
4
  Summary: Upload or schedule videos to TikTok with viral TikTok sounds and hashtags.
5
5
  Project-URL: Homepage, https://github.com/haziq-exe/TikTokAutoUploader
6
6
  Author-email: HAZIQ <haziqmk123@gmail.com>
@@ -17,6 +17,7 @@ Requires-Dist: inference>=0.18.1
17
17
  Requires-Dist: pillow>=8.0.0
18
18
  Requires-Dist: playwright>=1.0.0
19
19
  Requires-Dist: requests>=2.0.0
20
+ Requires-Dist: scikit-learn>=0.24.0
20
21
  Description-Content-Type: text/markdown
21
22
 
22
23
  <div align="center">
@@ -28,8 +29,9 @@ Description-Content-Type: text/markdown
28
29
 
29
30
  [![PyPI version](https://img.shields.io/pypi/v/tiktokautouploader.svg)](https://pypi.org/project/tiktokautouploader/) [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
30
31
 
32
+
31
33
  <p align="center">
32
- <img src="READMEimage/READMEGIF.gif" alt="" width="900"/>
34
+ <img src="READMEimage/READMEvid.gif" alt="" width="900"/>
33
35
  </p>
34
36
 
35
37
  ## 🚀 Features
@@ -42,8 +44,6 @@ Description-Content-Type: text/markdown
42
44
  - **⏰ Cutdown on upload time:** Upload to TikTok with way less hassle and much more speed using our library.
43
45
  - **📝 Upload to different accounts:** Stay organized and on top of multiple different accounts with our multi-account functionality.
44
46
 
45
- ⭐️ If you like this project please feel free to star it, Thank you.
46
-
47
47
  ## 📦 Installation
48
48
 
49
49
  1. **Python Installation:** Install the package using `pip`:
@@ -143,10 +143,4 @@ Created by **Haziq**. Feel free to reach out at [haziqmk123@gmail.com](mailto:ha
143
143
  ## 📄 License
144
144
 
145
145
  This project is licensed under the MIT License. See the [LICENSE](LICENSE.md) file for details.
146
-
147
- ## 📮 Related Projects
148
-
149
- If you liked this project please check out my use case showcase project that generates TikToks and uploads them using 'tiktokautouploader'
150
-
151
- [TikTokGenerator](https://github.com/haziq-exe/TikTokGenerator)
152
-
146
+ ```
@@ -0,0 +1,7 @@
1
+ tiktokautouploader/__init__.py,sha256=u7OWCK_u68ST8dfrkSF4Yw44CJOzV9NXI6ASRuoDfmE,64
2
+ tiktokautouploader/function.py,sha256=vR2ELk1ydps0K9nhA1bxIc2Cf3d5qbvfRm3wUxkDEyk,35292
3
+ tiktokautouploader/Js_assets/login.js,sha256=SLhtPYo8ZfTRUnbR7Xqp084lSuAOqIWUxi75FlFH3vs,966
4
+ tiktokautouploader-3.14.dist-info/METADATA,sha256=9AoqNXOcgyMZyvhgx2bB06uj5uq4caZxge7JyWJbloU,5862
5
+ tiktokautouploader-3.14.dist-info/WHEEL,sha256=fl6v0VwpzfGBVsGtkAkhILUlJxROXbA3HvRL6Fe3140,105
6
+ tiktokautouploader-3.14.dist-info/licenses/LICENSE.md,sha256=hYds_VJIpnS5gC73WhuWk2IY_e9BWjuEJthQCb9ThyU,1073
7
+ tiktokautouploader-3.14.dist-info/RECORD,,
@@ -1,7 +0,0 @@
1
- tiktokautouploader/__init__.py,sha256=u7OWCK_u68ST8dfrkSF4Yw44CJOzV9NXI6ASRuoDfmE,64
2
- tiktokautouploader/function.py,sha256=wH2bcLPMfahox8toEc6L11NtVIE5JHMyj-13VCQPtjw,44652
3
- tiktokautouploader/Js_assets/login.js,sha256=SLhtPYo8ZfTRUnbR7Xqp084lSuAOqIWUxi75FlFH3vs,966
4
- tiktokautouploader-3.5.dist-info/METADATA,sha256=uHiOyXy8K0766nma3U1wHcUCs_Nc0-De0S_WerXE7RA,6125
5
- tiktokautouploader-3.5.dist-info/WHEEL,sha256=fl6v0VwpzfGBVsGtkAkhILUlJxROXbA3HvRL6Fe3140,105
6
- tiktokautouploader-3.5.dist-info/licenses/LICENSE.md,sha256=hYds_VJIpnS5gC73WhuWk2IY_e9BWjuEJthQCb9ThyU,1073
7
- tiktokautouploader-3.5.dist-info/RECORD,,