lspci -k
07:00.0 Network controller: Broadcom Inc. and subsidiaries BCM43142 802.11b/g/n (rev 01)
Subsystem: Lenovo Device 0611
❯ ip link
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default qlen 1000
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: enp8s0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP mode DEFAULT group default qlen 1000
link/ether 60:02:92:4e:4f:b8 brd ff:ff:ff:ff:ff:ff
yay -S broadcom-wl-dkms
==> ERROR: Missing mnt kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing srv kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing lib kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing run kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing etc kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing tmp kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing lib64 kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing boot kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing dev kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing home kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing root kernel headers for module broadcom-wl/6.30.223.271.
==> ERROR: Missing var kernel headers for module broadcom-wl/6.30.223.271.
public function rules()
{
return [
'title' => 'required|string|max:255,unique:categories,title',
'slug' => 'required|string|max:255,unique:categories,slug',
];
}
public function up()
{
Schema::create('categories', function (Blueprint $table) {
$table->id();
$table->string('title');
$table->string('slug');
$table->timestamps();
});
}
<?php
namespace App\Http\Requests\Category;
use Illuminate\Contracts\Validation\Validator;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Http\Exceptions\HttpResponseException;
class StoreRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array<string, mixed>
*/
public function rules()
{
return [
'title' => 'required|string|max:255,unique:categories',
'slug' => 'required|string|max:255,unique:categories',
];
}
protected function failedValidation(Validator $validator)
{
throw new HttpResponseException(response()->json(
[
'errors' => $validator->errors(),
'status' => true
],
400
));
}
}
print(f"full_path: {full_path}")
return full_path
group_path = getGroupPathById(file_path, group_id)
new_tab = newTab(new_group_name)
group_path.append(new_tab)
new_group = newGroup(new_group_name)
group_path.append(new_group)
function eventsApiPosts()
{
register_rest_route('events/v1', 'posts', [
'methods' => WP_REST_SERVER::READABLE,
'callback' => 'eventsApiPostsFunc',
]);
}
add_action('rest_api_init', 'eventsApiPosts');
function eventsApiPostsFunc($data)
{
$term_slug = $data['term_slug'] ?? null;
$date = $data['date'];
$now = date('Y-m-d');
$current_page = $data['current_page'];
$lang = $data['lang'];
if ($date) {
if ($date === 'coming-soon') {
$meta_query = array(
array(
'key' => 'loop_event_date',
'value' => $now,
'compare' => '>',
'type' => 'DATE'
)
);
} else if ($date === 'past-events') {
$meta_query = array(
array(
'key' => 'loop_event_date',
'value' => $now,
'compare' => '<',
'type' => 'DATE'
)
);
} else {
$meta_query = array(
array(
'key' => 'loop_event_date',
'value' => $date,
'compare' => 'LIKE'
)
);
}
}
$tax_query = [];
if ($term_slug) {
$tax_query = array(
array(
'taxonomy' => 'events_category',
'field' => 'slug',
'terms' => [$term_slug],
)
);
}
$post_type = 'events';
$posts_per_page = 3;
$offset = ($current_page * $posts_per_page) - $posts_per_page;
$post_events = new WP_Query(array(
'post_type' => $post_type,
'posts_per_page' => $posts_per_page,
'offset' => $offset,
'tax_query' => $tax_query,
'meta_query' => $meta_query,
// 'orderby' => 'meta_value', // Order by meta value as numeric
// 'meta_key' => 'featured', // Meta key for sorting
// 'meta_type' => 'DATE', // Meta type
// 'order' => 'DESC',
));
$total_posts = $post_events->found_posts;
$pages = ceil($total_posts / $posts_per_page);
$events_array = $post_events->get_posts();
$events_array = array_map(function ($event) use ($lang) {
$id = $event->ID;
$title = get_the_title($id);
$term = get_the_terms($id, 'events_category')[0];
if ($lang === 'ro') {
$location = get_field('title_ro', $term);
} else {
$location = $term->name;
}
$loop = get_field('loop', $id);
$event_date = $loop['event_date'];
$short_description = $loop['short_description'];
$image = get_the_post_thumbnail_url($id);
return [
'id' => $id,
'title' => $title,
'location' => $location,
'event_date' => $event_date,
'featured' => get_field('featured', $id),
'short_description' => $short_description,
'image' => $image,
'lang' => $lang,
'term_name' => $term->name,
'permalink' => get_the_permalink($id),
];
}, $events_array);
$count = count($events_array);
return [
'lang' => $lang,
'total' => $total_posts,
'count' => $count,
'pages' => $pages,
'current_page' => $current_page,
'events' => $events_array,
'offset' => $offset,
'current_page' => $current_page,
'posts_per_page' => $posts_per_page,
];
}
Есть акаунт на bitbucket, свой, и есть акаунт компании.
В акаунте компании я создал группу и добавил пользователей, и когда создаю новый проект, подлючаю эту группу, и сразу у всех пользователе есть доступ, это удобно.
Пришел новый человек, добавил в группу, ушел, исключаю...
Проблема в том, что бесплатно только 5 чел, и взяли стажера, не было понятно будет работать или нет, и теперь я уже не вместился в эту группу, и приходилось работать из под аккаунта компании.
Вот для чего нужны несколько ключей.
Вот как я сделал.
и теперь когда клонирую, добавляю -b